目錄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); } }