2021-05-25 04:17:24 +02:00
|
|
|
import sys
|
2021-04-20 03:37:49 +02:00
|
|
|
import yaml
|
|
|
|
import re
|
|
|
|
import os
|
2021-05-19 10:37:52 +02:00
|
|
|
import re
|
2021-04-20 03:37:49 +02:00
|
|
|
|
2021-06-12 18:28:21 +02:00
|
|
|
try:
|
|
|
|
from yaml import CSafeLoader as SafeLoader
|
|
|
|
except ImportError:
|
|
|
|
from yaml import SafeLoader
|
|
|
|
|
|
|
|
|
2021-04-20 03:37:49 +02:00
|
|
|
abspath = os.path.abspath(__file__)
|
|
|
|
dname = os.path.dirname(abspath)
|
|
|
|
os.chdir(dname)
|
|
|
|
|
2021-05-25 04:17:24 +02:00
|
|
|
data_path = '../stm32-data/data'
|
2021-04-20 03:37:49 +02:00
|
|
|
|
2021-05-25 04:17:24 +02:00
|
|
|
try:
|
|
|
|
_, chip_name, output_file = sys.argv
|
|
|
|
except:
|
2021-06-16 15:12:07 +02:00
|
|
|
raise Exception("Usage: gen.py STM32F429ZI_CM0 path/to/generated.rs")
|
|
|
|
|
|
|
|
c = chip_name.split('_', 1)
|
|
|
|
|
|
|
|
chip_name = c[0].upper()
|
|
|
|
core_name = None
|
|
|
|
|
|
|
|
if len(c) > 1:
|
|
|
|
core_name = c[1].lower()
|
2021-05-10 01:20:04 +02:00
|
|
|
|
2021-05-25 04:17:24 +02:00
|
|
|
# ======= load chip
|
|
|
|
with open(f'{data_path}/chips/{chip_name}.yaml', 'r') as f:
|
2021-06-12 18:28:21 +02:00
|
|
|
chip = yaml.load(f, Loader=SafeLoader)
|
2021-05-10 01:20:04 +02:00
|
|
|
|
2021-05-25 04:17:24 +02:00
|
|
|
# ======= Generate!
|
|
|
|
with open(output_file, 'w') as f:
|
|
|
|
singletons = [] # USART1, PA5, EXTI8
|
|
|
|
exti_interrupts = [] # EXTI IRQs, EXTI0, EXTI4_15 etc.
|
|
|
|
pins = set() # set of all present pins. PA4, PA5...
|
|
|
|
|
|
|
|
# ========= peripherals
|
|
|
|
|
|
|
|
singletons.extend((f'EXTI{x}' for x in range(16)))
|
|
|
|
num_dmas = 0
|
|
|
|
|
2021-06-16 15:12:07 +02:00
|
|
|
core = chip['cores'][0]
|
|
|
|
if core_name != None:
|
|
|
|
for c in chip['cores']:
|
|
|
|
if core_name == c['name']:
|
|
|
|
core = c
|
|
|
|
|
|
|
|
for (name, peri) in core['peripherals'].items():
|
2021-05-25 04:17:24 +02:00
|
|
|
if 'block' not in peri:
|
|
|
|
continue
|
|
|
|
|
|
|
|
block = peri['block']
|
|
|
|
block_mod, block_name_unparsed = block.rsplit('/')
|
|
|
|
block_mod, block_version = block_mod.rsplit('_')
|
|
|
|
block_name = ''
|
|
|
|
for b in block_name_unparsed.split('_'):
|
|
|
|
block_name += b.capitalize()
|
|
|
|
|
|
|
|
custom_singletons = False
|
|
|
|
|
|
|
|
if block_mod == 'gpio':
|
|
|
|
custom_singletons = True
|
|
|
|
port = name[4:]
|
|
|
|
port_num = ord(port) - ord('A')
|
|
|
|
|
|
|
|
for pin_num in range(16):
|
|
|
|
pin = f'P{port}{pin_num}'
|
|
|
|
pins.add(pin)
|
|
|
|
singletons.append(pin)
|
|
|
|
|
2021-06-25 14:00:11 -04:00
|
|
|
# if block_mod == 'dma':
|
|
|
|
# custom_singletons = True
|
|
|
|
# for ch_num in range(8):
|
|
|
|
# channel = f'{name}_CH{ch_num}'
|
|
|
|
# singletons.append(channel)
|
2021-05-25 04:17:24 +02:00
|
|
|
|
|
|
|
if not custom_singletons:
|
|
|
|
singletons.append(name)
|
|
|
|
|
2021-06-25 14:00:11 -04:00
|
|
|
for (channel_id, defn) in core['dma_channels'].items():
|
|
|
|
singletons.append( channel_id )
|
|
|
|
|
2021-05-25 04:17:24 +02:00
|
|
|
f.write(f"embassy_extras::peripherals!({','.join(singletons)});")
|