2024年5月27日发(作者:)
51
入门成高手:
/2031/
PS2
鼠标控制
PS/2鼠标键盘协议
引脚定义如下所示
PS/2鼠标和键盘履行一种双向同步串行协议,换句话说,每次数据线上发送一
位数据并且每在时钟线上发一个脉冲就被读入,键盘/鼠标可以发送数据到主机而主
机也可以发送数据到设备,但主机总是在总线上有优先权。它可以在任何时候抑制
来自于键盘/鼠标的通讯,只要把时钟拉低即可。从键盘/鼠标发送到主机的数据在时
钟信号的下降沿,当时钟从高变到低的时候被读取,从主机发送到键盘/鼠标的数据
在上升沿,当时钟从低变到高的时候被读取。不管通讯的方向怎样,键盘/鼠标总是
产生时钟信号。如果主机要发送数据它。必须首先告诉设备开始产生时钟信号。最
大的时钟频率是33kHz而且大多数设备工作在1020kHz如果你要制作一个PS/2设备我
推荐你把频率控制在15kHz左右这就意味着时钟应该是高40微秒低40微秒
所有数据安排在字节中每个字节为一帧包含了11个位,这些位的含义如下
1个起始位总是为0
8个数据位低位在前
1个校验位奇校验
1个停止位总是为1
如果数据位中包含偶数个1,校验位就会置1;如果数据位中包含奇数个1,校验
位就会置0,数据位中1的个数加上校验位总为奇数,这就是奇校验,这是用来错误
检测。
当主机发送数据给键盘/鼠标时,设备回送一个握手信号来应答数据包已经收
到,这个位不会出现在设备发送数据到主机的过程中,设备到主机的通讯过程数据
和时钟线都是集电极开路结构,正常保持高电平当键盘或鼠标等待发送数据时它首
先检查时钟以确认它是否是高电平,如果不是,那么是主机抑制了通讯,设备必须
缓冲任何要发送的数据直到重新获得总线的控制权。键盘有16字节的缓冲区而鼠标
的缓冲区仅存储最后一个要发送的数据包,如果时钟线是高电平设备就可以开始传
送数据。
每位在时钟的下降沿被主机读入,时钟频率为10--16.7kHz。从时钟脉冲的上升沿
到一个数据转变的时间至少要有5微秒,数据变化到时钟脉冲的下降沿的时间至少要
有5微秒并且不大于25微秒,这个定时非常重要你应该严格遵循它!主机可以在第11
个时钟脉冲停止位之前把线拉低,导致设备放弃发送当前字节。这是非常罕见的。
在停止位发送后,设备在发送下个包前至少应该等待50毫秒,这将给主机时间,当
它处理接收到的字节时抑制发送,主机在收到每个包时通常自动做这个,在主机释
放抑制后设备至少应该在发送任何数据前等50毫秒
我推荐下面的过程发送一个单一字节从仿真键盘/鼠标到主机
1)等待Clock=high
2)延时50微秒
3)Clocks仍旧为high?
No—到第1步
4)Data=high
No—放弃(并且从主机读取字节)
51
入门成高手:
/2031/
5)延迟20毫秒(=40微秒tothetimeClockispulledlowinsendingthestartbit。)
6)输出起始位(0)在发送所有这些位的每一位后
7)输出8个数据位>测试时钟确认主机是否把它拉低了
8)输出校验位/这说明主机要放弃这次传送
9)输出停止位(1)
10)延迟30毫秒
按如下的过程发送单个位
1)设置/复位数据
2)延迟20微秒
3)把时钟拉低
4)延迟40微秒
5)释放时钟
6)延迟20微秒
主机到设备的通讯
被发送的包有点不同于主机到设备通讯过程,首先PS/2设备总是产生时钟信
号。如果主机要发送数据它必须首先把时钟和数据线设置为请求发送状态,如下:
通过下拉时钟线至少100微秒来抑制通讯通过下拉数据线来应用请求发送然后释
放时钟设备应该在不超过10毫秒的间隔内就要检查这个状态,当设备检测到这个状
态它将开始产生时钟信号并且时钟脉冲标记下输入八个数据位和一个停止位,主机
仅当时钟线为低的时候改变数据线,而数据在时钟脉冲的上升沿被锁存,这在发生
在设备到主机通讯的过程中正好相反,在停止位发送后设备要应答接收到的字节就
把数据线拉低并产生最后一个时钟脉冲,如果主机在第11个时钟脉冲后不释放数据
线,设备将继续产生时钟脉冲直到数据线被释放,然后设备将产生一个错误,主机
可以在第11个时钟脉冲应答位前中止一次传送,只要下拉时钟线至少100微秒,要使
得这个过程易于理解主机必须按下面的步骤发送数据到PS/2设备
1)把时钟线拉低至少100微秒
2)把数据线拉低
3)释放数据线
4)等待设备把时钟线拉低
5)设置/复位数据线发送第一个数据位
6)等待设备把时钟拉高
7)等待设备把时钟拉低
8)重复5-7步发送剩下的7个数据位和校验位
9)释放数据线
10)等待设备把数据线拉低
11)等待设备把时钟线拉低
12)等待设备释放数据线和时钟线
设备产生的信号注意应答位时序的改变,数据改变发生在时钟线为高的时候,
不同于其它11位是当它为低的时候,在主机最初把数据线拉低后,设备开始产生时钟
脉冲的时间必须步大于15ms,数据包被发送的时间必须不大于2ms,如果这两个条
件不满足,主机将产生一个错误,在包收到后主机为了处理数据立刻把时钟线拉低
来抑制通讯,如果主机发送的命令要求有一个回应,这个回应必须在主机释放时钟
线后20ms之内被收到,如果没有收到,则主机产生一个错误,在设备到主机通讯的情
况中时钟改变后的5微秒内不应该发生数据改变的情况,如果你要仿真一个鼠标或键
盘我推荐你按如下的过程从主机读入数据,在你的主程序中至少每10毫秒检测数据
线是否为低,如果数据线已被主机拉低则从主机读取一个字节
1)等待时钟线为高
2)数据线仍然为低吗
发布评论