86 #if defined(RTEMS_SMP) && defined(CPU_CACHE_NO_INSTRUCTION_CACHE_SNOOPING) 91 #if CPU_DATA_CACHE_ALIGNMENT > CPU_CACHE_LINE_BYTES 92 #error "CPU_DATA_CACHE_ALIGNMENT is greater than CPU_CACHE_LINE_BYTES" 95 #if CPU_INSTRUCTION_CACHE_ALIGNMENT > CPU_CACHE_LINE_BYTES 96 #error "CPU_INSTRUCTION_CACHE_ALIGNMENT is greater than CPU_CACHE_LINE_BYTES" 111 #if defined(CPU_DATA_CACHE_ALIGNMENT) 112 #if defined(CPU_CACHE_SUPPORT_PROVIDES_RANGE_FUNCTIONS) 113 _CPU_cache_flush_data_range( d_addr, n_bytes );
115 const void * final_address;
127 final_address = (
void *)((
size_t)d_addr + n_bytes - 1);
129 while( d_addr <= final_address ) {
130 _CPU_cache_flush_1_data_line( d_addr );
145 #if defined(CPU_DATA_CACHE_ALIGNMENT) 146 #if defined(CPU_CACHE_SUPPORT_PROVIDES_RANGE_FUNCTIONS) 147 _CPU_cache_invalidate_data_range( d_addr, n_bytes );
149 const void * final_address;
161 final_address = (
void *)((
size_t)d_addr + n_bytes - 1);
163 while( final_address >= d_addr ) {
164 _CPU_cache_invalidate_1_data_line( d_addr );
178 #if defined(CPU_DATA_CACHE_ALIGNMENT) 182 _CPU_cache_flush_entire_data();
193 #if defined(CPU_DATA_CACHE_ALIGNMENT) 198 _CPU_cache_invalidate_entire_data();
208 #if defined(CPU_DATA_CACHE_ALIGNMENT) 218 #if defined(CPU_CACHE_SUPPORT_PROVIDES_CACHE_SIZE_FUNCTIONS) 219 return _CPU_cache_get_data_cache_size( level );
232 #if defined(CPU_DATA_CACHE_ALIGNMENT) 233 _CPU_cache_freeze_data();
239 #if defined(CPU_DATA_CACHE_ALIGNMENT) 240 _CPU_cache_unfreeze_data();
247 #if defined(CPU_DATA_CACHE_ALIGNMENT) 248 _CPU_cache_enable_data();
252 #if !defined(CPU_CACHE_SUPPORT_PROVIDES_DISABLE_DATA) 256 #if defined(CPU_DATA_CACHE_ALIGNMENT) 257 _CPU_cache_disable_data();
266 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) \ 267 && defined(RTEMS_SMP) \ 268 && defined(CPU_CACHE_NO_INSTRUCTION_CACHE_SNOOPING) 275 static void smp_cache_inst_inv(
void *arg)
277 smp_cache_area *area = arg;
279 _CPU_cache_invalidate_instruction_range(area->addr, area->size);
282 static void smp_cache_inst_inv_all(
void *arg)
284 _CPU_cache_invalidate_entire_instruction();
287 static void smp_cache_broadcast( SMP_Action_handler handler,
void *arg )
294 if ( isr_level == 0 ) {
297 cpu_self = _Per_CPU_Get();
300 _SMP_Broadcast_action( handler, arg );
302 if ( isr_level == 0 ) {
314 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) \ 315 && !defined(CPU_CACHE_SUPPORT_PROVIDES_RANGE_FUNCTIONS) 317 _CPU_cache_invalidate_instruction_range(
322 const void * final_address;
334 final_address = (
void *)((
size_t)i_addr + n_bytes - 1);
335 i_addr = (
void *)((
size_t)i_addr & ~(CPU_INSTRUCTION_CACHE_ALIGNMENT - 1));
336 while( final_address >= i_addr ) {
337 _CPU_cache_invalidate_1_instruction_line( i_addr );
338 i_addr = (
void *)((
size_t)i_addr + CPU_INSTRUCTION_CACHE_ALIGNMENT);
349 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 350 #if defined(RTEMS_SMP) && defined(CPU_CACHE_NO_INSTRUCTION_CACHE_SNOOPING) 351 smp_cache_area area = { i_addr, n_bytes };
353 smp_cache_broadcast( smp_cache_inst_inv, &area );
355 _CPU_cache_invalidate_instruction_range( i_addr, n_bytes );
367 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 368 #if defined(RTEMS_SMP) && defined(CPU_CACHE_NO_INSTRUCTION_CACHE_SNOOPING) 369 smp_cache_broadcast( smp_cache_inst_inv_all,
NULL );
371 _CPU_cache_invalidate_entire_instruction();
382 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 383 return CPU_INSTRUCTION_CACHE_ALIGNMENT;
392 #if defined(CPU_CACHE_SUPPORT_PROVIDES_CACHE_SIZE_FUNCTIONS) 393 return _CPU_cache_get_instruction_cache_size( level );
406 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 407 _CPU_cache_freeze_instruction();
413 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 414 _CPU_cache_unfreeze_instruction();
421 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 422 _CPU_cache_enable_instruction();
429 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 430 _CPU_cache_disable_instruction();
437 #if defined(CPU_MAXIMAL_CACHE_ALIGNMENT) 438 return CPU_MAXIMAL_CACHE_ALIGNMENT;
440 size_t max_line_size = 0;
441 #if defined(CPU_DATA_CACHE_ALIGNMENT) 444 if ( max_line_size < data_line_size )
445 max_line_size = data_line_size;
448 #if defined(CPU_INSTRUCTION_CACHE_ALIGNMENT) 450 size_t instruction_line_size = CPU_INSTRUCTION_CACHE_ALIGNMENT;
451 if ( max_line_size < instruction_line_size )
452 max_line_size = instruction_line_size;
455 return max_line_size;
466 const void *code_addr,
470 #if defined(CPU_CACHE_SUPPORT_PROVIDES_INSTRUCTION_SYNC_FUNCTION) 471 _CPU_cache_instruction_sync_after_code_change( code_addr, n_bytes );
void rtems_cache_enable_instruction(void)
Definition: cacheimpl.h:419
void rtems_cache_instruction_sync_after_code_change(const void *code_addr, size_t n_bytes)
Ensure necessary synchronization required after code changes.
Definition: cacheimpl.h:465
void rtems_cache_invalidate_entire_data(void)
Definition: cacheimpl.h:191
void rtems_cache_disable_instruction(void)
Definition: cacheimpl.h:427
void rtems_cache_freeze_data(void)
Definition: cacheimpl.h:230
Constants and Structures Related with Thread Dispatch.
void rtems_cache_enable_data(void)
Definition: cacheimpl.h:245
void rtems_cache_invalidate_multiple_instruction_lines(const void *i_addr, size_t n_bytes)
Invalidates multiple instruction cache lines.
Definition: cacheimpl.h:344
void rtems_cache_flush_multiple_data_lines(const void *d_addr, size_t n_bytes)
Flushes multiple data cache lines.
Definition: cacheimpl.h:109
#define _ISR_Get_level()
Return current interrupt level.
Definition: isrlevel.h:128
Per CPU Core Structure.
Definition: percpu.h:347
#define CPU_DATA_CACHE_ALIGNMENT
Cache definitions and functions.
Definition: cache-l2c-310.c:65
void rtems_cache_invalidate_multiple_data_lines(const void *d_addr, size_t n_bytes)
Invalidates multiple data cache lines.
Definition: cacheimpl.h:143
void rtems_cache_disable_data(void)
Definition: cacheimpl.h:254
void _Thread_Dispatch_enable(Per_CPU_Control *cpu_self)
Enables thread dispatching.
Definition: threaddispatch.c:362
size_t rtems_cache_get_data_cache_size(uint32_t level)
Returns the data cache size in bytes.
Definition: cacheimpl.h:216
size_t rtems_cache_get_data_line_size(void)
Returns the data cache line size in bytes.
Definition: cacheimpl.h:206
void rtems_cache_unfreeze_instruction(void)
Definition: cacheimpl.h:411
size_t rtems_cache_get_maximal_line_size(void)
Returns the maximal cache line size of all cache kinds in bytes.
Definition: cacheimpl.h:435
RTEMS_INLINE_ROUTINE Per_CPU_Control * _Thread_Dispatch_disable(void)
Disables thread dispatching.
Definition: threaddispatch.h:191
void rtems_cache_freeze_instruction(void)
Definition: cacheimpl.h:404
void rtems_cache_unfreeze_data(void)
Definition: cacheimpl.h:237
size_t rtems_cache_get_instruction_line_size(void)
Returns the instruction cache line size in bytes.
Definition: cacheimpl.h:380
void rtems_cache_invalidate_entire_instruction(void)
Invalidates the entire instruction cache.
Definition: cacheimpl.h:365
void rtems_cache_flush_entire_data(void)
Flushes the entire data cache.
Definition: cacheimpl.h:176
unsigned size
Definition: tte.h:74
size_t rtems_cache_get_instruction_cache_size(uint32_t level)
Returns the instruction cache size in bytes.
Definition: cacheimpl.h:390
SuperCore SMP Implementation.
#define NULL
Requests a GPIO pin group configuration.
Definition: bestcomm_api.h:77