1 个不稳定版本
0.10.3 | 2024年5月31日 |
---|
#242 在 嵌入式开发
10MB
222K SLoC
德州仪器低功耗RF微控制器的PACs
此存储库包含德州仪器低功耗RF(LPRF)系列Cortex-M微控制器的外设访问包(PACs)。
所有这些包都是使用svd2rust和tixml2svd自动生成的。
包
LPRF芯片系列中的每个设备系列都有自己的PAC。设备系列是德州仪器将具有相同外设的类似设备分组的方式。在此命名方案中,x
是一个通配符。例如,CC2652和CC1312都属于cc13x2_cc26x2系列。
为了防止在包中大量重复,每个设备系列只有一个PAC,而不是每个设备。
以下列出了PACs
PAC | 支持设备 | TI SDK链接 | 目标 |
---|---|---|---|
cc13x0 |
CC1310, CC1350 | https://www.ti.com/tool/download/SIMPLELINK-CC13X0-SDK | thumbv7m-none-eabi |
cc13x1_cc26x1 |
CC1311P3, CC1311R3, CC2651P3, CC2651R3, CC2651R3SIPA | https://github.com/TexasInstruments/cc13xx_cc26xx_sdk | thumbv7em-none-eabi |
cc13x2_cc26x2 |
CC2642R, CC2652R, CC2652RB, CC1312R, CC1352R, CC1352P, CC2652P, CC2652PSIP, CC2652RSIP | https://github.com/TexasInstruments/cc13xx_cc26xx_sdk | thumbv7em-none-eabihf |
cc13x2x7_cc26x2x7 |
CC1312R7, CC1352P7, CC2652P7, CC2652R7 | https://github.com/TexasInstruments/cc13xx_cc26xx_sdk | thumbv7em-none-eabihf |
cc13x4_cc26x4 |
CC1314R, CC1354R, CC1354P, CC2674R, CC2674P | https://github.com/TexasInstruments/cc13xx_cc26xx_sdk | thumbv8m.main-none-eabihf |
cc2640r2 |
CC2640R2 | https://www.ti.com/tool/download/SIMPLELINK-CC2640R2-SDK | thumbv7m-none-eabi |
工作原理
此存储库尝试使用tixml2svd和svd2rust尽可能地自动化。本节试图描述此存储库是如何构建的。
要查看代码的组织方式,请尝试运行以下命令
$ tree -L 2
这应该会输出类似以下的内容
.
├── Cargo.lock
├── Cargo.toml
├── CONTRIBUTING.md
├── input
│ ├── devices
│ └── Modules
├── LICENSE.txt
├── pacs
│ ├── cc13x0
│ ├── cc13x1_cc26x1
│ ├── cc13x2_cc26x2
│ ├── cc13x2x7_cc26x2x7
│ ├── cc13x4_cc26x4
│ └── cc2640r2
├── README.md
├── svds
│ ├── cc13x0.svd
│ ├── cc13x1_cc26x1.svd
│ ├── cc13x2_cc26x2.svd
│ ├── cc13x2x7_cc26x2x7.svd
│ ├── cc13x4_cc26x4.svd
│ └── cc2640r2.svd
├── tests
│ ├── cc13x0
│ ├── cc13x2-cc26x2
│ ├── cc13x4-cc26x4
│ └── cc2640r2
├── tools
│ └── generate_pacs.py
└── xtask
├── Cargo.toml
└── src
27 directories, 15 files
使用tools/generate_pacs.py
自动化从输入XML文件创建PACs。
输入文件
input
目录包含来自TI的设备定义文件。它们可以从Code Composer Studio(CCS)安装中复制。
Modules
文件夹中的文件以TI XML格式定义设备的外围设备集。
这些文件用于使用tixml2svd生成svd
文件。
位于 input/devices
中的 XML 文件是人工维护的。它们基于设备系列。在 input/devices
中的单个 XML 文件将生成一个 PAC。
补丁
TI 的 XML 源代码不包含中断定义。因此,还有人工维护的 rust 文件,其中包含在 Rust 中定义中断向量表的所需代码。这些文件用于修补生成的 lib.rs
文件。理想情况下,SVD 文件也会被修补,但这稍微复杂一些,所以我们暂时使用更简单的解决方案。
添加或更新设备
要更新源文件,请将 Modules
文件夹从 <INSTALL_LOC>/ti/ccs<CCS_VER>/ccs/ccs_base/common/targetdb/
复制到本存储库中 input/Modules
文件夹。 <INSTALL_LOC>
是您安装 CCS 的位置。 <CCS_VER>
是您安装的 CCS 版本,不带任何 .
或其他分隔符,因此 12.2.0 变为 1220。
- 按照上述说明从 CCS 复制文件
- 如果添加新的设备系列,请在
input/devices/
中创建设备系列 XML 描述符。- 提示:这些可以从 CCS 复制
<INSTALL_LOC>/ti/ccs<CCS_VER>/ccs/ccs_base/common/targetdb/devices
。 - 从您想要的系列中选择一个设备并将其复制到树中,并重命名它
- 提示:这些可以从 CCS 复制
- 如果添加新的设备系列,请创建
device_family_ints.rs
,其中将device_family
替换为设备系列名称。- 提示:可以使用 TI 创建的 C 文件。它可以在
<TI_SDK>/source/ti/devices/<device_family>/inc/hw_ints.h
中找到。
- 提示:可以使用 TI 创建的 C 文件。它可以在
- 运行
cargo xtask generate
- 根据上一步中创建的向量表更新
device.x