-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathr0_testDynInfo.lua
More file actions
85 lines (72 loc) · 2.63 KB
/
r0_testDynInfo.lua
File metadata and controls
85 lines (72 loc) · 2.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
-- coding:utf-8
-- File Name: r0_testDynInfo.lua
-- Author: kht
-- Created Time: 2017/5/26 11:01:21
function Initialize(bus_id, ctrl_id)
adapter.create_fifo(bus_id, ctrl_id)
end
function show_controller_dyninfo(ret_data)
if adapter.read_elem(ret_data, 0) ~= 0x05 then
return false
end
if adapter.read_elem(ret_data, 1) ~= 17 then
return false
end
data1 = adapter.read_elem(ret_data, 4)
data2 = adapter.read_elem(ret_data, 5)
data3 = adapter.read_elem(ret_data, 6)
data4 = adapter.read_elem(ret_data, 7)
data = data1 + data2 * 2 ^ 8 + data3 * 2 ^ 16 + data4 * 2 ^ 24
str = string.format("%08X",data)
data1 = adapter.read_elem(ret_data, 8)
data2 = adapter.read_elem(ret_data, 9)
data3 = adapter.read_elem(ret_data, 10)
data4 = adapter.read_elem(ret_data, 11)
data = data1 + data2 * 2 ^ 8 + data3 * 2 ^ 16 + data4 * 2 ^ 24
str = "TotalTime:"..string.format("0X%08X",data)..str
print(str)
data = adapter.read_elem(ret_data, 12)
str = string.format("ErrorCode:0x%02X", data)
print(str)
data = adapter.read_elem(ret_data, 13)
str = string.format("RemainedNccmdCount:%d", data)
print(str)
data1 = adapter.read_elem(ret_data, 14)
data2 = adapter.read_elem(ret_data, 15)
data = data1 + data2 * 2 ^ 8
str = string.format("ErrorCount:%d", data)
print(str)
return true
end
function print_controller_dyninfo(bus_id, ctrl_id)
adapter.clear_upfifo(bus_id, ctrl_id)
cmd_get_controller_dyninfo = {0x5, 0x4, 0x2, 0x0}
ret = adapter.write_downdata(bus_id, ctrl_id, cmd_get_controller_dyninfo)
if not ret then
return
end
--这里实际上get_tickcount返回的是64位数据,而l_ticktime是其低32位的
--形如a,b = get_tickcount(),a是低32位,b是高32位的
--这里实际隐藏了一个bug,在还剩100ms就要向高位进位时判断是不准确的。
--但是考虑概率比较小,在脚本中不处理这个bug
l_ticktime,h_ticktime = get_tickcount()
while true do
-- 这个函数会读端口,并把收到的数据包发到控制器的upfifo上去
adapter.read_updata(bus_id, ctrl_id)
-- 从upfifo中拿数据
return_data = adapter.read_upfifo(bus_id, ctrl_id)
if return_data ~= nil then
if show_controller_dyninfo(return_data) then
break
end
end
--等待200ms,超时则退出
now_l_ticktime, b = get_tickcount()
if now_l_ticktime - l_ticktime > 200 then
print("TimeOut")
break
end
end
end
Initialize(4, 0)
print_controller_dyninfo(4, 0)