|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
——疯壳·开发板系列 GPIO实验教程 W& e1 i6 i9 T' h& U0 R
: s) L' u5 H( E! C% O/ w
" ^& C/ I: D! K" N! p3 l# O. R5 S$ [6 r D
3 q# T, [" v/ n& c. s8 V 图1 e0 j: _9 [9 E$ e7 p0 @
. p% K7 Y& l4 ?) h6 W 第一节LED硬件电路
4 m# E ^+ X7 |5 V" h# B. y+ L( G4 p: J) U
板子中有一个可控LED,接在DA14580的P24引脚,LED串联1K的限流电阻,如下图所示:& u" K- r- [9 X
' |1 S8 U8 M1 d+ q# M8 h8 Q
( ~3 e0 l2 i( G3 b4 q& G
图2
; v- ?" B4 C+ E+ v7 c* M- ~6 A+ Y/ h( F0 U5 U0 M$ t
Y+ O R4 r0 q9 [ g6 v4 }3 N
第二节 GPIO寄存器- v; o. [$ D* a* p/ T- H
$ N* q% W$ J8 Z# B t: b7 h T4 w 2.1 GPIO引脚介绍
5 F# D" J! s5 G! U4 f DA14580的I/O引脚功能可以通过软件配置,分为4组,分别为Port0、Port1、Port2、Port3,其中Port2只在QFN40与QFN48封装的芯片中,Port3只在QFN48封装的芯片中。
. M. k. E( |- s* ?8 d9 D Port0有8个引脚,Port1有6个引脚(其中包括DEBUG引脚SW_CLK与SWDIO),Port2有10个引脚,Port3有8个引脚;
6 }" x1 X: a3 l9 R0 g5 [$ y 每个引脚都可以选择上拉或者下拉25KOhm的电阻;
$ T' r, }% K! Q- i/ Q 每个引脚上拉电压在VBAT3V(降压模式)与VBAT1V(升压模式)两者可选;
- @* V$ H9 t9 D Q* l3 N1 F7 z 4路模数转换的引脚固定分配为Port0中的0:3引脚;
+ C0 T( [) e' E1 j! v 当系统进入睡眠模式时,引脚保持最后的状态。5 |* A! h5 N. R" p& x+ @
2.2寄存器介绍
7 y/ D5 `2 i( i) v. B 2.2.1 P0数据寄存器3 v! t3 I! M* q* S+ u4 s
" I$ P+ O+ p+ B1 z* a
5 G6 _5 J- f6 h6 l9 m+ j6 M
图3/ [ j7 m: k( y. L3 i0 ~$ s L; y
15:8位:保留不使用;! Z+ \2 T% W' v- d5 a
7:0位:写该寄存器则设置P0输出寄存器的值,读该寄存器则返回P0口的值。, Q3 ^, Q- o, X" x
2.2.2 P0设置数据寄存器
( R3 p: `& O; \! e: U8 c# ]" k/ d6 S- w
6 x7 t4 _& X5 A% Q 图4
' i$ p# x& T3 M+ v5 W% G7 w4 _ 15:8位:保留不使用;8 Y6 W* |7 V0 l
7:0位:写’1’到对应位则对应的引脚置’1’,写’0’无效,读该寄存器则返回0。
+ N8 w* @% z* V& u 2.2.3 P0复位数据寄存器! E+ A w0 h! r
6 k" h$ t3 X! b8 p" n X6 q7 |! Y& O
) m% ~7 n& H& V5 ^* e 图5- g! U: P0 w8 z# m. |0 X
15:8位:保留不使用;: I: g9 q1 V- k: A( F
7:0位:写’1’到对应位则对应的引脚置’0’,写’0’无效,读该寄存器则返回0。
$ ?, [8 r8 T! d/ r 2.2.4 P00模式寄存器8 B1 s! D, k% ]
" F$ G. Y) w* B( P; A7 C$ N
1 j; V" G) M! C' M* D, \" Z
8 A$ ^% `6 O7 d j8 l. `7 O 图6: J( \, t( F$ {! x6 v! o
15:10位:保留不使用;
0 q0 C. K5 m. t$ M* p 9:8位:设置引脚的上拉、下拉电阻的模式,00为输入,无电阻;01为输入,上拉电阻;10为输入,下拉电阻;11为输出,无电阻;在ADC模式中该位的设置无效。6 X- _3 I- ^4 N m" R) K8 z2 F
7:5位:保留不使用;8 [7 l8 j% Y! a4 Y3 R3 D
4:0位:设置引脚功能,0~25分别对应不同的功能,具体看上图,注:当一个输入功能设置为多个引脚时,引脚序号越低优先级越高,即优先选用序号低的引脚设置为该功能。P0的优先级比P1的高。
- S2 B' k1 m' S1 `9 J4 x 2.2.5 P1~P3的寄存器配置$ C! u) Z6 m' K+ j* f* l
参照P0寄存器的配置,需要注意的是P14与P15两个引脚模式的默认值是1,即默认上拉电阻。( u) U6 w. z( o0 C& u2 P
注:P14与P15为SWD调试接口的时钟与数据接口,在使用Jlink调试过程中不要使用这两个引脚。
7 J% O, H+ W- n 2.3 寄存器配置讲解+ p1 P3 j" t; l4 m9 q
#define P0_DATA_REG (* ( volatile uint16*)0x50003000)' r, N8 u) m5 G3 G$ z
#define P0_SET_DATA_REG (* ( volatile uint16*)0x50003002)
& @2 U2 U$ l; ^ #define P0_RESET_DATA_REG (* ( volatile uint16*)0x50003004)
- o( ]6 g! M/ _2 O2 { #define P00_MODE_REG (* ( volatile uint16*)0x50003006)% _$ U; f6 P! {% ~- ^" X6 v4 y" k0 a; \/ [
#define P01_MODE_REG (* ( volatile uint16*)0x50003008)
" P2 W2 m/ Y# c" h/ G #define P02_MODE_REG (* ( volatile uint16*)0x5000300A)+ N! c6 i% U( G, U* y' G* H: R
#define P03_MODE_REG (* ( volatile uint16*)0x5000300C); b: G* t+ g7 t( W7 z
#define P04_MODE_REG (* ( volatile uint16*)0x5000300E)
5 ?: W. S1 E' b4 ?" K7 z; m0 \ #define P05_MODE_REG (* ( volatile uint16*)0x50003010)
9 y8 |( B" J" r7 }/ `" \2 j #define P06_MODE_REG (* ( volatile uint16*)0x50003012), m0 r; Z! W) y3 {+ ?
#define P07_MODE_REG (* ( volatile uint16*)0x50003014)
; K+ F0 d' o' m* Q) [ 如果对P0整体操作,可以使用P0_DATA_REG寄存器,若使P0[7:0] = 0xaa,因为以上宏定义是定义的地址,则寄存器操作为P0_DATA_REG=0xaa;. S; i2 K7 B9 K
如果要读取P0的状态值,则通过读取P0_DATA_REG寄存器,P0_STATUS = P0_DATA_REG,若要读取某一位的状态值,则通过与操作之后返回逻辑值即可。$ u; a# {0 V% D7 ~7 q8 X" d" K8 [6 N) j# p
作为输出时P0_DATA_REG适合对整体P0口操作,而对于某一位进行操作则需要经过一些逻辑操作保持其它位的值不变,不是很方便。而P0_SET_DATA_REG和P0_RESET_DATA_REG这两个寄存器对位操作就十分方便。对某一位置’0’或置’1’只需对应位赋1,其它位赋0即可,因为该寄存器忽视写0操作。若使P00 = 1,P01 = 0则P0_SET_DATA_REG =0x01; P0_RESET _DATA_REG=0x02;. d6 \* P, W! j, E9 A, `
P0[x]_MODE_REG是P0口某一位的操作模式的设置寄存器,例如配置P00为输入口,不上拉电阻,P01为I2C_SDA,P02为输出口,则' S) Y! L3 d4 h
P00_ MODE _DATA_REG=0x00;. v7 P& Z8 J# _; _$ q- o
P01_ MODE _DATA_REG=0x0a; 6 a0 n4 e$ z* D. ~ `
P02_ MODE _DATA_REG=0x30;
5 r4 P z4 ^8 X. M/ k
+ d4 p3 @, c) Y- Q1 I6 Y+ P, j; @' x( X
* d# D" L+ {& H+ ]' ~7 M0 {* k0 ? 第三节 GPIO实验
% i$ t) p: c9 s' L3 L5 c5 ~
3 u* G; D+ P' q- m9 V4 Z 实验需要使用的模块有:手机开发板底板,Jlink调试工具,杜邦线、3.7V锂电池或Mocro USB线。8 l" G, \) O4 e% f0 V2 F1 H
使用JLINK通过杜邦线连接手机蓝牙位于手机主控底板,连接方式如下:4 x: U. z3 G; {' I; R
(1)JLINK一端只需要使用杜邦线连接JLINK的SWC、SWD、GND三个引脚,如下图所示:) J5 ^( K K: ]* @5 }: I; \
: N& }1 b- H5 `3 K/ [7 C$ M5 j
# ?( u. Q& E/ M# L
图7! l2 V& R, G, K- I. `
(2)手机蓝牙一端需要使用杜邦线连接上方右侧的J3三个引脚,与JLINK的连接引脚一一对应,分别为SWC-->SWCLK、SWD-->SWDIO、GND-->GND,如下图所示:
! X) m- V5 h" R. J3 ^3 X, g) y6 H( h5 h# k$ R2 `
% ]5 k7 `3 M* p0 w. `; C# l
图8# t N- ^: i, S1 ~6 ^) }1 F
将JLINK插上电脑的USB接口,连接好之后给手机主控底板供电,详细的介绍可以参考《如何上电》教程,路径为:..\WT_Mobile\0.从这里开始\0.开机测试。
' E1 {4 |' Q f+ J) f7 j 打开GPIO实验的Keil工程blinky.uvproj,位于目录:1 d+ _3 a0 v a; x
...\WT_Mobile\1.初级教程\DA14580\1.GPIO实验\projects\target_apps\peripheral_examples\blinky\Keil_5。
4 V! r% t: \+ h5 v3 C4 | L x7 M6 W2 X$ u0 X7 G; k+ }
X6 D# Z: L0 n8 `) K
图9
( m( R* l$ F( |+ R% v' y 打开工程文件之后,编译,点击DEBUG,然后点击全速运行,则可以看到开发板正面的蓝色LED灯开始闪烁,如下图所示:; h& p9 i! ^: O$ ?; X% Q
1 v! y. { V+ [8 k
; m2 n3 c. p( ~. _" Y5 M. e* w8 f" ]8 b
' J2 Z( q, ~7 J. @7 R9 q5 b
图10
7 Q+ V8 N- M0 T% N' l: u" I% U, u
& o0 W7 M/ M& q2 ^# `5 h8 f% B2 J$ D( U8 d
" E8 d# \" Z; Q" ?/ ]* Z* H* V 文件下载请点击:
GPIO实验教程.pdf
(710.42 KB, 下载次数: 0)
/ V0 N5 t2 n% @4 Q$ g
, i+ m+ w: x6 O h3 l4 m" Z4 Z h |
|