BIN格式的文件是通过编译软件编译生成的,你只要把这个格式的文件通过专门的烧录工具烧录到单片机的芯片中。不同的开发工具对应有不同的烧录工具的。
需要用到的工具就是烧录工具,任何开发开发方案中都会带有烧录工具的,你仔细找找肯定存在的。 我用的烧录工具名字为:burn_tool,你找找看有没有类似这样名字的小程序。
4-ADC12应有例程
//
//MSP430F149 ADC12模块+串行通讯的实验程序
//使用ADC12采集实验,将采集到数据送向PC(单路单次采集)
//P34为发送,P35为接收 晶体使32768HZ/8MHZ 串行波特率B/S
//使用SMCLK作为波特率发器时,不能使用LPM2,LPM3!
//以下程序已验证通过,初学者可直接使用由时间仓促和水平有限,请读者批评指正
//编写:>
需要说明的是该程序的功能是用定时器A的定时功能,对LED周期性的循环点亮。定时器A与CPU用的时钟源可以说是相互独立的(定时器A的时钟源选择MCLK时除外)。所以,当CPU进入休眠时,只要定时器A的时钟正常,他就能正常计数,产生定时间隔,也就能产生中断。
你的程序中TACTL = TASSEL_1 + ID_3 + MC_1; 定时器A的时钟源选择是ACLK,而CPU默认的是DCOCLK,两者并不冲突。这样写BCSCTL1 |=DIVA_1; 当然可以了(个人觉得这里没必要分频)。至于LPM3; 这句可要可不要。要的话,只要保证CPU进入低功耗时,你的定时器A的时钟ACLK正常工作就行。
不知道,这样说能明白不?
首先写发送程序,必须要使发送接收模块被允许,所以必须ME1 |= UTXE0 + URXE0该语句必须要写。其次发送接收都是高频的,故要将晶振设为高频,然后再对各个寄存器最一下必要的设置。
USART控制寄存器的组成部分:PENA,PEV,SP,CHAR,Listen,SYNC,MM,SWRST
各位都有其 *** 作功能,我列举几个我觉得比较重要的
首先看SYNC:
串口发送主要可分为异步的UART模式,和同步的SPI模式,即由SYNC来控制,
SYNC:“0”UART模式
“1”SPI模式
CHAR:“0”选择字符以7位发送,不用接收缓存寄存器URXBUF或发送缓存寄器UTXBUF的最高位
“1”选择字符以8位发送
SWRST: 置位时,USART的各中断允许初始化,直至复位时USART才被允许。
发送控制寄存器UTCTL亦类似,对各个位做必要的设置就可以得到你想要的结果。UTCTL8位由高到低分别为:未用,CKPL,SSEL1,SSEL0,URXSE,TXWake,未用,TXEPT。还有接收控制寄存器URCTL0和URCTL1详情可以参照书本。
另有一个比较重要的就是波特率计算,用到UBR0及UBR1波特率寄存器以及调整控制寄存器UMCTL具体计算为:UBR,UBR1和UBR0的16位数据
Mx ,调整器的各位数据
波特率=时钟周期/(UBR+(M7+M6+…+M0)/8)
贴上一个简单的程序:
#include <msp430x14xh>
void main(void)
{
volatile unsigned int i;
WDTCTL = WDTPW + WDTHOLD; // 关闭开门狗
P3SEL |= 0x30; // P34,5 = USART0 TXD/RXD
BCSCTL1 |= XTS; // ACLK= LFXT1,LFXT1高频工作
do
{
IFG1 &= ~OFIFG; // Clear OSCFault flag
for (i = 0xFF; i > 0; i--); // Time for flag to set
}
while ((IFG1 & OFIFG)); // OSCFault flag still set
BCSCTL2 |= SELM_3; // MCLK = LFXT1 (safe)
ME1 |= UTXE0 + URXE0; // Enable USART0 TXD/RXD
UCTL0 |= CHAR; // 8-bit character
UTCTL0 |= SSEL0; // UCLK= ACLK
UBR00 = 0x45; //
UBR10 = 0x00; //
UMCTL0 = 0x00; // 波特率计算
UCTL0 &= ~SWRST; //初始USART
IE1 |= URXIE0; // Enable USART0 RX interrupt
_BIS_SR(LPM0_bits + GIE); // Enter LPM0 w/ interrupt
}
#pragma vector=UART0RX_VECTOR
__interrupt void usart0_rx (void)
{
while (!(IFG1 & UTXIFG0)); // USART0 TX buffer ready
TXBUF0 = RXBUF0; // RXBUF0 to TXBUF0
}
亦可参考汇编的:
#include "msp430x12xh"
ORG 01100h ; Progam Start / 程序开始 /
;------------------------------------------------------------------------------
RESET movw #0A00h,SP //将立即数#0A00h赋给寄存器SP
call #Init_Sys
Mainloop bisb #CPUOFF,SR ; Enter LPM0 //CPU关闭进入低功耗模式0
nop
Init_Sys; Initalize MSP430 system
;------------------------------------------------------------------------------
StopWDT movw #WDTPW+WDTHOLD,&WDTCTL ; //关闭看门狗,高8位5A是写入,低8位80为时钟输入禁止,计数停止
SetupBC bisb #XTS,&BCSCTL1 ; LFXT1 = HF XTAL //选择晶振频率为高频,BCSCTL1寄存器的D6位为1,表示选择高频
SetupOsc bicb #OFIFG,&IFG1 ; Clear OSC fault flag //清中断标志1
movw #0FFh,R15 ; R15 = Delay //通用寄存器R15数据初始化
SetupOsc1 decw R15 ; Additional delay to ensure start //减一
jnz SetupOsc1 ; //不等于0时程序跳转
bitb #OFIFG,&IFG1 ; OSC fault flag set //状态位C置位
jnz SetupOsc ; OSC Fault, clear flag again //重新清中断标志1
bisb #SELM1+SELM0,&BCSCTL2 ; MCLK = LFXT1 //选择LFXT1CLK为MCLK的时钟源
SetupUART0 movb #CHAR,&UCTL0 ; 8-bit characters //8位数据位
movb #SSEL0,&UTCTL0 ; UCLK = ACLK //选择辅助时钟ACLK
movb #045h,&UBR00 ; 8MHz 115200
movb #000h,&UBR10 ; 8MHz 115200 //计算波特率
movb #000h,&UMCTL0 ; 8MHz no modulation 115200//未分频
bisb #UTXE0+URXE0,&ME1 ; Enable USART0 TXD/RXD //串口发送接收允许
bisb #URXIE0,&IE1 ; Enable USART0 RX interrupt//串口接收中断允许
SetupP3 bisb #030h,&P3SEL ; P34,5 = USART0 TXD/RXD //选择P34,5口,030h=001(p5)1(p4)0000,P3SEL的地址01bh的数值应该为0
bisb #010h,&P3DIR ; P34 = output direction //010h=0001(p4)0000,p4口为输出,
eint ; General enable interrupts //
ret ; Return from subroutine
;
;------------------------------------------------------------------------------
USART0RX_ISR; Confirm TX buffer is ready, then Echo back RXed character
;------------------------------------------------------------------------------
TX1 bitb #UTXIFG0,&IFG1 ; USART0 TX buffer ready //发送中断标志
jz TX1 ; Jump is TX buffer not ready //没在等待发送,则再去判断等待发送的标志
movb &RXBUF0,&TXBUF0 ; TX -> RXed character //共用一块缓冲
reti ;
;
;------------------------------------------------------------------------------
; Interrupt Vectors Used MSP430x13x/14x
;------------------------------------------------------------------------------
ORG 0FFFEh ; //复位中断
DW RESET ; POR, ext Reset, Watchdog //中断入口
ORG 0FFF2h ; //等待串口接收数据中断
DW USART0RX_ISR ; USART0 receive //串口接收
END
iar编程自带驱动的
需要
仿真器
开发板
跟电脑连接的驱动?
是串口吗?如果是就看芯片搜驱动
如果是下载用的
就配个msp-fet仿真器把
这个功能貌似没什么用
初始化之后是硬件自动实现的
你配置好寄存器即可;
通讯精准可以这么做
循环接受for(char i=1;i<数据长度;i++)
{
int overtime=0;
这里写接受函数
while (!(IFG2 & URXIFG1)){overtime++;if(overtime>1000)return;}
}
知识豪杰,快来加入430f149团队吧,一起答疑助人,没你不行!团队地址:>
以上就是关于新手求助:这里有个BIN格式的程序,如何将程序烧进msp430f149单片机里,需要用到什么。全部的内容,包括:新手求助:这里有个BIN格式的程序,如何将程序烧进msp430f149单片机里,需要用到什么。、谁帮我讲一下这段IAR的c语言程序,200分重谢!、我在调试一个map430f149单片机的程序,有两个疑问,请求高手解惑啊等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)