TA的每日心情 | 开心 2019-11-19 15:19 |
---|
签到天数: 1 天 [LV.1]初来乍到
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
PS/2接口协议解析及应用
% c) E) L4 i" p; A, o1 L- c1 PS/2接口标准的发展过程
% j9 e4 Z& M0 Z6 t3 G随着计算机工业的发展,作为计算机最常用输入设备的键盘也日新月异。1981年IBM推出了IBM PC/XT键盘及其接口标准。该标准定义了83键,采用5脚DIN连接器和简单的串行协议。实际上,第一套键盘扫描码集并没有主机到键盘的命令。为此,1984年IBM推出了IBM AT键盘接口标准。该标准定义了84~101键,采用5脚DIN连接器和双向串行通讯协议,此协议依照第二套键盘扫描码集设有8个主机到键盘的命令。到了1987年,IBM又推出了PS/2键盘接口标准。该标准仍旧定义了84~101键,但是采用6脚mini-DIN连接器,该连接器在封装上更小巧,仍然用双向串行通讯协议并且提供有可选择的第三套键盘扫描码集,同时支持17个主机到键盘的命令。现在,市面上的键盘都和PS/2及AT键盘兼容,只是功能不同而已。; W9 p* F* K& G) H/ m* Z+ _, @0 O' G+ e
: y/ Z; }0 Q8 d6 X. A
2 PS/2接口硬件
2 x, l& s; M0 q1 U2.1 物理连接器2 k) M# H2 N9 g v, e0 D2 i% R% G5 t
一般,具有五脚连接器的键盘称之为AT键盘,而具有六脚mini-DIN连接器的键盘则称之为PS/2键盘。其实这两种连接器都只有四个脚有意义。它们分别是Clock(时钟脚)、Data?数据脚?、+5V(电源脚)和Ground(电源地)。在PS/2键盘与PC机的物理连接上只要保证这四根线一一对应就可以了。PS/2键盘靠PC的PS/2端口提供+5V电源,另外两个脚Clock(时钟脚)和Data?数据脚?都是集电极开路的,所以必须接大阻值的上拉电阻。它们平时保持高电平,有输出时才被拉到低电平,之后自动上浮到高电平。现在比较常用的连接器如图1所示。
: p, W. k: p, \0 Y7 y0 A# r2.2 电气特性
; ]! ^+ y2 h; n, W3 H2 v; }PS/2通讯协议是一种双向同步串行通讯协议。通讯的两端通过Clock(时钟脚)同步,并通过Data(数据脚)交换数据。任何一方如果想抑制另外一方通讯时,只需要把Clock(时钟脚)拉到低电平。如果是PC机和PS/2键盘间的通讯,则PC机必须做主机,也就是说,PC机可以抑制PS/2键盘发送数据,而PS/2键盘则不会抑制PC机发送数据。一般两设备间传输数据的最大时钟频率是33kHz,大多数PS/2设备工作在10~20kHz。推荐值在15kHz左右,也就是说,Clock(时钟脚)高、低电平的持续时间都为40μs。每一数据帧包含11~12个位,具体含义如表1所列。
7 t$ \; |$ c. t4 d8 D# |' {0 G* i0 l; s8 R
表1 数据帧格式说明: f% l. Y* V$ L# O j1 B, g
1个起始位 总是逻辑09 w1 N; F. Y) k
8个数据位 (LSB)低位在前
4 j1 `3 Y8 o. q$ E# J* v: q1个奇偶校验位 奇校验
6 O+ G* v9 q' t) R) V# T" h' S1个停止位 总是逻辑1
" y- m2 y+ l9 d. i1个应答位 仅用在主机对设备的通讯中 s$ t6 d1 x" v+ S
表中,如果数据位中1的个数为偶数,校验位就为1;如果数据位中1的个数为奇数,校验位就为0;总之,数据位中1的个数加上校验位中1的个数总为奇数,因此总进行奇校验。
6 |/ J1 i/ P: V( f2.3 PS/2设备和PC机的通讯
* a7 g+ |9 Q2 G8 u) e# V0 YPS/2设备的Clock(时钟脚)和Data?数据脚?都是集电极开路的,平时都是高电平。当PS/2设备等待发送数据时,它首先检查Clock(时钟脚)以确认其是否为高电平。如果是低电平,则认为是PC机抑制了通讯,此时它必须缓冲需要发送的数据直到重新获得总线的控制权(一般PS/2键盘有16个字节的缓冲区,而PS/2鼠标只有一个缓冲区仅存储最后一个要发送的数据)。如果Clock(时钟脚)为高电平,PS/2设备便开始将数据发送到PC机。一般都是由PS/2设备产生时钟信号。发送时一般都是按照数据帧格式顺序发送。其中数据位在Clock(时钟脚)为高电平时准备好,在Clock(时钟脚)的下降沿被PC机读入。PS/2设备到PC机的通讯时序如图2所示。: L$ G6 d9 M- |+ [9 |
当时钟频率为15kHz时,从Clock(时钟脚)的上升沿到数据位转变时间至少要5μs。数据变化到Clock(时钟脚)下降沿的时间至少也有5 μs,但不能大于25 μs,这是由PS/2通讯协议的时序规定的。如果时钟频率是其它值,参数的内容应稍作调整。
; c: ^7 m9 o: q: c上述讨论中传输的数据是指对特定键盘的编码或者对特定命令的编码。一般采用第二套扫描码集所规定的码值来编码。其中键盘码分为通码(Make)和断码(Break)。通码是按键接通时所发送的编码,用两位十六进制数来表示,断码通常是按键断开时所发送的编码,用四位十六进制数来表示。9 v/ G7 z- A, B! d3 `
3 PS/2接口的嵌入式软件编程方法
) K; @! V2 a. S: b- l% \: lPS/2设备主要用于产生同步时钟信号和读写数据。
2 p/ F4 N+ M4 ]4 A5 }/ c. v3.1 PS/2向PC机发送一个字节
6 t I& {$ a. v, F/ _# E5 \9 J) ?6 h9 _) I% L2 s$ `& e' R0 y
从PS/2向PC机发送一个字节可按照下面的步骤进行:
0 x \( ~, Q" O& `3 e0 S$ n(1)检测时钟线电平,如果时钟线为低,则延时50μs;
+ m0 ?, {" |( o1 g* a. W(2)检测判断时钟信号是否为高,为高,则向下执行,为低,则转到(1);
# G S/ G( r/ J5 c- x(3)检测数据线是否为高,如果为高则继续执行,如果为低,则放弃发送(此时PC机在向PS/2设备发送数据,所以PS/2设备要转移到接收程序处接收数据);$ G& O) W+ P5 Z. g
(4)延时20μs(如果此时正在发送起始位,则应延时40μs);8 H: x; E4 V4 d( @0 @/ u' b5 g7 Q
(5)输出起始位(0)到数据线上。这里要注意的是:在送出每一位后都要检测时钟线,以确保PC机没有抑制PS/2设备,如果有则中止发送;
3 e! S3 G4 ?! `8 s( g: v(6)输出8个数据位到数据线上;0 u6 [' u/ v: s6 y- @
(7)输出校验位;8 M: ^% B7 P* t5 \) Z$ i/ Z/ {& ]
(8)输出停止位(1);
' w/ t, g+ P9 f& B$ S5 g5 ?2 O0 ~(9)延时30μs(如果在发送停止位时释放时钟信号则应延时50μs);5 X5 G5 N5 s0 C. w: g; R) Z
通过以下步骤可发送单个位:
# Z) b$ _ d4 W! y9 v. r5 y% n; E(1)准备数据位(将需要发送的数据位放到数据线上);
" ?7 U( N) a: D. G(2)延时20μs;8 s( r2 y6 K+ ]4 v: u9 O3 I8 u4 K2 S
(3)把时钟线拉低;5 n3 m0 q8 O$ a6 P3 ^
(4)延时40μs;
8 Y+ Q6 y0 ]7 |) i+ N6 i. M' t(5)释放时钟线;
& N; {9 S0 M& G1 S(6)延时20μs。
5 c% G4 k: d8 T, c2 t$ ~% q, D% }! s0 z3.2 PS/2设备从PC机接收一个字节
9 H: O7 F. I% u' q由于PS/2设备能提供串行同步时钟,因此,如果PC机发送数据,则PC机要先把时钟线和数据线置为请求发送的状态。PC机通过下拉时钟线大于100μs来抑制通讯,并且通过下拉数据线发出请求发送数据的信号,然后释放时钟。当PS/2设备检测到需要接收的数据时,它会产生时钟信号并记录下面8个数据位和一个停止位。主机此时在时钟线变为低时准备数据到数据线,并在时钟上升沿锁存数据。而PS/2设备则要配合PC机才能读到准确的数据。具体连接步骤如下:
# a+ E" x8 h( b [( C8 _7 u(1)等待时钟线为高电平。
% M& `% N, k: u* H9 [(2)判断数据线是否为低,为高则错误退出,否则继续执行。
' X8 t- B6 T4 w2 ^# ]' o(3)读地址线上的数据内容,共8个bit,每读完一个位,都应检测时钟线是否被PC机拉低,如果被拉低则要中止接收。
7 l: M4 \- ~1 k0 u(4)读地址线上的校验位内容,1个bit。' J& j9 B1 j7 d; O! n2 F
(5)读停止位。! p5 j6 K1 t6 B
(6)如果数据线上为0(即还是低电平),PS/2设备继续产生时钟,直到接收到1且产生出错信号为止(因为停止位是1,如果PS/2设备没有读到停止位,则表明此次传输出错)。
1 B6 g2 m0 o; }3 Q% H(7 输出应答位。
* s/ H5 e% x' Z(8) 检测奇偶校验位,如果校验失败,则产生错误信号以表明此次传输出现错误。
2 j, k/ w) a' ]' T9 \/ v(9)延时45 μs,以便PC机进行下一次传输。1 C: p; J' ?1 @8 W" e1 a+ I
读数据线的步骤如下:4 {0 [% h* I9 f! E3 X4 z- {: C. c! E
(1)延时20μs;+ e( x% @, p4 a! U$ i, _$ y& j
(2)把时钟线拉低?5 i& f1 c0 W2 z
(3)延时40μs?' Q7 H3 I/ I8 B Q" t
(4)释放时钟线?8 y0 j$ C8 G$ q! h$ j, a
(5)延时20μs?
J& }+ R8 b3 |; V(6)读数据线。( S' [7 Q& W/ N: y
下面的步骤可用于发出应答位;
& t" [7 }. d% W& V: g(1)延时15μs;
. H, v. p0 l0 _+ ~9 Q3 [(2)把数据线拉低;
3 k7 d1 A0 R, \8 j(3)延时5μs;$ s0 } [! S t$ T8 W
(4)把时钟线拉低;/ L0 ~7 \( ~$ y B" h8 v
(5)延时40μs;
- ~4 P( r, N. h& C) }0 e( f(6)释放时钟线;
) G' {3 Q0 @6 ~1 o! z(7)延时5μs;
2 x; P* w: |5 g" ]) [/ M(8)释放数据线。
7 Y! T9 ^' B4 `& }8 D( {& s3 C
4 用于工控机的双键盘设计# |/ A+ Q4 h9 e' W
工控机通常要接标准键盘,但是为了方便操作,常常需要外接一个专用键盘。此实例介绍了在工控PC机到PS/2总线上再接入一个自制专用键盘的应用方法。/ A& {7 s. [5 T& x
该设计应能保证两个键盘单独工作,而且相互不能影响。因此,不能直接把专用键盘和标准键盘一起接到工控PC的PS/2口。鉴于这种情况,本设计使用模拟开关CD4052并通过时分复用工控PC的PS/2口,来使在同一个时刻只有一个键盘有效,从而解决上述问题。其硬件原理图如图3所示。其中P2口和P1口用于键盘扫描电路(图中未画出),P0.0为数据端,P0.1为时钟端,P0.2为模拟开关选通端。由于专用键盘不需要接收工控PC机的命令,所以软件中并不需要写这部分相应的代码。
& j) k0 p( m2 X$ e1 N/ h通过软件可在专用键盘复位后把P0.2清0,以使模拟开关CD4052打开相应的通道。这时工控PC的标准键盘将开始工作。标准键盘可以完成工控PC刚启动时对外设检测的应答。复位后的专用键盘不停地扫描有没有按键,如果有键按下则识别按键,并且按照预先的设计进行编码,同时调用发送程序并通过PS/2口发送到工控PC。此时模拟开关关闭相应通道(将P0.2置1),专用键盘接入工控PC PS/2口的时钟线和数据线而工作,但标准键盘被模拟开关从PS/2的时钟线和数据线中断而不工作,这样,双键盘便可时分复用同一个工控PC机的PS/2口。相应的发送子程序如下:
% G$ f W" Q/ C#define DATA P00 用P0.0做数据线
0 v: v# H' D& |1 I. ~; v9 }#define CLK P01 用P0.1做时钟线
5 F8 U" X; J2 g$ [, ^/ S: V+ M#define INHIBIT P02 用P0.2做CD4052的INH端
c3 I b: }) z#define PORTR P1 用P1口做读入口
" Y0 L% j8 c: [* K3 B% G0 L* K; `#define PORTW P2 用P2口做写出口 可以实现64个自定义键
- v$ X ^* O. y- l9 Pvoid send(uchar x)/***function for send a char da-ta***/7 N, z/ y* ]* _ @) L2 j, M" b8 l5 c
{3 c3 t3 N% B4 u! _6 a4 d
uchar i,temp,char_temp;+ w6 ]7 l7 }* j3 B) j. ]' ?
bit flag_check=1;7 h: u$ x' n, c% r& d/ j& q( y
INHIBIT=1;//disable standard keyboard! W6 b6 {' \ e8 m6 L8 A
delay_ ms(3);% V! j* L' n6 ?2 a
temp=x;% @' |" P( r# a) j9 a
for(i=0;i<8;i++)//find the number of 1 in this uchar x is odd or not9 o! R& r& {( f2 F8 P" Z. K
{7 d0 X7 l" L- P8 C3 U6 W
char_temp=temp&0x01;
- b# D8 q3 g2 Pif(char_temp==0x01)
) m0 t4 x2 H/ _& C) G4 I{ R J6 d, ^7 K( i1 K
flag_check=!flag_check;3 ~# z: R2 F j* B3 d
}- ?) r3 d+ x9 C6 J. }- @
temp=temp>>1;- F8 t- A; m, L6 S& p
}
^" a% b7 I3 GCLK=1;//send 1 to P1 then read P12 h" e4 a" B+ L1 O% c9 x
while (!CLK) //if CLK is low wait+ d% J% A" ?; e5 a: U5 n/ Z
{
! T9 c; D; j! k& c: F3 Z. G;
- i/ J- e7 v, a# _8 U( L& ~0 M}
: X2 r2 E% D3 ^7 R5 {CLK=1;DATA=1;//send 1 to P1 then read P1
$ ^* O; J! V, Gif(CLK==1)
" p% v# h. \# d0 u% I7 K, j# D{
$ V9 k( B& `7 X9 ~1 _* ~) s) n9 \delay_us(30);//
9 H1 i$ e9 A# J7 k}: w. ?5 h4 j: F }% a, ^
if(CLK==1&&DATA==1)//send data( J% o# n' I# b0 Y# Q" z8 b
{
1 F/ h/ p r; ?3 j- Z! ODATA=0;//start bit 0
* K7 h; v- z$ w- _! ]5 H; N i. S8 \delay_us(10);0 D# f) ^" t# N1 R- K
CLK=0;
% S' o8 Z" ~8 W) ~# S$ \4 Odelay_us(5);//
v- \7 B' Y5 _* ^temp=x;
) R3 G2 O( o: ^: r5 Jfor(i=0;i<8;i++)//send 8 bits LSBfirst) j( |! z! r' d" C& e
{
& ?5 V1 |; b2 J! e$ G! ?: s% jCLK=1;
' W5 I; ~8 z" _' v! Wdelay_us(5);/ \! o8 C" j' k! G
char_temp=temp&0x01;
0 G' x* p0 A& T! [( N2 G8 ^# m5 {if(char_temp==0x01)% i8 n6 s# s- \% U% [
{
1 G" s3 e. n& }$ B) @. b: V# a) p( YDATA=1;
$ x7 K& ^5 Z, j! C. g: G: z0 B% t}
4 k* q0 X1 E( n7 u' Telse) T l1 [. K* V4 Y% s1 w/ t, ?
{
( H: y; G) C2 Y; gDATA=0;! ^6 ~+ [6 l& m2 g' }5 f
}* G* u. Q0 J/ M1 J% D# m! U
//DATA=(bit)(temp&0x01);( {# u% T; [# g5 \7 v5 L
//LSB9 |# K+ R! q- |, y# ~. s; k. E4 ~# Y
delay_us(10);
7 k" o O W r# ?, P& z6 `8 w0 q: vCLK=0;7 o1 f( c" ?& H6 G& c# B/ E
delay_us(5);/ M1 w9 w( n0 M+ O2 i
temp=temp>>1;
" Z6 \4 f t5 Z" W- v* |, ], w/ h} U% U: [; m- c$ j1 f( c
CLK=1;//send check bit
1 b( d0 _' h& {8 P* N* |7 Vdelay_us(5);?# U' R. V1 ~) ^
DATA=flag_check;3 L" a8 p! R( `# V* c; {0 ]* y( G% h. l
delay_us(10);?
2 O2 i% G( |8 a3 W( F hCLK=0;) f3 I# ]$ G% H* e6 f
delay_us(5)/ ?7 E9 [! l. h6 i/ t
CLK=1;//send stop bit( @9 c- }! I* H) _" w
delay_us(5);?9 i2 _7 p+ o/ @0 }$ M
DATA=1;( \/ a. h3 ~( c
delay us?10??
$ O/ w% F! E3 P: J/ wCLK=0?7 U* ]' ]1 A7 C. l. O( c
delay_us(5);?) r, _2 k( R' Q$ F
CLK=1;
$ z k- j2 w, r, Bdelay_us(30);? ?
/ d! ]4 M1 R8 G+ D( D& `4 iCLK=1;DATA=1;//send 1 to P1 then read P1
) }& K3 @9 a2 l7 X5 Tif(CLK==1&&DATA==0)
8 `% Z% p0 | ~, G1 {{9 F) g- ], B7 N7 R1 b* W) k3 b
return; //pc is sending data to mcu, go to
( f* D ^9 k9 u" ?. ?6 ^receiving function
/ x* T4 b' k. b; S}5 @$ P% U+ D* L, d
INHIBIT=0; //enable standard keyboard
5 x, ]; ?* p* F7 q}
6 c7 p: o; F& y1 r& V" }! i, _5 结论
, u% u* X9 h$ Q8 P2 c/ J2 _% aPS/2接口协议是现在大多数键盘、鼠标与PC机通讯的标准协议。其中鼠标对PC机的通讯更为简单,只是传输数据的内容不一样而已。充分理解PS/2接口协议,可以帮助设计者自主开发一些工控机上的专用键盘等外设,并能够按照用户的要求开发出专用的多功能键盘。该工控机的双键盘设计目前已被某工控公司所采纳,并已作为组件加入到产品当中。 |
& X4 R& S7 f+ s8 s |
|