// template for functions that load an aligned value from memory
#define load_func(type) \
- type##_t load_##type(reg_t addr) __attribute__((always_inline)) { \
+ inline type##_t load_##type(reg_t addr) { \
if (addr & (sizeof(type##_t)-1)) \
throw trap_load_address_misaligned(addr); \
reg_t vpn = addr >> PGSHIFT; \
inline insn_fetch_t load_insn(reg_t addr)
{
- return access_icache(addr)->data;
+ icache_entry_t entry;
+ return refill_icache(addr, &entry)->data;
}
void flush_tlb();
reg_t translate(reg_t addr, access_type type);
// ITLB lookup
- const uint16_t* translate_insn_addr(reg_t addr) __attribute__((always_inline)) {
+ inline const uint16_t* translate_insn_addr(reg_t addr) {
reg_t vpn = addr >> PGSHIFT;
if (likely(tlb_insn_tag[vpn % TLB_ENTRIES] == vpn))
return (uint16_t*)(tlb_data[vpn % TLB_ENTRIES] + addr);