0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux SID開發(fā)指南

嵌入式Linux那些事 ? 來源:嵌入式Linux那些事 ? 作者:嵌入式Linux那些事 ? 2023-03-06 10:19 ? 次閱讀

Linux SID 開發(fā)指南

1 前言

1.1 編寫目的

介紹Linux 內(nèi)核中基于Sunxi 硬件平臺的SID 模塊驅(qū)動的詳細(xì)設(shè)計,為軟件編碼和維護(hù)提供基 礎(chǔ)。

1.2 適用范圍

內(nèi)核版本Linux-5.4, Linux-4.9 的平臺。

1.3 相關(guān)人員

SID 驅(qū)動、Efuse 驅(qū)動、Sysinfo 驅(qū)動的維護(hù)、應(yīng)用開發(fā)人員等。

1.4 術(shù)語、定義、縮略語

image-20221219105007286

2 模塊描述

2.1 模塊功能

SID 提供的功能可以分為四大部分:ChipID、SoC Version、Efuse 功能、一些狀態(tài)位。

2.1.1 Chip ID 功能

對于全志的SoC 來說,ChipID 用于該SoC 的唯一標(biāo)識,如A83 的ChipID 標(biāo)識其在所有A83 中的唯一(目前僅保證同一型號SoC 中的ChipID 唯一)。ChipID 由4 個word(16 個byte)組成,共128bit,通常放在Efuse(見2.1.3 節(jié))的起始4 個word。具體ChipID 的bit 含義,請參考生產(chǎn)制造部為每顆SoC 定義的《ChipID 燒碼規(guī)則》。

2.1.2 SoC Version 功能

嚴(yán)格講SoC Version 包含兩部分信息: 1.Bonding ID,表示不同封裝。

Version,表示改版編號。

說明:這兩個信息所在的寄存器不一定都在SID 模塊內(nèi)部,且各平臺位置不一,但軟件上為了統(tǒng)一管理,都?xì)w屬為SID 模塊。

BSP 會返回這兩個信息的組合值,由應(yīng)用去判斷和做出相應(yīng)的處理。

2.1.3 Efuse 功能

對軟件來說,Efuse 中提供了一個可編程的永久存儲空間,特點是每一位只能寫一次(從0到1)。 Efuse 接口方式,Efuse 容量大于512bit 采用SRAM 方式。帶有SRAM 的硬件結(jié)構(gòu)示意圖如下:

image-20221219105300040

2.1.4 一些狀態(tài)位

Secure Enable標(biāo)明當(dāng)前系統(tǒng)的Security 屬性是否打開,即是否運行了SecureBoot 和SecureOS。 芯片SecureEnable 狀態(tài)位保存在SID 模塊的0xa0 寄存器。

2.2 模塊位置

SID 是一個比較獨立的模塊,在Linux 內(nèi)核中沒有依賴其他子系統(tǒng),在Sunxi 平臺默認(rèn)是ko 方式,存放在drivers/soc/sunxi 目錄中。 SID 為其他模塊提供API 的調(diào)用方式。關(guān)系如下圖:

image-20221219105416344

1)TV、Thermal、GMAC 的校準(zhǔn)參數(shù)保存在SID 中; 2)Nand、SMP、VE 需要讀取SoC Version; 3)CE 和HDMI 會用到SID 中的一些Key; 4)Sysinfo 比較特殊,為了方便用戶空間獲取、調(diào)試SID 信息,專門設(shè)計的一個字符型設(shè) 備驅(qū)動。

2.3 模塊device tree 配置說明(適用Linux-5.4)

SID 模塊在Device tree 中通常會用到兩個模塊的配置信息:sunxi-sid 以sun50iw10p1為例,需要在sun50iw10p1.dtsi 中添加節(jié)點:

sid@3006000 {

compatible = "allwinner,sun50iw10p1-sid", "allwinner,sunxi-sid";

reg = <0x0 0x03006000 0 0x1000>;

#address-cells = <1>;

#size-cells = <1>;

/* some guys has nothing to do with nvmem */

secure_status {

reg = <0x0 0>;

offset = <0xa0>;

size = <0x4>;

};

chipid {

reg = <0x0 0>;

offset = <0x200>;

size = <0x10>;

};

rotpk {

reg = <0x0 0>;

offset = <0x270>;

size = <0x20>;

};

};

在sid 下增加子節(jié)點secure_status, chipid, rotpk。就可以用key_info 來訪問。

console:/ # echo chipid > /sys/class/sunxi_info/key_info ; cat /sys/class/sunxi_info/

key_info

console:/ # 00000400

2.4 模塊源碼結(jié)構(gòu)

