mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 18:28:20 +08:00
mdbx: fix for MIPS cacheflush().
This commit is contained in:
parent
5ce40269b3
commit
c52a57dac5
12
src/osal.h
12
src/osal.h
@ -366,19 +366,23 @@ static __inline void mdbx_memory_barrier(void) {
|
|||||||
#define mdbx_coherent_barrier() mdbx_memory_barrier()
|
#define mdbx_coherent_barrier() mdbx_memory_barrier()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__mips) && defined(__linux)
|
#if defined(__mips) || defined(__mips__) || defined(__mips64) || \
|
||||||
|
defined(__mips64) || defined(_M_MRX000) || defined(_MIPS_)
|
||||||
/* Only MIPS has explicit cache control */
|
/* Only MIPS has explicit cache control */
|
||||||
#include <asm/cachectl.h>
|
#include <sys/cachectl.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static __inline void mdbx_invalidate_cache(void *addr, size_t nbytes) {
|
static __inline void mdbx_invalidate_cache(void *addr, size_t nbytes) {
|
||||||
mdbx_coherent_barrier();
|
mdbx_coherent_barrier();
|
||||||
#if defined(__mips) && defined(__linux)
|
#if defined(__mips) || defined(__mips__) || defined(__mips64) || \
|
||||||
|
defined(__mips64) || defined(_M_MRX000) || defined(_MIPS_)
|
||||||
|
#if defined(DCACHE)
|
||||||
/* MIPS has cache coherency issues.
|
/* MIPS has cache coherency issues.
|
||||||
* Note: for any nbytes >= on-chip cache size, entire is flushed. */
|
* Note: for any nbytes >= on-chip cache size, entire is flushed. */
|
||||||
cacheflush(addr, nbytes, DCACHE);
|
cacheflush(addr, nbytes, DCACHE);
|
||||||
#elif defined(_M_MRX000) || defined(_MIPS_)
|
#else
|
||||||
#error "Sorry, cacheflush() for MIPS not implemented"
|
#error "Sorry, cacheflush() for MIPS not implemented"
|
||||||
|
#endif /* __mips__ */
|
||||||
#else
|
#else
|
||||||
/* LY: assume no relevant mmap/dcache issues. */
|
/* LY: assume no relevant mmap/dcache issues. */
|
||||||
(void)addr;
|
(void)addr;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user