ZHCU022AF July   2010  – September 2022

 

  1.   摘要 - MSP430™ 闪存器件引导加载程序 (BSL)
  2.   商标
  3. 1引言
    1. 1.1 补充在线信息
    2. 1.2 BSL 特性概览
    3. 1.3 调用 BSL
      1. 1.3.1 硬件 BSL 调用
        1. 1.3.1.1 具有共享JTAG 引脚的 MSP430 器件
          1. 1.3.1.1.1 阻止使用共享 JTAG 引脚调用BSL的因素
        2. 1.3.1.2 具有专用 JTAG 引脚的 MSP430 闪存器件
          1. 1.3.1.2.1 阻止使用专用 JTAG 引脚调用BSL的因素
        3. 1.3.1.3 带有 USB 的器件
      2. 1.3.2 软件 BSL 调用
    4. 1.4 UART 协议
    5. 1.5 USB 协议
  4. 2引导加载程序协议 - 1xx、2xx 和 4xx 系列
    1. 2.1 同步序列
    2. 2.2 命令
      1. 2.2.1 不受保护的命令
      2. 2.2.2 受密码保护的命令
    3. 2.3 编程流程
    4. 2.4 数据帧
      1. 2.4.1 数据流结构
      2. 2.4.2 校验和
      3. 2.4.3 示例序列
      4. 2.4.4 命令-详细说明
        1. 2.4.4.1  概述
        2. 2.4.4.2  RX 数据块
        3. 2.4.4.3  RX 密码
        4. 2.4.4.4  批量擦除
        5. 2.4.4.5  擦除段
        6. 2.4.4.6  擦除主存储器或者信息存储器
        7. 2.4.4.7  擦除检查
        8. 2.4.4.8  更改波特率
        9. 2.4.4.9  设置内存偏移
        10. 2.4.4.10 加载 PC
        11. 2.4.4.11 TX 数据块
        12. 2.4.4.12 TX BSL 版本
    5. 2.5 可史可法 BSL
    6. 2.6 退出 BSL
    7. 2.7 密码保护
    8. 2.8 代码保护保险丝
    9. 2.9 BSL 内部设置和资源
      1. 2.9.1 芯片识别和 BSL 版本
      2. 2.9.2 外部调用 BSL 的矢量
      3. 2.9.3 初始化状态
      4. 2.9.4 内存分配和资源
  5. 3引导加载程序协议 - F5xx 和 F6xx 系列
    1. 3.1 BSL 数据包
    2. 3.2 UART 外设接口 (PI)
      1. 3.2.1 包装器
      2. 3.2.2 缩写
      3. 3.2.3 消息
      4. 3.2.4 接口专用命令
        1. 3.2.4.1 更改波特率
    3. 3.3 I2C 外设接口
      1. 3.3.1 I2C 协议定义
      2. 3.3.2 具有字节级确认的基本协议
      3. 3.3.3 BSL 的 I2C 协议 - 从从服务器读取
      4. 3.3.4 确认 (ACK)
      5. 3.3.5 包装器
    4. 3.4 USB 外设接口
      1. 3.4.1 包装器
      2. 3.4.2 硬件要求
    5. 3.5 BSL 内核命令结构
      1. 3.5.1 缩写
      2. 3.5.2 命令说明
    6. 3.6 BSL 安全
      1. 3.6.1 受保护的命令
      2. 3.6.2 RAM 擦除
    7. 3.7 BSL 内核响应
      1. 3.7.1 缩写
      2. 3.7.2 BSL 内核消息
      3. 3.7.3 BSL 版本号
      4. 3.7.4 UART BSL 的示例序列
    8. 3.8 BSL 公共函数和 Z 区域
      1. 3.8.1 从外部应用中启动 BSL
      2. 3.8.2 返回到BSL函数描述
  6. 4引导加载程序硬件
    1. 4.1 硬件描述
      1. 4.1.1 电源
      2. 4.1.2 串行接口
        1. 4.1.2.1 电平移动
        2. 4.1.2.2 对 RST/NMI 和 TEST 或者 TCK 引脚的控制
      3. 4.1.3 目标连接器
      4. 4.1.4 部件列表
  7. 5器件和引导加载程序版本间的差异
    1. 5.1 1xx、2xx 和 4xx BSL 版本
    2. 5.2 ROM BSL 版本 1.10 的特殊考虑
    3. 5.3 1xx、2xx 和 4xx BSL 已知问题
    4. 5.4 有关MSP430F14x 器件系列 BSL的特殊说明
    5. 5.5 基于 F5xx 和 F6xx 闪存的 BSL 版本
  8. 6引导加载程序 PCB 布局建议
  9. 7修订历史记录

初始化状态

当激活 BSL 时,下列设置生效:

  • 停止监视计时器
  • 禁用所有中断 (GIE=0)
  • V1.10
    堆栈指针不会被修改,除非它指向已排除的内存区域。如果是,则初始化为 021Ah。
    V1.30 或更高版本
    如果 BSL 由程序通过热启动矢量调用,则堆栈指针不会被修改。如果 BSL 由 BSL RESET 序列启动或者由程序通过冷启动矢量调用,则初始化为 0220h。
  • F1xx
    确定基本时钟模块,使最低频率为 1.5MHz:
    只在冷启动时
    SR,BCSCTL1 = 85h(RSEL = 5,XT2Off = 1)
    DCOCTL = 80h(DCO = 4,MOD = 0), BCSCTL2 = 00h:只在冷启动时, SCG1 = 00h(SMCLK 开启)
    F2xx
    确定基本时钟模块,使最低频率为 1.5MHz:
    只在冷启动时
    SR,BCSCTL1 = 88h(RSEL = 8,XT2Off = 1)
    DCOCTL = 80h(DCO = 4,MOD = 0)
    , BCSCTL2 = 00h:只在冷启动时, SCG1 = 00h(SMCLK 开启)
    F4xx
    确定 FLL 振荡器和系统时钟,使最低频率为 1.5MHz:
    SCFI0 = 00h(D = 0,FN_x = 0)
    SCFI1 = 98h (N_DCO)
    SCFQCTL:(M = 0)
    SR:SCG0 = 1(FLL 环路控制关闭)
    只在冷启动时, FLL_CTL1 = 00h
  • SW-UART:Timer_A 在带有 MCLK 源的连续模式 (Div=1) 下运行
    CCR0 用于比较
    CCTL0 用于 CCIFG0 的轮询
  • TX 引脚设置为 RS232 闲置状态输出高电平
  • RX 引脚设置为输入
  • 受密码保护的命令被锁定(只在冷启动时)

系统初始化之后,BSL准备运行,并等待第一个同步序列 (SS),接着是包含第一个 BSL 命令的数据帧。