-
Notifications
You must be signed in to change notification settings - Fork 178
/
Copy pathsoc_linux.py
110 lines (82 loc) · 4.54 KB
/
soc_linux.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#
# This file is part of Linux-on-LiteX-VexRiscv
#
# Copyright (c) 2019-2024, Linux-on-LiteX-VexRiscv Developers
# SPDX-License-Identifier: BSD-2-Clause
import os
import json
import shutil
import subprocess
from migen import *
from litex.soc.interconnect.csr import *
from litex.soc.cores.cpu.vexriscv_smp import VexRiscvSMP
from litex.soc.cores.gpio import GPIOOut, GPIOIn
from litex.soc.cores.spi import SPIMaster
from litex.soc.cores.bitbang import I2CMaster
from litex.soc.cores.pwm import PWM
from litex.tools.litex_json2dts_linux import generate_dts
# SoCLinux -----------------------------------------------------------------------------------------
def SoCLinux(soc_cls, **kwargs):
class _SoCLinux(soc_cls):
def __init__(self, **kwargs):
# SoC ----------------------------------------------------------------------------------
soc_cls.__init__(self, cpu_type="vexriscv_smp", cpu_variant="linux", **kwargs)
# RGB Led ----------------------------------------------------------------------------------
def add_rgb_led(self):
rgb_led_pads = self.platform.request("rgb_led", 0)
for n in "rgb":
self.add_module(name=f"rgb_led_{n}0", module=PWM(getattr(rgb_led_pads, n)))
# Switches ---------------------------------------------------------------------------------
def add_switches(self):
self.switches = GPIOIn(Cat(self.platform.request_all("user_sw")), with_irq=True)
self.irq.add("switches")
# SPI --------------------------------------------------------------------------------------
def add_spi(self, data_width, clk_freq):
spi_pads = self.platform.request("spi")
self.spi = SPIMaster(spi_pads, data_width, self.clk_freq, clk_freq)
# I2C --------------------------------------------------------------------------------------
def add_i2c(self):
self.i2c0 = I2CMaster(self.platform.request("i2c", 0))
# Ethernet configuration -------------------------------------------------------------------
def configure_ethernet(self, remote_ip):
remote_ip = remote_ip.split(".")
try: # FIXME: Improve.
self.constants.pop("REMOTEIP1")
self.constants.pop("REMOTEIP2")
self.constants.pop("REMOTEIP3")
self.constants.pop("REMOTEIP4")
except:
pass
self.add_constant("REMOTEIP1", int(remote_ip[0]))
self.add_constant("REMOTEIP2", int(remote_ip[1]))
self.add_constant("REMOTEIP3", int(remote_ip[2]))
self.add_constant("REMOTEIP4", int(remote_ip[3]))
# DTS generation ---------------------------------------------------------------------------
def generate_dts(self, board_name):
json_src = os.path.join("build", board_name, "csr.json")
dts = os.path.join("build", board_name, "{}.dts".format(board_name))
with open(json_src) as json_file, open(dts, "w") as dts_file:
dts_content = generate_dts(json.load(json_file), polling=False)
dts_file.write(dts_content)
# DTS compilation --------------------------------------------------------------------------
def compile_dts(self, board_name, symbols=False):
dts = os.path.join("build", board_name, "{}.dts".format(board_name))
dtb = os.path.join("build", board_name, "{}.dtb".format(board_name))
subprocess.check_call(
"dtc {} -O dtb -o {} {}".format("-@" if symbols else "", dtb, dts), shell=True)
# DTB combination --------------------------------------------------------------------------
def combine_dtb(self, board_name, overlays=""):
dtb_in = os.path.join("build", board_name, "{}.dtb".format(board_name))
dtb_out = os.path.join("images", "rv32.dtb")
if overlays == "":
shutil.copyfile(dtb_in, dtb_out)
else:
subprocess.check_call(
"fdtoverlay -i {} -o {} {}".format(dtb_in, dtb_out, overlays), shell=True)
# Documentation generation -----------------------------------------------------------------
def generate_doc(self, board_name):
from litex.soc.doc import generate_docs
doc_dir = os.path.join("build", board_name, "doc")
generate_docs(self, doc_dir)
os.system("sphinx-build -M html {}/ {}/_build".format(doc_dir, doc_dir))
return _SoCLinux(**kwargs)