SID 驅(qū)動的源代碼目錄下:

linux-4.9,linux-5.4

./drivers/soc/sunxi/

└── sunxi-sid.c // 實現(xiàn)了SID對外的所有API接口

對外提供的接口頭文件:./include/linux/sunxi-sid.h

2.5 內(nèi)核配置

此配置項一般默認(rèn)開,不需要重新配置 在longan 環(huán)境中在根目錄執(zhí)行./build.sh menconfig進(jìn)入配置主界面,配置路徑如下:

System Type

└─>ARM system type

└─>Allwinner Ltd. SUNXI family

配置界面圖示:

image-20221219105647967

SID 驅(qū)動本身沒有注冊為單獨的模塊,需要通過注冊sysinfo 字符驅(qū)動(實現(xiàn)代碼見drivers/char/sunxi-sysinfo/)來提供sysfs 節(jié)點。 在longan 環(huán)境中在根目錄執(zhí)行./build.sh menconfig進(jìn)入配置主界面,配置路徑如下

Device Drivers

└─>Character devices

└─>sunxi system info driver

配置界面圖示:

image-20221219105712117

3 模塊設(shè)計

3.1 結(jié)構(gòu)框圖

SID 驅(qū)動內(nèi)部的功能劃分如下圖所示:

image-20221219105727865

總體上,SID 驅(qū)動內(nèi)部可以分為兩大部分: 1.SID Register RW,封裝了對寄存器按位讀取的接口,以及獲取指定compatible 的模塊基地址等。 2.SID Api,以API 的方式提供一些功能接口:獲取Key、獲取SoC Version、獲取SecureEnable、獲取ChipID 等。

3.2 關(guān)鍵數(shù)據(jù)定義

3.2.1 常量及宏定義

3.2.1.1 key 的名稱定義

在獲取Key 的時候,調(diào)用者需要知道Key 的名稱,以此作為索引的依據(jù)。Key 名稱詳見sunxisid.h:

1 #define EFUSE_CHIPID_NAME "chipid"

2 #define EFUSE_BROM_CONF_NAME "brom_conf"

3 #define EFUSE_BROM_TRY_NAME "brom_try"

4 #define EFUSE_THM_SENSOR_NAME "thermal_sensor"

5 #define EFUSE_FT_ZONE_NAME "ft_zone"

6 #define EFUSE_TV_OUT_NAME "tvout"

7 #define EFUSE_OEM_NAME "oem"

9 #define EFUSE_WR_PROTECT_NAME "write_protect"

10 #define EFUSE_RD_PROTECT_NAME "read_protect"

11 #define EFUSE_IN_NAME "in"

12 #define EFUSE_ID_NAME "id"

13 #define EFUSE_ROTPK_NAME "rotpk"

14 #define EFUSE_SSK_NAME "ssk"

15 #define EFUSE_RSSK_NAME "rssk"

16 #define EFUSE_HDCP_HASH_NAME "hdcp_hash"

17 #define EFUSE_HDCP_PKF_NAME "hdcp_pkf"

18 #define EFUSE_HDCP_DUK_NAME "hdcp_duk"

19 #define EFUSE_EK_HASH_NAME "ek_hash"

20 #define EFUSE_SN_NAME "sn"

21 #define EFUSE_NV1_NAME "nv1"

22 #define EFUSE_NV2_NAME "nv2"

23 #define EFUSE_BACKUP_KEY_NAME "backup_key"

24 #define EFUSE_RSAKEY_HASH_NAME "rsakey_hash"

25 #define EFUSE_RENEW_NAME "renewability"

26 #define EFUSE_OPT_ID_NAME "operator_id"

27 #define EFUSE_LIFE_CYCLE_NAME "life_cycle"

28 #define EFUSE_JTAG_SECU_NAME "jtag_security"

29 #define EFUSE_JTAG_ATTR_NAME "jtag_attr"

30 #define EFUSE_CHIP_CONF_NAME "chip_config"

31 #define EFUSE_RESERVED_NAME "reserved"

32 #define EFUSE_RESERVED2_NAME "reserved2"

33 /* For KeyLadder */

34 #define EFUSE_KL_SCK0_NAME "keyladder_sck0"

35 #define EFUSE_KL_KEY0_NAME "keyladder_master_key0"

36 #define EFUSE_KL_SCK1_NAME "keyladder_sck1"

37 #define EFUSE_KL_KEY1_NAME "keyladder_master_key1"

sunxi-sid.h 不是所有key 都能訪問,一般可以訪問的已經(jīng)在dts 定義。

3.2.2 關(guān)鍵數(shù)據(jù)結(jié)構(gòu)

