STM32MP135裸机编程:唯一ID(UID)、设备标识号、设备版本

0 资料准备

1.STM32MP13xx参考手册

1 唯一ID(UID)、设备标识号、设备版本

1.1 寄存器说明

(1)唯一ID
唯一ID可以用于生成USB序列号或者为其它应用所使用(例如程序加密)。
在这里插入图片描述
(2)设备标识号
通过该寄存器可以获知STM32MP13xx的具体型号
在这里插入图片描述

(3)设备版本
用于区分STM32MP13xx的硬件版本,DEV_ID应该固定为0x501。
()

1.2 使用方法

以下代码打印唯一ID、设备标识号、设备版本

int cpu(void)
{
    u16 *p;

    /* SOC型号 */
    p = (u16 *)RPN_BASE;
    printf("RPN         : 0x%03X\r\n", p[0] & 0xfff);
    printf("Model       : ");
    
    switch (p[0] & 0xfff)
    {
    case 0x6C9:
        printf("STM32MP131A\r\n");
        break;
    case 0x6C8:
        printf("STM32MP131C\r\n");
        break;
    case 0xEC9:
        printf("STM32MP131D\r\n");
        break;
    case 0xEC8:
        printf("STM32MP131F\r\n");
        break;
    case 0x0C1:
        printf("STM32MP133A\r\n");
        break;
    case 0x0C0:
        printf("STM32MP133C\r\n");
        break;
    case 0x8C1:
        printf("STM32MP133D\r\n");
        break;
    case 0x8C0:
        printf("STM32MP133F\r\n");
        break;
    case 0x001:
        printf("STM32MP135A\r\n");
        break;
    case 0x000:
        printf("STM32MP135C\r\n");
        break;
    case 0x801:
        printf("STM32MP135D\r\n");
        break;
    case 0x800:
        printf("STM32MP135F\r\n");
        break;
    default:
        printf("Unknown\r\n");
        break;
    }

    /* UID信息 */
    p = (u16 *)UID_BASE;
    printf("UID         : %04X-%04X-%04X-%04X-%04X-%04X\r\n", p[5], p[4], p[3], p[2], p[1], p[0]);
    

    /* 设备版本号 */
    p = (u16 *)DV_BASE;
    printf("version     : 0x%04x\r\n", p[1] & 0xfff);

    return 0;
}

打印内容如下:
在这里插入图片描述

相关推荐

  1. UniApp中获取安卓设备唯一标识符

    2024-07-15 00:26:04       32 阅读
  2. stm32mp135d u-boot 引导流程

    2024-07-15 00:26:04       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 00:26:04       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 00:26:04       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 00:26:04       57 阅读
  4. Python语言-面向对象

    2024-07-15 00:26:04       68 阅读

热门阅读

  1. DelphiXE内存泄漏问题,已经发生了很多次

    2024-07-15 00:26:04       22 阅读
  2. ros2--colcon

    2024-07-15 00:26:04       20 阅读
  3. 行人越界检测 越线 越界区域 多边形IOU越界判断

    2024-07-15 00:26:04       22 阅读
  4. Vscode插件推荐——智能切换输入法(Smart IME)

    2024-07-15 00:26:04       19 阅读