filter hid_HID调试工具
在做HID相關的產品是,我們經常要看看輸出是否正確,這時就需要一些小工具,這些小工具可以自己開發,也可以從網上找些已經做好的,下面介紹幾款工具,
1. PassMark KeyboardTest
這是Windows下的一款測試小工具,小巧簡單實用,是Windows下面測試的好助手,有一個月的免費試用期。
2. evtest
Linux下面的測試工具,可以使用 “apt-get install evtest”安裝。
需要su權限執行,可以選擇監聽那個“/dev/input/eventXX”。
(注意:直接使用“cat /dev/input/eventXX”會產生一堆亂碼)
3. showkey
Linux下面的測試工具,ubuntu好些不需要安裝可以直接使用,命令“showkey -a”顯示輸入的字符。
4. hcidump
這是一款Linux下的工具,可以使用命令“apt-get install bluez-hcidump”安裝,其功能和命令十分豐富,
打開help文檔,可以看到有如下功能,
# hcidump --help
Usage: hcidump [OPTION...] [filter]
-i, --device=hci_dev HCI device
-l, --snap-len=len Snap len (in bytes)
-p, --psm=psm Default PSM
-m, --manufacturer=compid Default manufacturer
-w, --save-dump=file Save dump to a file
-r, --read-dump=file Read dump from a file
-d, --wait-dump=host Wait on a host and send
-t, --ts Display time stamps
-a, --ascii Dump data in ascii
-x, --hex Dump data in hex
-X, --ext Dump data in hex and ascii
-R, --raw Dump raw data
-C, --cmtp=psm PSM for CMTP
-H, --hcrp=psm PSM for HCRP
-O, --obex=port Channel/PSM for OBEX
-P, --ppp=channel Channel for PPP
-S, --sap=channel Channel for SAP
-D, --pppdump=file Extract PPP traffic
-A, --audio=file Extract SCO audio data
-Y, --novendor No vendor commands or events
-4, --ipv4 Use IPv4 as transport
-6 --ipv6 Use IPv6 as transport
-h, --help Give this help list
-v, --version Give version information
--usage Give a short usage message舉例來說其強大的功能,Bluetooth HID輸入“12345”,選擇既輸出ASCII又輸出hex,結果如下,
# hcidump -X
HCI sniffer - Bluetooth packet analyzer ver 2.5
device: hci0 snap_len: 1500 filter: 0xffffffffffffffff
> ACL data: handle 21 flags 0x02 dlen 14
L2CAP(d): cid 0x0041 len 10 [psm 0]
0000: a1 01 00 00 1e 00 00 00 00 00 ..........
1> ACL data: handle 21 flags 0x02 dlen 14
L2CAP(d): cid 0x0041 len 10 [psm 0]
0000: a1 01 00 00 1f 00 00 00 00 00 ..........
> ACL data: handle 21 flags 0x02 dlen 14
L2CAP(d): cid 0x0041 len 10 [psm 0]
0000: a1 01 00 00 20 00 00 00 00 00 .... .....
23> ACL data: handle 21 flags 0x02 dlen 14
L2CAP(d): cid 0x0041 len 10 [psm 0]
0000: a1 01 00 00 21 00 00 00 00 00 ....!.....
> ACL data: handle 21 flags 0x02 dlen 14
L2CAP(d): cid 0x0041 len 10 [psm 0]
0000: a1 01 00 00 22 00 00 00 00 00 ....".....
45> ACL data: handle 21 flags 0x02 dlen 14
L2CAP(d): cid 0x0041 len 10 [psm 0]
0000: a1 01 00 00 00 00 00 00 00 00 ..........Bluetooth HID輸入“12345”,選擇輸出raw data,結果如下,
從結果上看,輸出6行,前5行是輸出“Press Key”事件(12345),最后一個是“release key”事件。
正常而言,一般是 按下(press)一個Key后,馬上松開(release);不過這會造成傳輸效率低下,所以這里是只傳輸按下(press) key的事件,最后才傳輸一個松開(release) key的事件(我們稱之為Fast HID)。不過,這在一些設備上會出現丟失字符的現象。所以需要修改Bluetooth firemare來設置一個選項Enable/Disable "Fast HID"。
# hcidump -R
HCI sniffer - Bluetooth packet analyzer ver 2.5
device: hci0 snap_len: 1500 filter: 0xffffffffffffffff
> 02 15 20 0E 00 0A 00 41 00 A1 01 00 00 1E 00 00 00 00 00
> 02 15 20 0E 00 0A 00 41 00 A1 01 00 00 1F 00 00 00 00 00
> 02 15 20 0E 00 0A 00 41 00 A1 01 00 00 20 00 00 00 00 00
> 02 15 20 0E 00 0A 00 41 00 A1 01 00 00 21 00 00 00 00 00
> 02 15 20 0E 00 0A 00 41 00 A1 01 00 00 22 00 00 00 00 00
> 02 15 20 0E 00 0A 00 41 00 A1 01 00 00 00 00 00 00 00 00
5.? 還有其他Linux節點與此有關,如/dev/hidrawX,沒有搞懂里面數據的具體含義;
另外,還有節點/dev/input/eventX,但是沒有細細研究。
$ sudo hexdump /dev/hidraw0
0000000 0001 2300 0000 0000 0100 0000 0026 0000
0000010 0000 0001 1f00 0000 0000 0100 0000 001e
0000020 0000 0000 0001 2400 0000 0000 0100 0000
0000030 0020 0000 0000 0001 2100 0000 0000 0100
0000040 0000 0026 0000 0000 0001 2700 0000 0000
0000050 0100 0000 0000 0000 0000 0001 2700 0000
0000060 0000 0100 0000 001e 0000 0000 0001 2500
0000070 0000 0000 0100 0000 0027 0000 0000 0001
總結
以上是生活随笔為你收集整理的filter hid_HID调试工具的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: asp上传文件到ftp服务器,ASP.N
- 下一篇: 软件测试-白盒测试:逻辑覆盖