目录ui
从上两的两个电路可知3d
1.LED1链接在LED-LINK上,而LED-LINK是从CC2530芯片的P1.0端口引出,一样LED2链接在LED-COMM上,而LED-COMM从CC2530芯片P1.1端口引出。
2.两个LED灯正极接的是CC2530芯片,而负极经过1K电阻后接地。根据LED灯单向导电特性,因此CC2530芯片端口为高电平时LED灯便会亮.code
寄存器名称 | 寄存器做用 | 寄存器描述 |
---|---|---|
P1 (0x90) | *控制端口1的高低电平 | 端口1.通用I/O。能够经过SFR位寻址 |
P1SEL (0xF4) | 端口1 8个子端口的功能选择 | P1SEL的8个bit分别表明 => P1.7~P1.0的功能选择. 值为 0:表明通用I/0(GPIO)功能. 值为 1 : 表明外设功能 |
P1DIR (0xFE) | 端口1 输入输出选择 | P1DIR的bit定义同P1SEL; 值为 0:表明从外部输入信号至CC2530; 值为 1:表明从CC2530输出信号至外部 |
P1INP (0xF6) | 端口1 输入模式选择 | P1INP定义为P1.7~P1.2的I/O输入模式。其中P1.0和P1.1是没有上拉/下拉功能。 值为 0:上拉/下拉。 值为 1:三态(高电平、低电平、高阻态) |
注意:端口输入模式选择中的三态分别是(高电平、低电平、高阻态),其中高阻态是让端口电阻无限大,让其外部信号改变不会影响到内部总线。
在官方示例文档中,推荐使用 &=~
组合赋值运算将寄存器的某一位置为 0
;使用 |=
组合赋值运算将寄存器的某一位置为 1
。咱们能够经过如下示例来了解。blog
例1:将P1_0设置为GPIO功能并将设置为输出模式。
/*********官方推荐************/ // 将P1_0设置为GPIO P1SEL &=~ 0x01; // 将P1_0设置为输出模式 P1DIR |= 0x01; /*********通常作法**********/ P1SEL = 0x00; P1DIR = 0x01;
使用官方推荐的操做方法和使用咱们通常作法有什么好处呢?其实乍一看咱们发现官方推荐方式仍是比较复杂,其实通常作法比较简介,好像通常作法还更好一些。咱们继续看下面的例子。文档
例2:假设P1SEL初始值为0x3一、P1DIR初始值为0xC3.请在不改变初始值的状况下将P1_0设置为GPIO功能并将设置为输出模式。
/*********官方推荐************/ // 将P1_0设置为GPIO P1SEL &=~ 0x01; // 将P1_0设置为输出模式 P1DIR |= 0x01; /*********通常作法**********/ P1SEL = 0x30; P1DIR = 0xC3;
从例2中你们就能够发现官方推荐作法的好处,若是使用官方推荐的方式,那么只须要关注需修改的那一位,不须要知道其它位究竟是怎么样的。其中最重要的就是在改变某一位的值时不会影响到其它位。it
单片机实现延时的方法有不少,通常是经过执行空指令来实现延时的效果。需知道单片机的晶振频率和主频。咱们这里使用的是类51单片机,使用的晶振是32MHz晶振;按照文档说法,执行如下代码可让其延时1ms.io
typedef unsigned int uint; void delay_ms(uint ms) { for(uint i = 0 ; i < ms ; i ++) { for(uint j = 0 ; j < 535 ; j++) } }
本次实验的操做流程以下。table
程序代码中并没有特别难的地方,根据流程图和以前的分析程序一目了然。class
#include <ioCC2530.h> #define LED1 P1_0 //P1.0端口控制LED1发光二极管 #define unint unsigned int void init_gpio() { // 设置 gpio P1SEL &= ~0x01; // 设置 输出 P1DIR |= 0x01; // P1端口下拉 P1 = 0; } void delay(unint z) { for (unint i = 0; i < z; i++) { for (unint j = 0; j < 500; j++); } } void main(void) { init_gpio(); while (1) { LED1 = 0; // 熄灭LED1发光二极管 delay(1000); LED1 = 1; // 点亮LED1发光二极管 delay(1000); } }