28335 bootloader
时间: 2023-05-08 11:02:00 浏览: 97
28335 bootloader是指针对Texas Instruments公司生产的C2000系列32位微控制器28335而设计的启动程序。这个启动程序是在芯片上电后最先运行的程序,在它的作用下,其他的高级应用程序才能被正确加载和执行。
28335 bootloader的主要功能是用于引导加载其他的应用程序,包括DSP算法、驱动程序和应用层程序等等,因此它的稳定性和可靠性非常重要。此外,它还要负责初始化硬件系统、检测外设和存储器设备以及设置时钟和中断等操作,为后续程序的正常运行做好准备工作。
28335 bootloader通常由固件工程师和嵌入式系统开发人员编写,并在开发板上进行验证和调试。在编写过程中,需要考虑到芯片硬件的特性、外设的设置以及存储器地址等方面的因素,避免在后续的应用程序中出现问题。
总之,28335 bootloader是一种非常重要的启动程序,它为嵌入式系统提供了必要的支持和保障,确保其他应用程序能够被正确运行。
相关问题
dsp28335bootloader
DSP28335是德州仪器(Texas Instruments)公司推出的一款数字信号处理器。而bootloader(引导加载程序)是一段存在于DSP28335芯片上的特殊程序,用于引导加载操作系统或其他应用程序。
DSP28335 bootloader的作用主要包括以下几点:
1. 引导加载:bootloader负责在DSP28335芯片上的存储器中寻找到操作系统或其他应用程序的入口地址,并将其加载到芯片的内存中进行运行。通过bootloader的引导加载,DSP28335芯片能够正确地启动操作系统或应用程序,实现功能的正常运行。
2. 程序更新:由于DSP28335芯片上的应用程序需要不断更新,bootloader提供了程序更新的功能。当需要更新应用程序时,可以通过特定的方式将新的程序写入芯片的存储器中,并在重启后由bootloader负责将新的程序加载到内存中,实现程序的更新。
3. 系统设置:bootloader还可以提供一些系统设置的功能,如处理器时钟频率设置、外设初始化配置等。这些设置可以保证DSP28335芯片在启动时具有特定的系统配置,以支持不同的应用需求。
总的来说,DSP28335 bootloader是一段特殊的程序,控制着DSP28335芯片的启动过程、程序加载和更新,以及系统设置等功能。它在DSP28335芯片的使用过程中起到了重要的作用,保证了芯片的正常运行和应用的更新。
TMS320F28335 bootloader参考代码
以下是一个简单的TMS320F28335 bootloader的参考代码,仅供参考:
```c
#include "F28335_SysCtrl.h"
#include "F28335_Gpio.h"
#include "F28335_Sci.h"
#define APP_START_ADDR 0x8000 // 应用程序的起始地址
#define PAGE_SIZE 128 // 每页的大小
#define FLASH_SECTOR_SIZE 0x1000 // 扇区大小
void jump_to_app(void); // 跳转到应用程序
void main(void)
{
Uint16 i;
Uint16 page_buf[PAGE_SIZE];
Uint32 app_addr = APP_START_ADDR;
Uint16 page_addr = 0;
Uint16 page_num = 0;
Uint16 page_count = 0;
Uint16 byte_count = 0;
Uint16 checksum = 0;
Uint16 cmd = 0;
Uint16 len = 0;
Uint16 data = 0;
Uint16 crc = 0;
InitSysCtrl(); // 初始化系统时钟
InitGpio(); // 初始化GPIO
InitSci(); // 初始化SCI
// 等待接收命令
while(1)
{
// 接收起始符和命令
while(SciRxReady() == 0);
cmd = SciaRegs.SCIRXBUF.all;
while(SciRxReady() == 0);
cmd |= (SciaRegs.SCIRXBUF.all << 8);
// 接收数据长度
while(SciRxReady() == 0);
len = SciaRegs.SCIRXBUF.all;
while(SciRxReady() == 0);
len |= (SciaRegs.SCIRXBUF.all << 8);
// 接收数据
for(i = 0; i < len; i++)
{
while(SciRxReady() == 0);
data = SciaRegs.SCIRXBUF.all;
page_buf[byte_count++] = data;
// 每填满一页,就写入一次FLASH
if(byte_count == PAGE_SIZE)
{
EALLOW;
FlashErase((Uint16*)(app_addr + page_addr));
for(i = 0; i < PAGE_SIZE; i += 2)
{
FlashProgram((Uint16*)(app_addr + page_addr + i), page_buf[i/2]);
}
EDIS;
byte_count = 0;
page_addr += PAGE_SIZE;
page_num++;
// 判断是否填满一个扇区,如果是,就跳转到应用程序
if(page_num == FLASH_SECTOR_SIZE / PAGE_SIZE)
{
jump_to_app();
}
}
}
// 计算校验和
for(i = 0; i < len; i++)
{
checksum += page_buf[i];
}
// 接收校验和
while(SciRxReady() == 0);
crc = SciaRegs.SCIRXBUF.all;
while(SciRxReady() == 0);
crc |= (SciaRegs.SCIRXBUF.all << 8);
// 验证校验和是否正确
if(checksum != crc)
{
// 校验和错误,发送NAK
SciaRegs.SCITXBUF = 0x15;
}
else
{
// 校验和正确,发送ACK
SciaRegs.SCITXBUF = 0x06;
// 计算数据总量
page_count += page_num;
page_num = 0;
// 判断是否接收完毕,如果是,就跳转到应用程序
if(cmd == 0x01)
{
jump_to_app();
}
}
}
}
void jump_to_app(void)
{
asm(" ESTOP0"); // 停止CPU
asm(" LWR 0, X:SP"); // 从应用程序的栈地址处加载SP
asm(" LWPI 0, X:PC"); // 从应用程序的程序地址处加载PC
asm(" NOP"); // 等待上面的指令执行
asm(" NOP");
asm(" NOP");
asm(" NOP");
}
```
以上代码仅为示例代码,仅供参考,具体实现可能因应用场景不同而有所差异。您需要根据自己的需求来编写和测试bootloader代码。