47 lines
1.0 KiB
C

#ifndef __SYSTEM_H
#define __SYSTEM_H
#include "microwatt_soc.h"
#include "io.h"
#define CSR_ACCESSORS_DEFINED
#define CSR_BASE DRAM_CTRL_BASE
#define CONFIG_CPU_NOP "nop"
#ifdef __SIM__
#define MEMTEST_BUS_SIZE 512//16
#define MEMTEST_DATA_SIZE 1024//16
#define MEMTEST_ADDR_SIZE 128//16
#define CONFIG_SIM_DISABLE_DELAYS
#endif
extern void flush_cpu_dcache(void);
extern void flush_cpu_icache(void);
static inline void flush_l2_cache(void) { }
/* Fake timer stuff. LiteX should abstract this */
static inline void timer0_en_write(int e) { }
static inline void timer0_reload_write(int r) { }
static inline void timer0_load_write(int l) { }
static inline void timer0_update_value_write(int v) { }
static inline uint64_t timer0_value_read(void)
{
uint64_t val;
__asm__ volatile ("mfdec %0" : "=r" (val));
return val;
}
static inline void csr_write_simple(unsigned long v, unsigned long a)
{
return writel(v, a);
}
static inline unsigned long csr_read_simple(unsigned long a)
{
return readl(a);
}
#endif /* __SYSTEM_H */