Symbian3/PDK/Source/GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC.dita
changeset 1 25a17d01db0c
child 3 46218c8b8afa
equal deleted inserted replaced
0:89d6a7a84779 1:25a17d01db0c
       
     1 <?xml version="1.0" encoding="utf-8"?>
       
     2 <!-- Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies) All rights reserved. -->
       
     3 <!-- This component and the accompanying materials are made available under the terms of the License 
       
     4 "Eclipse Public License v1.0" which accompanies this distribution, 
       
     5 and is available at the URL "http://www.eclipse.org/legal/epl-v10.html". -->
       
     6 <!-- Initial Contributors:
       
     7     Nokia Corporation - initial contribution.
       
     8 Contributors: 
       
     9 -->
       
    10 <!DOCTYPE concept
       
    11   PUBLIC "-//OASIS//DTD DITA Concept//EN" "concept.dtd">
       
    12 <concept id="GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC" xml:lang="en"><title>Remapping
       
    13 Cache Attributes and Access Permissions on ARMv6K and ARMv7 Platforms</title><shortdesc>Describes the behavior change brought about by remapping the cache
       
    14 attributes and the access permissions on the ARMv6K (ARM1176 &amp; ARM11MPCore),
       
    15 ARMv7 (Cortex-8N), and future platforms.</shortdesc><prolog><metadata><keywords/></metadata></prolog><conbody>
       
    16 <ul>
       
    17 <li id="GUID-50632F8E-91A0-597C-8176-9FE352A8B9ED"><p> <xref href="GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC.dita#GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC/GUID-B8EA1997-C922-5E98-A32E-A77D641D11BC">Reduced set access permissions</xref>  </p> <ul>
       
    18 <li id="GUID-9225B023-192F-5D04-92BA-0278768872FF"><p> <xref href="GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC.dita#GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC/GUID-ABBF3854-B8B8-52A0-B3F6-1DF44A37194A">Affected kernel interface</xref>  </p> </li>
       
    19 </ul> </li>
       
    20 <li id="GUID-9851FDDF-8F0E-5AF1-AF7F-9C6273E9B0A8"><p> <xref href="GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC.dita#GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC/GUID-E137E4E9-AADA-5BCE-8FC8-504ACD486394">Remapping cache attributes</xref>  </p> <ul>
       
    21 <li id="GUID-6B59981E-754F-5E9B-80F1-99D53D464B70"><p> <xref href="GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC.dita#GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC/GUID-EDFD1FE0-ACD7-54B4-9633-0149E3FDF551">Types of memory supported</xref>  </p> </li>
       
    22 <li id="GUID-057483C0-F40F-503D-82D7-B2CC199AC9F9"><p> <xref href="GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC.dita#GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC/GUID-548E9689-F7AB-5F61-A8AE-EA2043E70D34">Mapping existing memory types</xref>  </p> </li>
       
    23 <li id="GUID-4D7899BC-B6AD-5C9F-9135-7E37F2CFC21E"><p> <xref href="GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC.dita#GUID-EC2D5CA5-538C-5375-B00D-3107CD87CFFC/GUID-F90E6B00-6492-5471-975F-3C078046627A">Mapping ARMv6K or ARMv7 onto TMappingAttributes</xref>. </p> </li>
       
    24 </ul> </li>
       
    25 </ul>
       
    26 <section id="GUID-B8EA1997-C922-5E98-A32E-A77D641D11BC"><title>Reduced set
       
    27 access permissions</title> <p>The ARMv6-style page table reserves three bits
       
    28 in the page/directory table for access permission, so eight possible values
       
    29 are available. The use of four possible access permissions is sufficient.
       
    30 Therefore, removing the surplus access permissions frees up one page table
       
    31 bit that is used by Symbian platform internally. </p> <p id="GUID-ABBF3854-B8B8-52A0-B3F6-1DF44A37194A"><b>Affected kernel interface</b> </p> <p>The
       
    32 shadow pages kernel interface is valid on all platforms except for the emulator.
       
    33 On ARMv6 and previous platforms, shadow pages are created using access permission <codeph>PrivilegedRW/UserRO</codeph>,
       
    34 this is not supported by the limited set of encoding. Shadow pages are now
       
    35 mapped as <codeph>PrivilegedRO/UserRO</codeph>, instead. </p> <codeblock id="GUID-9197EF7D-F549-5144-A322-4C04CD80CFCC" xml:space="preserve">class Epoc
       
    36     {
       
    37 public:
       
    38     ...
       
    39     IMPORT_C static TInt AllocShadowPage(TLinAddr aRomAddr);
       
    40     IMPORT_C static TInt FreeShadowPage(TLinAddr aRomAddr);
       
    41     IMPORT_C static TInt FreezeShadowPage(TLinAddr aRomAddr);
       
    42     ...
       
    43     };</codeblock> <p>This represents a serious behaviour break in the kernel
       
    44 interface. A device driver (running on ARMv7) that creates a shadow page and
       
    45 then attempts to alter the content of the page now panics. </p> <p>This is
       
    46 a common use case for run-mode debuggers. However, a debugging interface is
       
    47 already provided, see <xref href="GUID-E91A8060-77E3-35F0-A945-7081406C79CE.dita"><apiname>DebugSupport</apiname></xref> in <filepath>...\memmodel\epoc\platform.h</filepath>,
       
    48 where breakpoints are managed internally by the kernel. Therefore, it is believed
       
    49 that a run-time debugger that uses the <codeph>CodeModifier</codeph> implementation
       
    50 in the kernel should not be affected by this change. </p> <p>After a shadow
       
    51 page is created using <xref href="GUID-3DC7B5F2-512E-3FF3-BC08-945DDE2AE680.dita#GUID-3DC7B5F2-512E-3FF3-BC08-945DDE2AE680/GUID-4FA10D18-3BA2-3307-B2E1-77C9CD8D2B6B"><apiname>Epoc::AllocShadowPage()</apiname></xref>, the kernel
       
    52 allows the device driver to alter its content using <xref href="GUID-3DC7B5F2-512E-3FF3-BC08-945DDE2AE680.dita#GUID-3DC7B5F2-512E-3FF3-BC08-945DDE2AE680/GUID-5B889008-BC18-3127-89EF-B8EAB0834190"><apiname>Epoc::CopyToShadowMemory()</apiname></xref>. </p> <p><note> <xref href="GUID-3DC7B5F2-512E-3FF3-BC08-945DDE2AE680.dita#GUID-3DC7B5F2-512E-3FF3-BC08-945DDE2AE680/GUID-EF014DA2-EE35-3DBD-A325-C5648AD27C36"><apiname>Epoc::FreezeShadowPage()</apiname></xref> is obsolete for platforms that use the reduced set of access permissions,
       
    53 as the shadow memory is always in a “frozen” state, because it can only be
       
    54 changed through the kernel interface.</note> </p> </section>
       
    55 <section id="GUID-E137E4E9-AADA-5BCE-8FC8-504ACD486394"><title>Remapping cache
       
    56 attributes </title> <p>ARMv6 architecture uses a large number of bits in the
       
    57 page table to describe all of the options for inner and outer cachability.
       
    58 No applications use all of these options simultaneously so a smaller number
       
    59 of configurable options has been implemented to meet the needs of the system. </p> <p>This
       
    60 alternative cache mapping allows up to eight different mappings in page tables.
       
    61 The Symbian OS kernel and device drivers do not need more than four or five
       
    62 different cache mappings. </p> <p>Cache mapping cannot be altered during run-time.
       
    63 It must be configured before the MMU is initialised. </p> <p>See the Bootstrap <xref href="GUID-5EB03086-A87D-5588-8927-7A7F8DB38366.dita">Port Implementation Tutorial</xref>. </p> <p id="GUID-EDFD1FE0-ACD7-54B4-9633-0149E3FDF551"><b>Types of memory supported</b> </p> <p>The
       
    64 kernel supports the following types of memory: </p> <table id="GUID-23FAD8A6-579B-5E3D-A705-A53BA304D529">
       
    65 <tgroup cols="2"><colspec colname="col0"/><colspec colname="col1"/>
       
    66 <tbody>
       
    67 <row>
       
    68 <entry><p> <b>Memory type</b>  </p> </entry>
       
    69 <entry><p> <b>Description</b>  </p> </entry>
       
    70 </row>
       
    71 <row>
       
    72 <entry><p> <codeph>EMemAttStronglyOrdered</codeph>  </p> </entry>
       
    73 <entry><p>Writes are not combined. The order of memory accesses is preserved.
       
    74 Serves as a memory barrier, which means: </p> <ul>
       
    75 <li id="GUID-800FC168-69E5-5A89-B5A4-F34AF25E7F9E"><p>previous accesses to
       
    76 any type of memory must complete before accesses to strongly ordered memory
       
    77 start </p> </li>
       
    78 <li id="GUID-75C9FA7F-3BCC-50FE-B053-A48DEF46A2D2"><p>accesses to strongly
       
    79 ordered memory must complete before any further access to any type of memory
       
    80 takes place. </p> </li>
       
    81 </ul> <p>This type is used for hardware mapping. </p> </entry>
       
    82 </row>
       
    83 <row>
       
    84 <entry><p> <codeph>EMemAttDevice</codeph>  </p> </entry>
       
    85 <entry><p>Writes are not combined. The order of memory accesses is preserved.
       
    86 This type is used for hardware mapping. </p> </entry>
       
    87 </row>
       
    88 <row>
       
    89 <entry><p> <codeph>EMemAttNormalUncached</codeph>  </p> </entry>
       
    90 <entry><p>Non cacheable memory: The order of accesses is not preserved. Writes
       
    91 may be combined. For example, this is used for video memory. </p> </entry>
       
    92 </row>
       
    93 <row>
       
    94 <entry><p> <codeph>EMemAttNormalCached</codeph>  </p> </entry>
       
    95 <entry><p>Write-back read/write allocate cached memory, inner and outer. Used
       
    96 for “ordinary” memory. </p> </entry>
       
    97 </row>
       
    98 </tbody>
       
    99 </tgroup>
       
   100 </table> <p> <note> Device memory and normal memory can be set as shared or
       
   101 non-shared, strongly ordered accesses are assumed to be shared. </note></p> <p>The
       
   102 complete set of memory types supported by Symbian platform are represented
       
   103 by the values of the <xref href="GUID-7CB34E6F-CBF7-3F04-8CB1-2D6C29C73992.dita"><apiname>TMemoryType</apiname></xref> enum. </p> <p id="GUID-548E9689-F7AB-5F61-A8AE-EA2043E70D34"><b>Mapping existing memory
       
   104 types</b> </p> <p>The <xref href="GUID-1CE7A793-6313-372C-AC1A-6D3F6C6F5042.dita"><apiname>TMappingAttributes</apiname></xref> constants allow
       
   105 the cache attributes to be manipulated. On remapped platforms, these map into <xref href="GUID-7CB34E6F-CBF7-3F04-8CB1-2D6C29C73992.dita"><apiname>TMemoryType</apiname></xref> as
       
   106 follows: </p> <table id="GUID-24B0E1CD-67D9-5FAD-8984-9E202975F7EA">
       
   107 <tgroup cols="2"><colspec colname="col0"/><colspec colname="col1"/>
       
   108 <tbody>
       
   109 <row>
       
   110 <entry><p> <b> Memory type described by TMappingAttributes</b>  </p> </entry>
       
   111 <entry><p> <b>Memory type</b>  </p> </entry>
       
   112 </row>
       
   113 <row>
       
   114 <entry><p> <xref href="GUID-27DA5FEE-8F76-3D9E-8726-FA5CB808680A.dita"><apiname>EMapAttrFullyBlocking</apiname></xref>  </p> </entry>
       
   115 <entry><p> <xref href="GUID-F6F245E9-9DB7-3BEF-8F58-9A7F8E0F5D59.dita"><apiname>EMemAttStronglyOrdered</apiname></xref>  </p> </entry>
       
   116 </row>
       
   117 <row>
       
   118 <entry><p> <xref href="GUID-B8ACFB0F-B457-358F-96EF-94BFBA6FE4A5.dita"><apiname>EMapAttrBufferedNC</apiname></xref>  </p> <p> <xref href="GUID-468C3800-7AEE-3219-9EBB-9C52971B3E0E.dita"><apiname>EMapAttrBufferedC</apiname></xref>  </p> </entry>
       
   119 <entry><p> <xref href="GUID-922F4FB9-57C0-31BF-ADFB-CC6B8376A39B.dita"><apiname>EMemAttDevice</apiname></xref>  </p> </entry>
       
   120 </row>
       
   121 <row>
       
   122 <entry><p> <xref href="GUID-AE44E6A7-5CD2-31D9-A701-188B26CDEBB0.dita"><apiname>EMapAttrL1Uncached</apiname></xref>  </p> <p> <xref href="GUID-5ADA8BB4-A7B9-3347-B9A8-B50BE92F66BC.dita"><apiname>EMapAttrCachedWTRA</apiname></xref>  </p> <p> <xref href="GUID-54A8E3DA-996D-3317-A129-9AD12201E3C1.dita"><apiname>EMapAttrCachedWTWA</apiname></xref>  </p> </entry>
       
   123 <entry><p> <xref href="GUID-FD4404AF-192C-3D20-A4BC-AE1181A14E43.dita"><apiname> EMemAttNormalUncached</apiname></xref>  </p> </entry>
       
   124 </row>
       
   125 <row>
       
   126 <entry><p> <xref href="GUID-FA3DD609-9C88-38C9-8719-4AB28B8E84EA.dita"><apiname>EMapAttrCachedWBRA</apiname></xref>  </p> <p> <xref href="GUID-9B211A60-6B45-31D5-A096-2B7944E651A0.dita"><apiname>EMapAttrCachedWBWA</apiname></xref>  </p> <p> <xref href="GUID-BB620F1F-FD18-3FCB-B1FC-7C3555F471B6.dita"><apiname>EMapAttrL1CachedMax</apiname></xref>  </p> <p> <xref href="GUID-72222BDB-E369-3D03-B3EE-A04B125EB2A3.dita"><apiname>EmapAttrCachedMax</apiname></xref>  </p> </entry>
       
   127 <entry><p> <xref href="GUID-2191E3C7-5F22-38D1-BB16-BD78B44AE7AA.dita"><apiname>EMemAttNormalCached</apiname></xref>  </p> </entry>
       
   128 </row>
       
   129 <row>
       
   130 <entry><p> <xref href="GUID-A647726F-5569-3EAA-9E24-70FBEAF6F94B.dita"><apiname>EMapAttrAltCacheWTRA</apiname></xref>  </p> <p> <xref href="GUID-23C6459E-65F4-317E-B22D-6AB91A2F3462.dita"><apiname>EMapAttrAltCacheWTWA</apiname></xref>  </p> <p> <xref href="GUID-4F97DE5E-3031-3AB5-9646-996DD1EB9C15.dita"><apiname>EMapAttrAltCacheWBRA</apiname></xref>  </p> <p> <xref href="GUID-D34AE0F7-21A3-3B8C-B768-1A7840257780.dita"><apiname>EMapAttrAltCacheWBWA</apiname></xref>  </p> </entry>
       
   131 <entry><p>Return error </p> </entry>
       
   132 </row>
       
   133 <row>
       
   134 <entry><p> <xref href="GUID-1E6DD28F-F53C-34F0-B5A1-88263389ACF7.dita"><apiname>EMapAttrL2CachedWTRA</apiname></xref>  </p> <p> <xref href="GUID-1695C568-36F8-3860-8253-D25CC6F2100E.dita"><apiname>EMapAttrL2CachedWTWA</apiname></xref>  </p> <p> <xref href="GUID-E82A15FB-6A92-388F-A6F2-AA0DBAC720E8.dita"><apiname>EMapAttrL2CachedWBRA</apiname></xref>  </p> <p> <xref href="GUID-CAD3DE19-9508-319E-9C61-1E7910D30AC9.dita"><apiname>EMapAttrL2CachedWBWA</apiname></xref>  </p> <p> <xref href="GUID-CE3B3839-E9B5-3B8F-AB41-3F589CD3347C.dita"><apiname>EMapAttrL2CachedMax</apiname></xref>  </p> </entry>
       
   135 <entry><p>Takes no effect. Only the inner cache description matters. </p> <p>This
       
   136 policy is already in place on ARMv5 platforms with L210, where the page table
       
   137 does not support a separate description of the inner and outer cache attributes. </p> </entry>
       
   138 </row>
       
   139 </tbody>
       
   140 </tgroup>
       
   141 </table> <p id="GUID-F90E6B00-6492-5471-975F-3C078046627A"><b> Mapping ARMv6K or ARMv7
       
   142 onto TMappingAttributes</b> </p> <p>To describe memory on ARMv6K or ARMv7
       
   143 using the original <xref href="GUID-1CE7A793-6313-372C-AC1A-6D3F6C6F5042.dita"><apiname>TMappingAttributes</apiname></xref> bit mask, the device
       
   144 driver should use the following values: </p> <table id="GUID-C5D9F8B3-670A-5595-BE7A-288E34E077ED">
       
   145 <tgroup cols="2"><colspec colname="col0"/><colspec colname="col1"/>
       
   146 <tbody>
       
   147 <row>
       
   148 <entry><p> <b>ARMv6K/v7 memory type TMemoryType</b>  </p> </entry>
       
   149 <entry><p> <b>TMappingAttributes mask to use</b>  </p> </entry>
       
   150 </row>
       
   151 <row>
       
   152 <entry><p> <codeph>EMemAttStronglyOrdered</codeph>  </p> </entry>
       
   153 <entry><p> <codeph>EMapAttrFullyBlocking</codeph>  </p> </entry>
       
   154 </row>
       
   155 <row>
       
   156 <entry><p> <codeph>EMemAttDevice</codeph>  </p> </entry>
       
   157 <entry><p> <codeph>EMapAttrBufferedNC</codeph>  </p> </entry>
       
   158 </row>
       
   159 <row>
       
   160 <entry><p> <codeph>EMemAttNormalUncached</codeph>  </p> </entry>
       
   161 <entry><p> <codeph>EMapAttrL1Uncached</codeph>  </p> </entry>
       
   162 </row>
       
   163 <row>
       
   164 <entry><p> <codeph>EMemAttNormalCached</codeph>  </p> </entry>
       
   165 <entry><p> <codeph>EmapAttrCachedMax</codeph>  </p> </entry>
       
   166 </row>
       
   167 </tbody>
       
   168 </tgroup>
       
   169 </table> </section>
       
   170 </conbody></concept>