cpu/gowin_emcu: Increase similarities with cortex_m3 (since gowin_emcu is a Cortex M3).

This commit is contained in:
Florent Kermarrec 2024-01-04 08:57:25 +01:00
parent 85ef3bd8a7
commit 6d3c955d59
3 changed files with 19 additions and 21 deletions

View file

@ -5,8 +5,6 @@
# Copyright (c) 2022 Florent Kermarrec <florent@enjoy-digital.fr>
# SPDX-License-Identifier: BSD-2-Clause
import os
from migen import *
from litex.gen import *

View file

@ -9,8 +9,8 @@ from migen import *
from litex.gen import *
from litex.soc.interconnect import wishbone, ahb
from litex.soc.cores.cpu import CPU
from litex.soc.interconnect import wishbone, ahb
# Gowin EMCU ---------------------------------------------------------------------------------------
@ -22,38 +22,41 @@ class GowinEMCU(CPU):
human_name = "Gowin EMCU"
data_width = 32
endianness = "little"
reset_address = 0x0000_0000
gcc_triple = "arm-none-eabi"
linker_output_format = "elf32-littlearm"
nop = "nop"
io_regions = {
# Origin, Length.
0x4000_0000: 0x2000_0000,
0xa000_0000: 0x6000_0000
0x4000_0000 : 0x2000_0000,
0xa000_0000 : 0x6000_0000,
}
# Memory Mapping.
@property
def mem_map(self):
return {
"rom" : 0x0000_0000,
"sram" : 0x2000_0000,
"peripherals" : 0x4000_0000,
"csr" : 0xa000_0000,
"rom" : 0x0000_0000,
"sram" : 0x2000_0000,
"main_ram" : 0x1000_0000,
"csr" : 0xa000_0000,
}
# GCC Flags.
@property
def gcc_flags(self):
flags = f" -mcpu=cortex-m3 -mthumb"
flags = f" -march=armv7-m -mthumb"
flags += f" -D__CortexM3__"
flags += f" -DUART_POLLING"
return flags
def __init__(self, platform, variant, *args, **kwargs):
super().__init__(*args, **kwargs)
def __init__(self, platform, variant="standard"):
self.platform = platform
self.reset = Signal()
self.interrupt = Signal(5)
self.reset_address = self.mem_map["rom"] + 0
self.periph_buses = []
self.pbus = wishbone.Interface(data_width=32, adr_width=30, addressing="word")
self.periph_buses = [self.pbus]
self.memory_buses = []
# CPU Instance.
# -------------
@ -63,8 +66,8 @@ class GowinEMCU(CPU):
self.cpu_params.update(
# Clk/Rst.
i_FCLK = ClockSignal("sys"),
i_PORESETN = ~ResetSignal("sys") & ~self.reset,
i_SYSRESETN = ~ResetSignal("sys") & ~self.reset,
i_PORESETN = ~ (ResetSignal("sys") | self.reset),
i_SYSRESETN = ~ (ResetSignal("sys") | self.reset),
i_MTXREMAP = Signal(4, reset=0b1111),
o_MTXHRESETN = bus_reset_n,
@ -182,15 +185,12 @@ class GowinEMCU(CPU):
# Peripheral Bus (AHB -> Wishbone).
# ---------------------------------
self.pbus = wishbone.Interface(data_width=32, adr_width=30, addressing="word")
ahb_targexp0 = ahb.Interface()
for s, _ in ahb_targexp0.master_signals:
self.cpu_params[f"o_TARGEXP0H{s.upper()}"] = getattr(ahb_targexp0, s)
for s, _ in ahb_targexp0.slave_signals:
self.cpu_params[f"i_TARGEXP0H{s.upper()}"] = getattr(ahb_targexp0, s)
self.submodules += ahb.AHB2Wishbone(ahb_targexp0, self.pbus)
self.periph_buses.append(self.pbus)
def connect_uart(self, pads, n=0):
assert n in (0, 1), "this CPU has 2 built-in UARTs, 0 and 1"

View file

@ -5,8 +5,8 @@
extern "C" {
#endif
__attribute__((unused)) static void flush_cpu_icache(void){};
__attribute__((unused)) static void flush_cpu_dcache(void){};
__attribute__((unused)) static void flush_cpu_icache(void){}; /* No instruction cache */
__attribute__((unused)) static void flush_cpu_dcache(void){}; /* No instruction cache */
void flush_l2_cache(void);
void busy_wait(unsigned int ms);