3.2.2.1 soc_ver_map

用于管理多個SoC 的Version 信息,方便用查表的方式實現(xiàn)SoC Version API。其中有兩個分量:id,即BondingID;rev[],用于保存BondingID 和Version 的各種組合值。定義在sunxi-sid.c 中:

#define SUNXI_VER_MAX_NUM 8

struct soc_ver_map {

u32 id;

u32 rev[SUNXI_VER_MAX_NUM];

};

對于一個SoC 定義一個soc_ver_map 結(jié)構(gòu)數(shù)組,使用id 和不同Version 在rev[] 中查找對應(yīng)的組合值。

3.2.2.2 soc_ver_reg

SoC Version、BondingID、SecureEnable 的存儲位置因SoC 而異,所以定義了一個結(jié)構(gòu)來記錄這類信息的位置,包括屬于那個模塊(基地址)、偏移、掩碼、位移等。定義見sunxisid.c:

#define SUNXI_SOC_ID_INDEX 1

#define SUNXI_SECURITY_ENABLE_INDEX 2

struct soc_ver_reg {

s8 compatile[48];

u32 offset;

u32 mask;

u32 shift;

};

每個SoC 會定義一個soc_ver_reg 數(shù)組,目前各元素的定義如下: 0 - SoC Version 信息在寄存器中的位置。 1 - BondingID 信息在寄存器中的位置。 2 - SecureEnable 信息在寄存器中的位置。

3.2.3 全局變量

定義幾個static 全局變量,用于保存解析后的ChipID、SoC_Ver 等信息:

static unsigned int sunxi_soc_chipid[4]; static unsigned int sunxi_serial[4]; static int sunxi_soc_secure; static unsigned int sunxi_soc_bin; static unsigned int sunxi_soc_ver;

3.3 模塊流程設(shè)計

3.3.1 SoC 信息讀取流程

本節(jié)中,這里把SoC Ver、ChipID、SecureEnable 信息統(tǒng)稱為“SoC 信息”,因為他們的讀取過程非常相似。都是遵循以下流程:

image-20221219110111514

3.3.2 Efuse Key 讀取流程

在讀取Efuse 中Key 的時候,需要判斷是否存在、以及訪問權(quán)限,過程有點復(fù)雜,用以下流程圖進(jìn)行簡單說明。

image-20221219110133623

4 接口設(shè)計

4.1 接口函數(shù)

4.1.1 s32 sunxi_get_platform(s8 *buf, s32 size)

? 作用:獲取SoC 平臺的名稱,實際上是一個BSP 研發(fā)代號,如sun8iw11。 ? 參數(shù): ? buf: 用于保存平臺名稱的緩沖區(qū) ? size:buf 的大小 ? 返回: ? 返回buf 中平臺名稱的實際拷貝長度(如果size 小于名稱長度,返回size)。

4.1.2 int sunxi_get_soc_chipid(u8 *chipid)

? 作用:獲取SoC 的ChipID(從Efuse 中讀到的原始內(nèi)容,包括數(shù)據(jù)內(nèi)容和順序)。 ? 參數(shù): ? chipid:用于保存ChipID 的緩沖區(qū) ? 返回: ? 會返回0,無實際意義

4.1.3 int sunxi_get_serial(u8 *serial)

