在嵌入式画板的时候, 我们需要先明确功能需求, 然后选择芯片, 然后再确定管脚, 特别是在嵌入式资源比较紧缺的时候, 合理分配管脚显得尤为重要.
但是当功能变得非常多的时候, 合理两个字也变得有一定的难度. 我这里谈谈我的一次分配的过程, 供大家参考.
第一步. 确定好功能和芯片
如我们要用 gd32f103 的 usart, i2c, spi 各一组, 由于芯片有很多管脚的封装, 这里功能简单, 我们选择 LQFP48 封装, 这些先在需求中确定下来.
第二步, 下载官方数据手册, 将封装整理出来.
如我们选择 LQFP48, 整理出来.
12 | PA1 | USART1_RTS, ADC012_IN1, TIMER1_CH1 |
13 | PA2 | USART1_TX, ADC012_IN2, TIMER1_CH2 |
14 | PA4 | SPI0_NSS, USART1_CK, ADC01_IN4 |
… |
为了辅助我们得到对应的功能, 我们需要更直观的通过功能选择对应的管脚.
import pyexcel as pe
import json
# 存有管脚记录的 xlsx 文件.
fn = '/media/lhpc04/da8a185a-95f0-4cbd-ba0a-5fe144872bd7/worksapce/edits/lanhui/硬件/杆塔倾斜/stm32f103 管脚记录.xlsx'
# 定义管脚数量
dddd = 3
wrk = {}
data = pe.get_sheet(file_name=fn)
for eline_i, eline in enumerate(data):
dws = eline[10].replace('\n','').replace('/', ',').split(',')
lnxx = False
ln_ind = eline[dddd]
if not isinstance(ln_ind, int):
continue
ln_eee = ''
for dw in dws:
dw = dw.strip()
if dw == '':continue
lnxx = True
wd = dw.split('_')
wd_ch = wd[0]
wd_wr = '_'.join(wd[1:])
if wd_ch not in wrk:
wrk[wd_ch] = {}
if wd_wr not in wrk[wd_ch]:
wrk[wd_ch][wd_wr] = []
wrk[wd_ch][wd_wr].append(ln_ind)
ln_eee += dw +' '
print(json.dumps(wrk,indent=4))
这个代码大概就是将各个模块分出来, 如下面这个是
"USART1": {
"CK": [
119
],
"TX": [
120,
164
],
"RX": [
121,
165
],
"CTS": [
122
],
"RTS": [
123
]
},
打印我们需要的管脚
model_names=['USART1']
for dx in model_names:
if dx not in wrk: # 没有 该功能
print('# {}'.format(dx))
continue
dxxx = wrk[dx]
print(dx)
for d in dxxx:
if len(dxxx[d]) == 1: # 如果只有一个复用, 就选在改引脚
print('{:15s} {}'.format(d, dxxx[d][0]))
else: # 否则输出列表
print('{:15s} {}'.format(d, dxxx[d]))
print()
输出
USART1
CK 119
TX [120, 164]
RX [121, 165]
CTS 122
RTS 123
- 我将上面的输出, 放在 vscode 这类有选择提示功能的文本编辑器中.
右边的滚动条的提示, 我们可以分析是否重复. 根据情况, 选择列表的元素作为我们的功能选择.
- 最后根据改数据制作电路图.
ps: 项目是使用的 stm32f429, 所以部分样例数据是 stm32f429 176 管脚的. 所以 gd32f103的数据没有准备全, 大概介绍了我的一点经验.