msp430点灯实验
一、实验内容
使用开发板:msp430f5529
使用的LED灯:为开发板上自带的User LEDs(LED1、LED2)
环境:CCS (Version: 12.2.0.00009)
通过ccs编写代码,控制LED1和LED2交替闪烁
二、开发板介绍
开发板正面 与背面图
1、 I/O 的简介
一般情况下,P1和 P2都是具有中断能力的。从 P1和 P2接口的各个I/O 管脚引入的中断可以独立的被使能并且设置为上升沿或者下降沿触发。对应的中断向量表分别为 P1IV 和 P2IV,它们只能进行字操作,并且 PAIV 这个寄存器根本不存在。 P1、P2可合为 PA,P3、P4可合为 PB,…PC、PD。所以 P1为8位BCD 0x00,PA 为16位 BCD 0x0000。当进行字操作写入 PA 口时,所有的16位都被写入这个端口;当利用字节操作写入 PA 口的低字节时,高字节保持不变。
2、I/O 的简单配置
(1)、功能选择寄存器 PXSEL
用来声明该端口是要应用于外围电路的特殊功能(不决定输入输出方向),默认为低电平。
低电平表示通用 I/O(默认),高电平表示该引脚将有连接外围电路的特殊用途即作为外设;
如:设置P1.0和P1.1为通用 I/O的操作:
P1SEL &= ~(BIT0+BIT1);
(2)、I/O 方向设定寄存器 PXDIR
如设定 P1.1和 P1.2为输出状态 操作为:
P1DIR |=(BIT1+BIT2); //等价于 PADIR |=(BIT1+BIT2)或 PADIR_L |=(BIT1+BIT2)
注意: 在msp430f5529.h的头文件中BITS有如下定义:
(3)、I/O 输入设定寄存器 PXIN
如设定 P1.1和 P1.2的输入为低电平 操作为:
P1IN &= ~(BIT1+BIT2);
(4)、I/O 输出设定寄存器 PXOUT
只用为简单的输出时:
设定 P1.1和 P1.2输出高电平 操作为:
P1OUT |= (BIT1+BIT2);
如果该引脚为正常 I/O 功能,且当前已设定为输入方向,且上拉/下拉电阻寄存器是有效地。那么 PXOUT 可以用来配置上拉和下拉电阻: 低电平为下拉电阻; 高电平为上拉电阻。
(5)、上拉/下拉电阻使能寄存器
低电平表示该寄存器为无效状态; 高电平表示该寄存器为有效状态;
三、原理图(只涉及本实验的)
由原理图可知,本实验应该设置P1.0和P4.7引脚为通用I/O,并且方向为输出方向,当P1.0和P4.7引脚为高电平时LED1和LED2点亮,为低电平时LED1和LED2熄灭。四、代码部分
main.c
#include <msp430.h>
#include <delay.h>//延时函数
#include <led.h> //初始化函数
int main(void)
{
WDTCTL = WDTPW | WDTHOLD; // 关闭看门狗
LED_Init(); //led初始化函数
while (1)
{
P1OUT |= BIT0; //亮灯
P4OUT &= ~BIT7; //熄灯
delay_ms(1000);
P1OUT &= ~BIT0; //熄灯
P4OUT |= BIT7; //亮灯
delay_ms(1000);
}
// return 0;
}
led.h
#ifndef GO_LED_H_
#define GO_LED_H_
#include <msp430.h>
void LED_Init(void);//初始化函数
#endif
led.c
#include "led.h"
void LED_Init(void)//led初始化函数
{
P1SEL &= ~BIT0; //设置P1.0口为通用I/O
P4SEL &= ~BIT7; //设置p4.7口为通用I/O
P1DIR |= BIT0; //设置P1.0口为输出模式
P4DIR |= BIT7; //设置p4.7口为输出模式
//初始化为熄灭
P1OUT &=~ BIT0; //低电平熄灯
P4OUT &=~ BIT7; //低电平熄灯
}
delay.h
#ifndef GO_DELAY_H_
#define GO_DELAY_H_
#include <msp430.h>
#define CPU_F ((double)1000000)
#define delay_us(x) __delay_cycles((long)(CPU_F*(double)x/1000000.0))//重新定义延时函数
#define delay_ms(x) __delay_cycles((long)(CPU_F*(double)x/1000.0))
#endif