? 作用:獲取SoC 的序列號(由ChipID 加工而來,格式定義見《chipid 接口的實現(xiàn)方案》。 ? 參數(shù): ? serial:用于保存序列號的緩沖區(qū) ? 返回: ? 會返回0,無實際意義

4.1.4 sunxi_get_soc_chipid_str(char *serial)

? 作用:獲取SoC 的ChipID 的第一個字節(jié),要求轉(zhuǎn)換為字符串格式。 ? 參數(shù): ? serial:用于打印ChipID 第一個字節(jié)的緩沖區(qū) ? 返回: ? 只會返回8(4 個字節(jié)的十六進(jìn)制打印長度),無實際意義

4.1.5 int sunxi_get_soc_ft_zone_str(char *serial)

? 作用:獲取FZ ZONE 的最后一個字節(jié),要求轉(zhuǎn)換為字符串格式。 ? 參數(shù): ? serial:用于打印ChipID 第一個字節(jié)的緩沖區(qū) ? 返回: ? 只會返回8(4 個字節(jié)的十六進(jìn)制打印長度),無實際意義

4.1.6 int sunxi_get_soc_rotpk_status_str(char *status)

? 作用:獲取rotpk 的狀態(tài),是否燒碼 ? 參數(shù): ? status:用于記錄是否燒碼的緩沖區(qū);0,未燒;1,已燒 ? 返回: ? %d 的長度,無實際意義

4.1.7 int sunxi_soc_is_secure(void)

? 作用:獲取整個系統(tǒng)的Secure 狀態(tài),即安全系統(tǒng)是否啟用。 ? 參數(shù): ? 無 ? 返回: ? 0,未啟用安全系統(tǒng);1,啟用

4.1.8 unsigned int sunxi_get_soc_bin(void)

? 作用:用于芯片分bin,部分SoC 平臺才支持。 ? 參數(shù): ? 無 ? 返回: ? 0: fail ? 1: normal ? 2: faster ? 3: fastest

4.1.9 unsigned int sunxi_get_soc_ver(void)

? 作用:獲取SoC 的版本信息。 ? 參數(shù): ? 無 ? 返回: ? 返回一個十六進(jìn)制的編號,需要調(diào)用者去判斷版本號然后做出相應(yīng)的處理。詳情參看dts, sid 節(jié)點。

4.1.10 s32 sunxi_efuse_readn(void key_name, void buf, u32

n) ? 作用:讀取Efuse 中的一個key 信息。 ? 參數(shù): ? key_name - Key 的名稱,定義詳見sunxi-sid.h ? buf - 用于保存Key 值的緩沖區(qū) ? size - buf 的大小 ? 返回: ? 0: success ? other: fail 版

4.2 內(nèi)部函數(shù)

4.2.1 static s32 sid_get_base(struct device_node **pnode,

void __iomem **base, s8 *compatible, u32 sec) ? 作用:從DTS 中獲取指定模塊的寄存器基地址。 ? 參數(shù): ? pnode - 用于保存獲取到的模塊node 信息 ? base - 用于保存獲取到的寄存器基地址 ? compatible - 模塊名稱,用于匹配DTS 中的模塊 ? 返回: ? 0: success ? other: fail

4.2.2 static void sid_put_base(struct device_node *pnode,

void __iomem *base, u32 sec) ? 作用:釋放一個模塊的基地址。 ? 參數(shù): ? pnode - 保存模塊node 信息 ? base - 該模塊的寄存器基地址 ? 返回: ? 無

4.2.3 static u32 sid_rd_bits(s8 *name, u32 offset, u32 shift,

u32 mask, u32 sec) ? 作用:從一個模塊的寄存器中,讀取指定位置的bit 信息。 ? 參數(shù): ? name - 模塊名稱,用于匹配DTS 中的模塊 ? offset - 寄存器相當(dāng)于基地址的偏移 ? shift - 該bit 在寄存器中的位移 ? mask - 該bit 的掩碼值 ? 返回:

? 0,fail ? other,獲取到的實際bit 信息 版

5 可測試性

/sys/class/sunxi_info/sys_info 此節(jié)點文件可以打印出一些SoC 信息,包括版本信息、ChipID 等:

# cat /sys/class/sunxi_info/sys_info sunxi_platform : sun50iw10p1 sunxi_secure : secure sunxi_chipid : 00000000000000000000000000000000 sunxi_chiptype : 00000400 sunxi_batchno : 0x1

/sys/class/sunxi_info/key_info 此節(jié)點用于獲取指定名稱的Key 信息。方法是先寫入一個Key 名稱,然后就可以讀取到Key 的內(nèi)容。執(zhí)行效果如下:

# echo chipid > /sys/class/sunxi_info/key_info ; cat /sys/class/sunxi_info/key_info 0xf1c1b200: 0x00000400 0xf1c1b204: 0x00000000 0xf1c1b208: 0x00000000 0xf1c1b20c: 0x00000000

6 其他說明

當(dāng)啟用安全系統(tǒng)后,Non-Secure 空間將無法訪問大部分的Efuse 信息,這個時候需要通過SMC 指令來讀取這些Key 信息。此時不能再使用普通的寄存器讀接口readl(),而是調(diào)用的SMC 接口:

目前,sunxi_smc_readl() 的實現(xiàn)在源代碼sunxi-smc.c,該文件保存在drivers/char/sunxisysinfo。

int sunxi_smc_readl(phys_addr_t addr)

目前,sunxi_smc_readl() 的實現(xiàn)在源代碼sunxi-smc.c,該文件保存在drivers/char/sunxisysinfo。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 內(nèi)核
    +關(guān)注

    關(guān)注

    3

    文章

    1410

    瀏覽量

    41143
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11469

    瀏覽量

    212891
  • SID
    SID
    +關(guān)注

    關(guān)注

    0

    文章

    16

    瀏覽量

    3150
收藏 0人收藏

    評論

    相關(guān)推薦
    熱點推薦

    EAC0945 linux開發(fā)指南

    EAC0945 linux開發(fā)指南
    發(fā)表于 09-28 12:40

    EAC0945 linux開發(fā)指南

    `EAC0945 linux開發(fā)指南`
    發(fā)表于 10-31 12:18

    Rockchip Linux SDK uboot logo開發(fā)指南

    arm嵌入式vs-rk3399 板卡uboot logo 開發(fā)指南概述:本文檔主要介紹 rockchip linux sdk uboot logo 顯示的相關(guān)功能、配置以及開發(fā)過程中的注意事項。適用于 rockhip
    發(fā)表于 10-09 08:12

    CPLD FPGA高級應(yīng)用開發(fā)指南

    CPLD FPGA高級應(yīng)用開發(fā)指南
    發(fā)表于 04-15 10:56 ?58次下載
    CPLD FPGA高級應(yīng)用<b class='flag-5'>開發(fā)指南</b>

    Tiny6410 Linux開發(fā)指南詳解

    Tiny6410 Linux 開發(fā)指南
    發(fā)表于 07-08 17:12 ?210次下載
    Tiny6410 <b class='flag-5'>Linux</b><b class='flag-5'>開發(fā)指南</b>詳解

    A64開發(fā)板LCD開發(fā)指南

    A64開發(fā)板LCD開發(fā)指南,驅(qū)動開發(fā)指南
    發(fā)表于 06-21 17:02 ?0次下載

    彩光燈開發(fā)指南

    彩光燈開發(fā)指南
    發(fā)表于 12-29 20:15 ?0次下載

    Linux的平臺下Mini210S裸機(jī)程序開發(fā)指南

    Linux的平臺下Mini210S裸機(jī)程序開發(fā)指南
    發(fā)表于 10-29 10:52 ?59次下載
    <b class='flag-5'>Linux</b>的平臺下Mini210S裸機(jī)程序<b class='flag-5'>開發(fā)指南</b>

    Rockchip Linux SDK的開發(fā)指南的詳細(xì)資料說明

    本文檔的主要內(nèi)容詳細(xì)介紹的是Rockchip Linux SDK的開發(fā)指南的詳細(xì)資料說明。
    發(fā)表于 01-10 17:17 ?74次下載
    Rockchip <b class='flag-5'>Linux</b> SDK的<b class='flag-5'>開發(fā)指南</b>的詳細(xì)資料說明

    迅為RK3399開發(fā)板嵌入式linux開發(fā)指南

    迅為RK3399開發(fā)板嵌入式linux開發(fā)指南迅為RK3399開發(fā)板發(fā)布《北京迅為嵌入式linux開發(fā)指
    發(fā)表于 11-01 16:58 ?79次下載
    迅為RK3399<b class='flag-5'>開發(fā)</b>板嵌入式<b class='flag-5'>linux</b><b class='flag-5'>開發(fā)指南</b>

    nRF52832開發(fā)指南-下冊

    nRF52832開發(fā)指南-下冊
    發(fā)表于 06-16 14:14 ?50次下載

    Tina_Linux_系統(tǒng)軟件開發(fā)指南

    Tina_Linux_系統(tǒng)軟件開發(fā)指南
    的頭像 發(fā)表于 03-02 15:25 ?2796次閱讀
    Tina_<b class='flag-5'>Linux</b>_系統(tǒng)軟件<b class='flag-5'>開發(fā)指南</b>

    Tina Linux配置開發(fā)指南

    Tina Linux配置開發(fā)指南
    的頭像 發(fā)表于 03-02 15:28 ?1.8w次閱讀
    Tina <b class='flag-5'>Linux</b>配置<b class='flag-5'>開發(fā)指南</b>

    Linux NOR開發(fā)指南

    Linux NOR開發(fā)指南
    的頭像 發(fā)表于 03-06 09:55 ?1295次閱讀
    <b class='flag-5'>Linux</b> NOR<b class='flag-5'>開發(fā)指南</b>

    【北京迅為】itop-龍芯2k1000開發(fā)指南Linux基礎(chǔ)入門vim 編輯器

    【北京迅為】itop-龍芯2k1000開發(fā)指南Linux基礎(chǔ)入門vim 編輯器
    的頭像 發(fā)表于 10-25 14:56 ?620次閱讀
    【北京迅為】itop-龍芯2k1000<b class='flag-5'>開發(fā)指南</b><b class='flag-5'>Linux</b>基礎(chǔ)入門vim 編輯器

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學(xué)習(xí)
    • 獲取您個性化的科技前沿技術(shù)信息
    • 參加活動獲取豐厚的禮品