| David Howells | 0bc42d7 | 2010-10-27 17:28:41 +0100 | [diff] [blame] | 1 | # | 
|  | 2 | # MN10300 CPU cache options | 
|  | 3 | # | 
|  | 4 |  | 
|  | 5 | choice | 
|  | 6 | prompt "CPU Caching mode" | 
|  | 7 | default MN10300_CACHE_WBACK | 
|  | 8 | help | 
|  | 9 | This option determines the caching mode for the kernel. | 
|  | 10 |  | 
|  | 11 | Write-Back caching mode involves the all reads and writes causing | 
|  | 12 | the affected cacheline to be read into the cache first before being | 
|  | 13 | operated upon. Memory is not then updated by a write until the cache | 
|  | 14 | is filled and a cacheline needs to be displaced from the cache to | 
|  | 15 | make room. Only at that point is it written back. | 
|  | 16 |  | 
|  | 17 | Write-Through caching only fetches cachelines from memory on a | 
|  | 18 | read. Writes always get written directly to memory. If the affected | 
|  | 19 | cacheline is also in cache, it will be updated too. | 
|  | 20 |  | 
|  | 21 | The final option is to turn of caching entirely. | 
|  | 22 |  | 
|  | 23 | config MN10300_CACHE_WBACK | 
|  | 24 | bool "Write-Back" | 
|  | 25 |  | 
|  | 26 | config MN10300_CACHE_WTHRU | 
|  | 27 | bool "Write-Through" | 
|  | 28 |  | 
|  | 29 | config MN10300_CACHE_DISABLED | 
|  | 30 | bool "Disabled" | 
|  | 31 |  | 
|  | 32 | endchoice | 
| David Howells | 344af92 | 2010-10-27 17:28:42 +0100 | [diff] [blame] | 33 |  | 
|  | 34 | config MN10300_CACHE_ENABLED | 
|  | 35 | def_bool y if !MN10300_CACHE_DISABLED | 
| David Howells | 518d4bb | 2010-10-27 17:28:43 +0100 | [diff] [blame^] | 36 |  | 
|  | 37 |  | 
|  | 38 | choice | 
|  | 39 | prompt "CPU cache flush/invalidate method" | 
|  | 40 | default MN10300_CACHE_MANAGE_BY_TAG | 
|  | 41 | depends on MN10300_CACHE_ENABLED | 
|  | 42 | help | 
|  | 43 | This determines the method by which CPU cache flushing and | 
|  | 44 | invalidation is performed. | 
|  | 45 |  | 
|  | 46 | config MN10300_CACHE_MANAGE_BY_TAG | 
|  | 47 | bool "Use the cache tag registers directly" | 
|  | 48 |  | 
|  | 49 | endchoice | 
|  | 50 |  | 
|  | 51 | config MN10300_CACHE_INV_BY_TAG | 
|  | 52 | def_bool y if MN10300_CACHE_MANAGE_BY_TAG && MN10300_CACHE_ENABLED | 
|  | 53 |  | 
|  | 54 | config MN10300_CACHE_FLUSH_BY_TAG | 
|  | 55 | def_bool y if MN10300_CACHE_MANAGE_BY_TAG && MN10300_CACHE_WBACK |