|
EDA365欢迎您!
您需要 登录 才可以下载或查看,没有帐号?注册
x
内容简介 & A. k4 a4 I5 o) M
《Atmega128单片机入门与提高》以引导读者快速掌握对ATmega128/128L单片机的编程为目的,详细介绍了涉及编程的ATmega128/128L单片机内部结构和外围接口的特点、性能及其指令系统。在此基础上,又介绍了ICCAVR 6.31A、GCCAVR、CodeVision AVR、IAR等集成开发环境编译器使用C语言的相关知识以及AVR Studio调试环境。书中穿插大量的实用程序,并在最后一章给出了许多综合实例;实例程序全部用C语言编写,且已全部在ICCAVR 6.31A开发环境上编译通过。《Atmega128单片机入门与提高》配光盘1张,包含书中全部实例程序的源代码以及一些相关的学习资料。
9 H' Z6 n9 w- e0 ^" O. y7 x/ r 《Atmega128单片机入门与提高》适合于ATmega128单片机的初学者以及有一定单片机与嵌入式系统应用基础的电子工程技术人员阅读,也可作为高等院校电子信息、自动控制等专业教学和科研开发的参考书。 % _' i0 F1 O$ x# G
: c: r' w' C1 q. y8 G
+ N' e: _' F ^目录
$ z2 J3 g6 Y7 D0 Z$ d3 Z第1章 单片机概述# q u2 u9 ?, A; s. X: a) T: B
1.1 单片机发展概述
& x9 K g, {. ]; A& K1.2 嵌入式系统与单片机& D# y( g/ {9 k" e B
1.3 AVR单片机概述# h' h4 }# _( E
1.4 AVR单片机的主要特点0 f* L7 g! j" e' T
1.5 AVR单片机最小系统, k9 r7 w6 c( |
1.6 AVR单片机实验系统概述& C# v5 t# j, Y" ]# s
+ _/ A: O) [' t# i; T
第2章 ATmega128硬件结构0 P, c4 U0 @' E, L3 ~ l5 o3 g
2.1 概述
: @5 q0 U2 F+ W9 F; I- E! Y2.1.1 结构和主要特点
" y) H9 C& d2 ]& f+ K2.1.2 主要性能" r9 d6 C: ]0 R
2.1.3 封装和引脚
5 a& O, k' n, V7 ~- k2.1.4 指令系统
+ e7 K8 D) i8 L, p2.2 内核9 T' h+ u0 q! s) \
2.2.1 结构概述
5 Z) r+ m+ Y- i8 e7 v$ P/ ]2.2.2 微控制器MCU* ]4 T- n- p R2 s$ `$ ^; V z/ O/ h9 v
2.2.3 指令执行时序4 o/ B" L4 M, b) B% {
2.2.4 复位和中断处理
: J) i5 n0 Z, g- @: t) T6 M2.3 存储器结构' i# U3 R# }* U9 o
2.3.1 系统内可编程的Flash程序存储器
0 h: C. Q9 l; }1 M* x2.3.2 SRAM数据存储器
! p. c. W$ V, I; d9 K2.3.3 I/O寄存器5 W- r' o4 [+ `' I- N& L( @. ~+ P
2.4 I/O端口描述$ n# {) x1 W/ w& T* g
2.4.1 作为通用数字I/O的端口* A. s% u$ j+ e: [( L% N! S a
2.4.2 数字输入使能和睡眠模式
5 h, {! p+ F2 T2.4.3 端口的第2功能+ @ F' F% H6 f+ U1 Z7 I
2.5 时钟系统$ E: V8 U$ L- U+ U
2.5.1 时钟系统和时钟分配
' B3 P& A3 U R( W+ Z( Q/ |' d8 H2.5.2 时钟源9 K9 K5 k2 X/ U7 y7 H, K7 e
2.5.3 外部晶振: y% W3 }) q2 l2 I6 Q- Y
2.5.4 外部低频晶振
2 _" N0 ~8 M- K% B5 E' _9 k4 x F2.5.5 外部RC振荡器
) f. E J8 z/ O9 R) X: [2.5.6 可校准的片内RC振荡器8 I+ ?, ?% J3 d$ z( y" F& [. D+ u
2.5.7 外部时钟源7 I) n) {! f1 h
2.5.8 定时器/计时器振荡器
9 P/ V ]5 p+ [2.5.9 系统时钟分频控制寄存器XDIV
1 c1 M3 H# B1 H4 ~3 O' a! o9 r( U2.6 定时器/计数器; D. q2 D: C3 V1 C
2.6.1 定时器/计数器预分频器( c( r3 [5 G: L+ }5 ^
2.6.2 8位定时器/计数器T/C0
+ { f6 ~9 G5 Z% B& m2.6.3 16位定时器/计数器+ ?9 W# j/ l+ i4 R5 }
2.6.4 8位定时器/计时器T/C25 F1 q) q; G1 }% U) m
2.6.5 输出比较调制器
; U1 d; {$ F: d- ~2.7 中断系统$ Y) U5 j9 [" f) d2 \$ R; a! Y2 \ \
2.7.1 复位和中断向量表的移动
6 V. W8 t! y5 R- u7 a$ K2.7.2 在应用区和Boot区之间移动中断5 y0 }) l. y8 l9 i* e! o0 z# j+ V
2.8 同步串行通信SPI
1 B6 H2 J/ M/ A6 ?% @2.8.1 SPI接口控制与数据传输过程" U% H- g- f% H8 a, M" a
2.8.2 与SPI接口相关的寄存器
% k5 A" B, t1 e; x# G8 q) I2.9 通用同步和异步串行接收器和转发器( b& p' C) V( I$ x0 T# I6 W
2.9.1 概述" c; N+ F! Y' w8 ]
2.9.2 串行时钟发生/ R# O3 F5 W+ @5 ]+ x7 ]
2.9.3 数据帧格式% A/ h8 v+ C- b; @' L
2.9.4 USART的初始化
& Y: w* _& T3 P1 K7 @2 B2.9.5 发送数据
6 @' l- f: l3 a2 w! ~) y& e! b7 ?2.9.6 数据接收' R* a4 A1 G3 b
2.9.7 异步串行数据的硬件扫描检测和接收时序0 D2 P) s' x8 a" k2 o6 \; X
2.9.8 多处理器通信模式& i4 w9 ?7 m* j3 A0 Z# o, Y( O* b" D
2.9.9 USART寄存器
- ]( s6 E! g; F5 m6 c* Z' C2.9.10 设置波特率与偏差. R0 h3 g5 T+ y/ q+ w& B1 J
2.10 TWI总线接口% M4 h& X1 V* q& T
2.10.1 两线串行接口总线! a6 ^' H3 }8 `: s3 S" p; `
2.10.2 TWI模块
}0 B5 z/ s/ C1 e2.10.3 TWI 寄存器6 T; Q& f4 p, H3 e. {3 k3 p* H9 v
2.10.4 使用TWI总线) B5 {# a3 E( R* u) E
2.10.5 多主机系统和仲裁; M+ c" n2 d! ~- G$ ~9 t
2.11 模拟比较器
% |- Z8 N; w/ l1 Y) r6 y6 p2.12 模/数转换器ADC接口! H; U( @1 m! E& `5 n
2.12.1 特点' Q- d! h+ N( A( p
2.12.2 操作过程8 m9 b R$ U5 N E/ C* p1 Y, s8 H
2.12.3 启动ADC转换
. D4 L0 t5 h5 R( b. A I! \( F2.12.4 预分频和转换时序 W3 b" K0 N* @" w0 U8 A
2.12.5 差分增益通道9 }/ c6 s4 i |$ N2 Y
2.12.6 输入通道和基准电源的选择$ i6 O1 o* l" B
2.12.7 ADC噪声抑制器
- o, `3 y, A% E2 \8 Y2.12.8 ADC 转换结果
( w# s) z/ Z8 T! g2.12.9 有关的I/O寄存器( t) Z: { Q K! n. g
2.13 电源管理和休眠模式
3 j% P) K8 M. I1 ^2.13.1 MCU 控制寄存器——MCUCR
' b( e, O# C3 }1 e* h+ s% P( k* Z0 Z2 \2.13.2 功耗最小化
3 A. d9 {% x: h/ J- v5 u0 f2.14 调试端口
6 G8 [ H" w( }2 H" H4 h# L2.14.1 JTAG接口
0 v r' p# s6 w) W2.14.2 JTAG在线仿真调试' `; V |* d1 {
2.14.3 JTAG程序下载功能2 h0 s, d& J |0 v
2.14.4 JTAG边界扫描
0 k2 ~$ N4 x" p* d9 R2.14.5 ATmega128 边界扫描次序5 U; w" O' Y7 z* a3 |, U* t
2.15 系统复位与看门狗) u9 o y) _1 D% ~8 K# L' [1 z+ I) R
2.15.1 复位源. F/ O$ q N7 u$ \
2.15.2 MCU控制和状态寄存器——MCUCSR& c7 J6 {4 T( A! x
2.15.3 片内基准电压
% W3 U" C+ U2 N1 z: Y: s2.15.4 看门狗定时器1 {2 y" j6 K0 x- S; G6 o& v
2.16 M103模式
8 ?9 |# L1 i" T! p2.16.1 ATmega103与ATmega128的兼容性
2 N; T# D$ \8 E U( d# W% Z2.16.2 ATmega103兼容模式 K0 Q! x' U, _
2.17 熔丝位
! {* n- q$ M+ Z( L' X" D$ L2.18 引导加载及自编程
! C9 n3 w, ]2 A6 C: |+ J9 o2.18.1 引导加载的过程
! a' X x% H, P8 t" I* Z2.18.2 相关I/O寄存器
: Q6 A/ ] X, L6 h" |2.18.3 Flash的自编程
! Y9 h+ c& h1 b& m3 J+ a2.18.4 一个简单的引导程序汇编代码 V/ q' A) x. _% T
2.19 数据存储器读/写访问
( _& j# M$ V9 f1 x2.19.1 EEPROM读/写访问
* P( p, w' _5 d, q. {2.19.2 寄存器描述
" e) \; Z0 O# Z( w' s+ y8 [
' p, D& c, c! H/ _" u7 P第3章 指令系统* H; D9 P! u1 Z0 h
3.1 概述" }! ]4 a% F+ K
3.1.1 指令表
2 [8 S H$ @7 G, L! _3.1.2 指令中使用的符号) Q# M% Z! x; F% z, f- K' T7 k& `
3.1.3 寻址方式和寻址空间
/ r/ d6 q R4 ?; a+ k$ U0 c3.2 算术和逻辑指令1 ^, _9 ~9 {' X U3 w" S
3.2.1 加法指令) \& Z. Z4 x. \0 `
3.2.2 减法指令; \6 X+ u3 J' A( G+ f! V
3.2.3 取反码指令
0 Y% \! C1 y. B7 `% d) P3.2.4 取补指令9 I% M3 ?+ v' C, h
3.2.5 比较指令
4 ?8 Y9 M/ C. H3.2.6 逻辑“与”指令$ x1 q6 W ~7 u
3.2.7 逻辑“或”指令
/ o9 v( t0 P0 b# A9 O0 E3.2.8 逻辑“异或”指令$ I% @$ _" P$ f! @3 B9 F* W$ R
3.2.9 乘法指令- ` S& E# a7 Y" W( n
3.3 跳转指令: h% k5 Y9 N% Z: Z& W$ @9 S V
3.3.1 无条件跳转指令
0 d& N& f; O5 f0 L3.3.2 条件跳转指令/ `7 N. e5 m+ d0 d; O9 g
3.3.3 测试条件符合跳行跳转指令
9 N1 ]( P+ e7 N9 V$ P- m" c6 ]3.3.4 子程序调用和返回指令
5 M6 ~5 B- O4 ?, y! U3.4 数据传送指令1 w$ Q$ _7 ~7 }5 L3 n- @4 J, u4 X8 \
3.4.1 直接数据传送指令
" y6 W0 o- o; k( L$ F3.4.2 间接数据传送指令
* p' L: g7 f0 B4 x, g8 C8 r3.4.3 从程序存储器直接取数据指令
+ o. x* l" A6 O- U9 Y3 m3.4.4 写程序存储器指令
5 M: a! H8 Y6 n1 M, ~ h: J3.4.5 I/O口数据传送7 w: W5 s: ?5 x Y1 T4 g- t- O
3.4.6 堆栈操作指令6 r! n3 W# F) m/ l
3.5 位指令和位测试指令4 F( Y: T7 G# o3 Q& k
3.5.1 带进位逻辑操作指令8 k8 E6 c+ [' ~, p# }+ a; Y
3.5.2 位变量传送指令
7 s5 e$ i' e: _2 g: @$ o3.5.3 位变量修改指令) a' i; j) i2 g# u6 y
3.6 MCU控制指令
4 m' ]+ M3 H9 G; f3.7 AVR汇编语言系统4 R2 [0 X; N b, r0 U
3.7.1 汇编语言语句格式
, k0 ?, ~' x/ B! Y3.7.2 汇编器伪指令1 B2 x& u. x$ n0 |# P
3.7.3 表达式
% |3 t0 R- A8 p* x) R
* a% \% ]+ E! T& y7 W& T+ {8 m8 `第4章 AVR单片机开发工具8 k U' C9 e. r' z0 S: x! A
4.1 AVR Studio集成开发环境
2 ?4 }7 V4 w1 ?7 }4.1.1 汇编程序编译器AVR Assembler/ ?# t; S4 L8 V1 g" f! X! ~# X0 }
4.1.2 仿真调试
& K' P9 ?5 T5 V9 X. b" C' O0 ~4.1.3 程序下载
* i$ b7 c5 ^/ |$ a9 d% o' H! b S4.2 ICCAVR集成开发环境
( S1 A4 A8 q- ?0 T- h$ c) @- f1 s4.2.1 安装ICCAVR编译器0 e# H. o: W: E" w8 N" s. D
4.2.2 ICCAVR介绍
5 O+ G8 L _& g. z- Z0 W4.2.3 ICCAVR导游
/ F+ T7 K2 r- |% ]9 b( G8 M! R: i6 w4.2.4 C库函数与启动文件6 `5 _9 W9 p+ E6 C
4.2.5 访问AVR硬件的编程
/ L: u1 k6 c; W) t# [4.3 其他主流AVR单片机开发环境
" s1 l M) `9 M0 b; \4.3.1 GCCAVR开发环境2 ]0 h; k% E4 g; E& m
4.3.2 CodeVision AVR集成开发环境
1 L, ~$ ^) _; [1 [, [7 o4.3.3 IAR集成开发环境
& M, t8 C- N/ H/ m6 N) O% o# N8 R v1 _% w8 Q0 X" \* N+ p( j t
第5章 ICCAVR的C语言基础
/ K7 M } S% }5 Z* ~" K5.1 C语言概述. }2 b2 ^/ U% S% C
5.1.1 发展过程
' ?7 R# }7 T& M+ E7 V: r5.1.2 特点1 b: k% }! U# H2 c8 M% f4 b
5.1.3 C源程序的结构特点
. Y3 V/ Y$ t. v, P$ M$ N! o: U+ _5.1.4 字符集 w; ?5 S' N5 y
5.1.5 C语言词汇 ?# ?2 F; P8 _) f7 X' \2 O
5.2 C语言基础) b* \; I- D7 h% V" A
5.2.1 数据类型
( ?; P1 G; k' ]' {/ `6 p% f8 Y' n5.2.2 算术运算符和算术表达式
0 w1 ?5 j7 F# g% N/ I) t5.2.3 关系运算符和表达式
7 m/ i; b. B6 _4 W5.2.4 逻辑运算符和表达式& v+ S0 D3 |- }! _: m
5.3 控制语句
. t/ b' |! U+ h) U5.3.1 if语句
' @) K3 E8 H v% k- p$ u5.3.2 条件运算符和条件表达式
6 c) W6 r2 r4 }% ]5.3.3 switch语句$ D- t7 p a# c4 J( v- P* Y5 X* v4 }$ O
5.3.4 goto语句和goto语句构成循环
! h5 j+ d* R3 {( a2 {! I7 c5.3.5 while语句& l. f6 R0 j! ^7 l; `3 I
5.3.6 dowhile语句0 p& C" r0 A j2 Z( P L
5.3.7 for语句4 z; u4 N+ T- b5 ?$ f: t& s+ C
5.3.8 循环的嵌套和几种循环的比较
' W- }' }$ V9 m/ b( V$ h5.3.9 break和continue语句
A" y/ n# g% p: a" B( a5.4 数组% n/ ~" j: Z2 \& B
5.4.1 一维数组的定义和引用
8 w( q5 |& s- b: h$ ?( G* G5.4.2 二维数组的定义和引用
4 ?% F9 i& Q9 s! }& @ y% P6 C5.4.3 字符数组9 v- K) l% e+ }9 ?% E. c
5.5 函数9 @2 |+ {2 ^, [
5.5.1 概述
4 _: V0 C5 Q6 H2 D/ b5.5.2 函数定义的一般形式; x' d8 x" _ E: I& g% C
5.5.3 函数的参数和函数的值
4 J/ }4 U3 U* F' X5.5.4 函数的调用3 f6 j% \2 t0 O0 u
5.5.5 函数的嵌套调用
, o' \, A3 Y! v3 A i5.5.6 函数的递归调用. t% w( e/ R6 ]/ w
5.5.7 数组作为函数参数" ^1 ~/ h& ?- a$ B" ]3 K6 j
5.5.8 局部变量和全局变量$ G# o% W7 Y/ q
5.5.9 变量的存储类别5 B( M1 u$ |" C: X# r% O
5.5.10 中断服务函数
1 w( W) [; N/ E5.6 指 针% H/ h! x& h) | c, H
5.6.1 地址指针的基本概念" A3 A$ r$ T* H: \0 y. q
5.6.2 变量的指针和指向变量的指针变量+ O! l$ y5 ]1 \
5.6.3 数组指针和指向数组的指针变量- I( v( V+ u4 ]4 U# X
5.6.4 字符串的指针指向字符串的指针变量3 }$ z: i% F% @ B9 S, L. [
5.6.5 函数指针变量
/ i d% b* O/ F* S5.6.6 指针数组和指向指针的指针
$ h! ~) M6 W% n' D) M: G$ m6 ~5.6.7 有关指针的数据类型和指针运算的小结
0 p* Q. d) y* r# q$ G- h4 y* d8 u5 l- u5.7 结构体与共用体4 M& q' {1 T# a, B2 B; X
5.7.1 定义结构的一般形式8 u- ?( @1 b4 {/ F
5.7.2 结构类型变量的说明2 E `3 e) c7 P& w: {& z# R, W
5.7.3 结构变量成员的表示方法
' `$ r" t# |$ D! o9 X5.7.4 结构变量的初始化
) F! J/ G8 s" x7 b4 q5.7.5 结构数组的定义
( A1 j3 V' \; h& l5 N5.7.6 结构指针变量的说明和使用
. u" s% J% | e; j# ~5.7.7 共用体7 I$ F5 `0 m* y
5.7.8 枚举类型1 z2 A4 L; n: ^0 d7 c5 T
5.7.9 类型定义符typedef
8 G! c( ~; o/ l: o9 q( Q5.8 位运算
5 ^% t& w" h- z+ s9 k7 r8 l7 Y3 W5.8.1 位运算符
9 R4 C; j" v3 y2 c0 }$ g9 T5.8.2 位域
& w% n. p# U' w9 S y6 m1 c5.9 编译预处理# T# w0 ^" e ?. H
5.9.1 概述
i; o x$ P) d8 W% d1 V3 p" q3 i5.9.2 宏定义/ b0 J2 f( C9 U) w* z$ Q1 E
5.9.3 文件包含1 F8 _7 d g; b& W1 S* f6 D: z
5.9.4 条件编译
$ Q; }& x$ T5 t/ m5 v; g5.10 ICCAVR附注与扩充
0 ~! D7 T0 ~" ~
1 V W/ ]6 F( Y3 f- f% l: u3 x1 y第6章 ATmega128基础实例
: U1 k4 M: ]5 R2 Z6.1 发光二极管应用实验
" e! [ N9 c7 W: F/ w* R+ F. o$ B' h( J6.1.1 实例功能
5 o9 c2 K0 ^2 Q U6.1.2 器件和原理3 G R2 a4 I0 F! q! J. U) v7 z/ N
6.1.3 硬件电路
- N! d$ c5 q9 g9 c6 D# w+ I6.1.4 程序设计
/ y5 m' A/ B; {$ _! Z6.2 键盘电路应用实例
1 c( {% j( ^' a& a: Y* ] c8 n0 I6.2.1 实例功能
0 R0 b1 m8 j7 t; D% i6.2.2 器件和原理
$ V0 M+ [5 J. x3 X8 |0 T9 s6.2.3 程序设计9 _/ F% [. S5 R, r. C
6.3 LED数码管应用实例
- @ F" u6 S% o4 m0 q6.3.1 实例功能
/ [9 b, Y) S3 |" R6.3.2 器件和原理% P ]# |! s8 m6 Z" Z- U. i
6.3.3 硬件电路
5 p1 R) u, a: K3 v* u6.3.4 程序设计+ I- {# T3 H9 U1 O- a: M$ T4 L
6.4 片内EEPROM应用实例. Z% \5 W, D/ t* @3 U: e" K
6.4.1 实例功能
, @) }' E4 u) ~" C7 e; h) r6.4.2 ATmega128片内EEPROM内部寄存器
$ |7 a9 @; I8 ]7 M6.4.3 硬件原理图
o* m" ]. R: q% V1 X# ~6.5 PWM应用实例
2 U, b0 ?# r; ]% L7 y8 }% j6.5.1 脉冲宽度控制PWM的工作原理
! n q0 e0 j+ s# Y7 s H1 a6.5.2 ATmega128内部PWM模块
. d3 g1 k. t( ]6 `2 Z6.5.3 利用T/C0的PWM模块产生锯齿波( {+ C2 `7 s; {& z$ k2 F
6.6 ADC应用实例1 e6 _- Q' a' J; I: O' ]
6.6.1 实例功能
6 |/ b, u Y2 Z; \$ g5 R6.6.2 ATmega128片内ADC内部寄存器
B( ^ q/ ^; o' e& b6.6.3 硬件原理图
/ m& J, m( X+ C. X* f& D6.6.4 程序设计
, t# j1 Y, V+ M6 `9 z; X4 J& A6 L6.7 串行口应用实例
. ]3 b0 z) `7 R* R6.7.1 实例功能
) Z7 P6 e: D; Y( c6.7.2 硬件电路
# ?- H/ X' m) A2 L' v" ?6.7.3 程序设计
* z3 X' L2 P. c5 G4 R3 R' M6.8 定时器应用实例7 m, \1 H7 J9 A) K; x$ j2 g# T- ^
6.8.1 实例功能
" R* J7 V }$ w$ D1 ` Q6.8.2 硬件原理图
4 k7 M$ U) E3 v. B; b6.8.3 程序设计
- @2 E; Z P+ J( E- e. ^% k
" T" T; R) V5 i: j1 \& H第7章 ATmega128高级应用实例
' M/ _6 _; s6 n$ z7.1 LCD显示屏应用实例 ^ O" a( D+ U: x2 ?! W
7.1.1 液晶显示概述
/ i4 Y6 O6 e/ p7.1.2 1602字符型LCD概述" H# |6 o% Z2 \& l3 ]9 u( e
7.1.3 1602 LCD的软硬件设计
1 w( T( U$ j3 _4 J' W0 q* }7.1.4 128×64点阵型LCD应用实例* K# ~3 E; r/ @/ b
7.2 单总线数字温度传感器DS18B20应用实例
4 n/ `. n5 g$ j! ]: j) w7 l( z7.2.1 单总线技术概述 ~5 K5 a8 W8 Y- G! A# H
7.2.2 单总线温度传感器DS18B20概述
) W- _; H5 q: e7 `/ w/ G7.2.3 DS18B20的软/硬件设计1 n e2 _. j/ i; _
7.3 I2C总线软/硬件设计实例
3 {4 c% `( [: V6 t6 W7.3.1 I2C串行总线概述9 Z4 F% w) h( L/ A
7.3.2 I2C总线器件工作原理及时序; A1 F- F7 _. N8 P% K
7.3.3 AT24C系列存储器的软/硬件设计3 k f1 v6 s: e+ W# r; x" e
7.4 93CXX系列存储器应用实例
; m3 u7 v* B+ l' u+ e0 \* b7.4.1 SPI总线概述2 | ~( _8 z2 e4 _& F! J1 \4 @
7.4.2 93C46存储器的软/硬件设计
$ |( }, ~! Y4 k1 ?) D7.5 DS1302时钟芯片应用实例0 T# o2 b- S1 P. A: ?1 ~
7.5.1 实时时钟概述, \% R4 w, J1 d6 \% S, d5 e( Q. O
7.5.2 DS1302的软/硬件设计实例
3 I; N. R, i/ l7.6 红外遥控软件解码应用实例- d G, X; W' ?( s, ?: J* l
7.6.1 红外遥控概述
+ f6 v2 v& }. v1 k% k" J u7 A7.6.2 SAA3010红外接收的软件解码应用实例
: P( g6 Q; L& D& u. @, H% x7.7 步进电动机应用软/硬件设计实例3 e& g/ h _+ F; p" u. I& r
7.7.1 步进电动机概述
% v1 ~: @3 I) G( [) U y9 U# F$ n7.7.2 步进电动机的控制
7 ~* F; S* t" j: L6 s7.7.3 步进电动机的应用设计- Y: D" F+ W1 P! n* J
7.8 U盘存储器应用实例, Y+ ?3 j7 ?) X+ U) p
7.8.1 USB概述8 U7 y' p. m2 _2 A
7.8.2 USB总线接口芯片CH3754 u) p$ q6 v. P
7.8.3 U盘存储器的应用设计
: [% g- x9 n) p8 Q* o9 x7.9 GSM模块应用实例6 Z& O4 z& t2 i
7.9.1 GSM概述
6 J( P- a! w1 @1 L7.9.2 西门子TC35模块概述. D9 ]/ f: x% F, ]( ?
7.10 D/A软硬件设计实例
4 D, L3 k; X9 v ~% l9 c7.10.1 D/A转换原理及主要技术指标* b0 v* z* Q/ V2 w$ }( u. t( v( C! J
7.10.2 DAC0832芯片及与单片机的接口实例
5 t# e, D$ ^( L& d5 I1 i& B- J7.11 GPS模块应用实例
" ?3 J! o! g5 \0 w+ r7.11.1 GPS概述( K2 w+ }5 e, j+ @/ \
7.11.2 ublox LEA4S模块概述
6 f1 B+ B7 j/ l7.11.3 GPS的应用设计
8 I N2 w8 ] k; b3 i: H& F: R7.12 LED点阵显示屏的应用实例
% d9 T& u6 _ H) K8 V* K5 p4 p7.12.1 LED点阵的种类及结构
8 U1 Z: S F1 L$ o% P3 \6 |- r. k3 C4 q7.12.2 8×8单色点阵LED的工作原理' `" a) k& z* \) J/ O5 p
7.12.3 LED点阵显示屏的系统设计
% z+ b( D/ m4 b: s2 N4 w参考文献, z% \7 F0 a* C/ u4 y! H
6 z. y2 Q5 F' |0 A8 _; e) c1 ?* [( P1 V; i
- Y; y3 v5 {& L7 B
前言
8 F# }, f: M' e0 K 单片机又称单片微控制器,其实质是把一个微型计算机系统集成到一个芯片上。它的优点是体积小,重量轻,价格便宜;现在通用的单片机按位数可分为4位机、8位机、16位机和32位机等。ATmega128/128L是Atmel公司推出的一款采用低功耗CMOS工艺生产的新型AVR高档8位单片机,是基于RISC(Reduced Instruction Set Computer)架构的新型的单片机,芯片内部集成了128 KB F1ash的存储器和丰富的硬件接口电路,是AVR高档单片机MEGA系列中资源最丰富、性能最强大的单片机;再加上AVR单片机的系统内可编程特性,从而无须购买昂贵的仿真器和编程器也可进行单片机嵌入式系统的设计和开发,同时也为单片机的初学者提供了非常方便、简捷的学习开发环境。另外,掌握了ATmegal28单片机的性能和使用技巧,就可以很容易地了解和掌握其他AVR高档单片机。 0 b' g+ O8 k8 }7 W6 h
9 j, D$ _/ W; ?; c3 q; V) q. z4 z0 k' A9 ^0 I
精彩书摘
" E' A5 L& [! r( |$ } 第1章 单片机概述9 M. F3 ]% n' i: P6 k! S
单片机(Single Chip Microcomputer)也称为单片微电脑或单片微型计算机,国际上统称为微控制器(Microcontroller,MCU或μC),是一类内部集成了计算机核心技术的智能芯片。在单片机产生之前,完成一项稍复杂的功能往往需要一块大而复杂的模拟电路,要花费巨大的精力去调试、完善。随着科技的不断进步,现在只要一块几厘米见方的单片机,写入简单的程序,就可以使电路简单很多。相信读者在使用并掌握了单片机技术后,不管在今后开发或是工作上,一定会带来意想不到的惊喜。
8 j3 K4 {4 P2 i# G" w 1.1 单片机发展概述
3 {' L! H# z/ `4 F+ _/ e! | 单片机诞生于20世纪70年代末,经历了SCM、MCU、SoC这3大阶段:5 V; k* m' l5 B4 I
①SCM即单片微型计算机(Single Chip Microcomputer)阶段,主要是寻求最佳的单片形态嵌入式系统的最佳体系结构。“创新模式”获得成功,奠定了SCM与通用计算机完全不同的发展道路。在开创嵌入式系统独立发展道路上,Intel公司功不可没。$ X) S( B, S# e) g
②MCU即微控制器(Micro Controller Unit)阶段,主要的技术发展方向是:不断扩展满足嵌入式应用时,对象系统要求的各种外围电路与接口电路,突显其对象的智能化控制能力。它所涉及的领域都与对象系统相关,因此,发展MCU的重任不可避免地落在电气、电子技术厂家。从这一角度来看,Intel逐渐淡出MCU的发展也有其客观因素。在发展MCU方面,最著名的厂家当数前Philips公司半导体部(现称NXP公司)。前Philips公司以其在嵌入式应用方面的巨大优势,将MCS-51从单片微型计算机迅速发展到微控制器。因此,当我们回顾嵌入式系统发展道路时,不要忘记Intel和前Philips的历史功绩。
7 h- ]* O0 l* ^3 i+ ~: d$ R/ N ③单片机是嵌入式系统的独立发展之路,向MCU阶段发展的重要因素就是寻求应用系统在芯片上的最大化解决,因此,专用单片机的发展自然形成了SoC化趋势。随着微电子技术、IC设计、EDA工具的发展,基于SoC的单片机应用系统设计会有较大的发展。因此,对单片机的理解可以从单片微型计算机、单片微控制器延伸到单片应用系统 |
|