From 922c57d1ba5cb53ba29bc303ab66e869065d540b Mon Sep 17 00:00:00 2001 From: Yufeng Zhang Date: Thu, 17 Jan 2013 14:27:36 +0000 Subject: [PATCH] sync-cache.c (__aarch64_sync_cache_range): Cast the results of (dcache_lsize - 1) and (icache_lsize - 1) to the type... 2013-01-17 Yufeng Zhang * config/aarch64/sync-cache.c (__aarch64_sync_cache_range): Cast the results of (dcache_lsize - 1) and (icache_lsize - 1) to the type __UINTPTR_TYPE__; also cast 'base' to the same type before the alignment operation. From-SVN: r195266 --- libgcc/ChangeLog | 7 +++++++ libgcc/config/aarch64/sync-cache.c | 6 ++++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/libgcc/ChangeLog b/libgcc/ChangeLog index 77504494477..d47f64ebb5f 100644 --- a/libgcc/ChangeLog +++ b/libgcc/ChangeLog @@ -1,3 +1,10 @@ +2013-01-17 Yufeng Zhang + + * config/aarch64/sync-cache.c (__aarch64_sync_cache_range): Cast the + results of (dcache_lsize - 1) and (icache_lsize - 1) to the type + __UINTPTR_TYPE__; also cast 'base' to the same type before the + alignment operation. + 2013-01-15 Sofiane Naci * config/aarch64/sync-cache.c (__aarch64_sync_cache_range): Update diff --git a/libgcc/config/aarch64/sync-cache.c b/libgcc/config/aarch64/sync-cache.c index 2512cb8e87e..66b7afedc1f 100644 --- a/libgcc/config/aarch64/sync-cache.c +++ b/libgcc/config/aarch64/sync-cache.c @@ -40,7 +40,8 @@ __aarch64_sync_cache_range (const void *base, const void *end) as per the GNU definition of __clear_cache. */ /* Make the start address of the loop cache aligned. */ - address = (const char*) ((unsigned long) base & ~ (dcache_lsize - 1)); + address = (const char*) ((__UINTPTR_TYPE__) base + & ~ (__UINTPTR_TYPE__) (dcache_lsize - 1)); for (address; address < (const char *) end; address += dcache_lsize) asm volatile ("dc\tcvau, %0" @@ -51,7 +52,8 @@ __aarch64_sync_cache_range (const void *base, const void *end) asm volatile ("dsb\tish" : : : "memory"); /* Make the start address of the loop cache aligned. */ - address = (const char*) ((unsigned long) base & ~ (icache_lsize - 1)); + address = (const char*) ((__UINTPTR_TYPE__) base + & ~ (__UINTPTR_TYPE__) (icache_lsize - 1)); for (address; address < (const char *) end; address += icache_lsize) asm volatile ("ic\tivau, %0" -- 2.30.2