Commit c6fe403e authored by Sergei Trofimovich's avatar Sergei Trofimovich

Revert "UNREG: use __builtin___clear_cache where available"

This reverts commit 6dd1257f.

Change fails vaildation:
  rts/sm/Storage.c:1351:20: error:
     error: ‘gcc_clear_cache’ defined but not used [-Werror=unused-function]
     STATIC_INLINE void gcc_clear_cache(void * begin, void * end)
parent c8370a82
......@@ -1341,26 +1341,6 @@ StgWord calcTotalCompactW (void)
#include <libkern/OSCacheControl.h>
#endif
#if defined(__GNUC__)
/* __clear_cache is a libgcc function.
* It existed before __builtin___clear_cache was introduced.
* See Trac #8562.
*/
extern void __clear_cache(char * begin, char * end);
STATIC_INLINE void gcc_clear_cache(void * begin, void * end)
{
/* __builtin___clear_cache is supported since GNU C 4.3.6.
* We pick 4.4 to simplify condition a bit.
*/
#if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4)
__builtin___clear_cache(begin, end);
#else
__clear_cache(begin, end);
#endif
}
#endif /* __GNUC__ */
/* On ARM and other platforms, we need to flush the cache after
writing code into memory, so the processor reliably sees it. */
void flushExec (W_ len, AdjustorExecutable exec_addr)
......@@ -1376,7 +1356,7 @@ void flushExec (W_ len, AdjustorExecutable exec_addr)
/* For all other platforms, fall back to a libgcc builtin. */
unsigned char* begin = (unsigned char*)exec_addr;
unsigned char* end = begin + len;
gcc_clear_cache((void*)begin, (void*)end);
__clear_cache((void*)begin, (void*)end);
#else
#error Missing support to flush the instruction cache
#endif
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment