Skip to content

Commit

Permalink
platform: intel: ace: remove redundant definitions from memory.h
Browse files Browse the repository at this point in the history
Platforms that can only be built with Zephyr, can directly use
Zephyr cached/uncached functions in memory.h. It turns out the SRAM
address and size definitions were only needed for these duplicate
cache operations, so they can be removed as well.

Signed-off-by: Kai Vehmanen <[email protected]>
  • Loading branch information
kv2019i committed Sep 10, 2024
1 parent 1a27843 commit 19ea950
Showing 1 changed file with 4 additions and 23 deletions.
27 changes: 4 additions & 23 deletions src/platform/intel/ace/include/ace/lib/memory.h
Original file line number Diff line number Diff line change
Expand Up @@ -34,30 +34,11 @@
#define PLATFORM_LPSRAM_EBB_COUNT (DT_REG_SIZE(DT_NODELABEL(sram1)) / SRAM_BANK_SIZE)
#define PLATFORM_HPSRAM_EBB_COUNT (DT_REG_SIZE(DT_NODELABEL(sram0)) / SRAM_BANK_SIZE)

#define SRAM_CACHED_BASE 0xA0000000
#define SRAM_BASE 0x40000000
#define SRAM_ALIAS_MASK 0xF0000000
#define SRAM_ALIAS_OFFSET 0x60000000
#include <zephyr/cache.h>

#if !defined UNIT_TEST
static inline void __sparse_cache *uncache_to_cache(void *address)
{
return (void __sparse_cache *)(((uintptr_t)(address) & ~SRAM_ALIAS_MASK) |
SRAM_CACHED_BASE);
}

static inline void *cache_to_uncache(void __sparse_cache *address)
{
return (void *)(((uintptr_t)(address) & ~SRAM_ALIAS_MASK) | SRAM_BASE);
}

#define is_uncached(address) \
(((uint32_t)(address) & SRAM_ALIAS_MASK) == SRAM_BASE)
#else
#define uncache_to_cache(address) address
#define cache_to_uncache(address) address
#define is_uncached(address) 0
#endif
#define uncache_to_cache(address) sys_cache_cached_ptr_get(address)
#define cache_to_uncache(address) sys_cache_uncached_ptr_get(address)
#define is_uncached(address) sys_cache_is_ptr_cached(address)

/**
* \brief Returns pointer to the memory shared by multiple cores.
Expand Down

0 comments on commit 19ea950

Please sign in to comment.