81740aa5 |
1 | local cmds = require('commands') |
2 | local getopt = require('getopt') |
3 | local bin = require('bin') |
4 | local utils = require('utils') |
81740aa5 |
5 | |
6 | example =[[ |
13d77ef9 |
7 | 1. script run test_t55x7_psk |
8 | 2. script run test_t55x7_psk -o |
81740aa5 |
9 | |
10 | ]] |
11 | author = "Iceman" |
13d77ef9 |
12 | usage = "script run test_t55x7_psk" |
81740aa5 |
13 | desc =[[ |
14 | This script will program a T55x7 TAG with the configuration: block 0x00 data 0x00088040 |
15 | The outlined procedure is as following: |
16 | |
17 | "lf t55xx write 0 00088040" |
18 | "lf read" |
19 | "data samples" |
20 | "data pskdet" |
21 | "data psknrz" |
22 | "data pskindala" |
23 | "data psknrzraw" |
24 | |
25 | Loop OUTER: |
26 | change the configuretion block 0 with: |
27 | -xxxx8xxx = PSK RF/2 with Manchester modulation |
28 | -xxxx1xxx = PSK RF/2 with PSK1 modulation (phase change when input changes) |
29 | -xxxx2xxx = PSK RF/2 with PSk2 modulation (phase change on bitclk if input high) |
30 | -xxxx3xxx = PSK RF/2 with PSk3 modulation (phase change on rising edge of input) |
31 | Loop INNER |
32 | for each outer configuration, also do |
33 | XXXXX0XX = PSK RF/2 |
34 | XXXXX4XX = PSK RF/4 |
35 | XXXXX8XX = PSK RF/8 |
36 | |
37 | In all 12 individual test for the PSK demod |
38 | |
39 | Arguments: |
40 | -h : this help |
81740aa5 |
41 | ]] |
42 | |
43 | local TIMEOUT = 2000 -- Shouldn't take longer than 2 seconds |
44 | local DEBUG = true -- the debug flag |
1fbf8956 |
45 | |
81740aa5 |
46 | |
13d77ef9 |
47 | -- local procedurecmds = { |
48 | -- [1] = '%s%s%s%s', |
49 | -- [2] = 'lf read', |
50 | -- --[3] = '', |
51 | -- [3] = 'data samples', |
52 | -- [4] = 'data pskdetectclock', |
53 | -- [5] = 'data psknrzrawdemod', |
54 | -- [6] = 'data pskindalademod', |
55 | -- } |
56 | |
57 | -- --BLOCK 0 = 00 08 80 40 PSK |
1fbf8956 |
58 | -- ----------- |
59 | -- 08------- bitrate |
60 | -- 8----- modulation PSK1 |
61 | -- 0---- PSK ClockRate |
62 | -- 40 max 2 blocks |
13d77ef9 |
63 | |
81740aa5 |
64 | local procedurecmds = { |
13d77ef9 |
65 | [1] = '00%02X%X%X40', |
66 | [2] = 'lf t55xx detect', |
81740aa5 |
67 | --[3] = '', |
13d77ef9 |
68 | [3] = 'lf t55xx info', |
81740aa5 |
69 | } |
81740aa5 |
70 | --- |
71 | -- A debug printout-function |
72 | function dbg(args) |
73 | if not DEBUG then |
74 | return |
75 | end |
76 | |
77 | if type(args) == "table" then |
78 | local i = 1 |
79 | while args[i] do |
80 | dbg(args[i]) |
81 | i = i+1 |
82 | end |
83 | else |
84 | print("###", args) |
85 | end |
86 | end |
87 | --- |
88 | -- This is only meant to be used when errors occur |
89 | function oops(err) |
90 | print("ERROR: ",err) |
91 | end |
92 | --- |
93 | -- Usage help |
94 | function help() |
95 | print(desc) |
96 | print("Example usage") |
97 | print(example) |
98 | end |
99 | -- |
100 | -- Exit message |
101 | function ExitMsg(msg) |
102 | print( string.rep('--',20) ) |
103 | print( string.rep('--',20) ) |
104 | print(msg) |
105 | print() |
106 | end |
107 | |
13d77ef9 |
108 | function test(modulation) |
109 | local bitrate |
110 | local clockrate |
aa77d2b1 |
111 | local block = "00" |
13d77ef9 |
112 | for bitrate = 0x0, 0x1d, 0x4 do |
113 | |
114 | for clockrate = 0,8,4 do |
13d77ef9 |
115 | |
1fbf8956 |
116 | for _ = 1, #procedurecmds do |
117 | local cmd = procedurecmds[_] |
81740aa5 |
118 | |
1fbf8956 |
119 | if #cmd == 0 then |
120 | |
121 | elseif _ == 1 then |
122 | |
123 | dbg("Writing to T55x7 TAG") |
124 | |
125 | local config = cmd:format(bitrate, modulation, clockrate) |
126 | dbg(('lf t55xx write 0 %s'):format(config)) |
127 | |
128 | config = tonumber(config,16) |
aa77d2b1 |
129 | local writecmd = Command:new{cmd = cmds.CMD_T55XX_WRITE_BLOCK,arg1 = config, arg2 = block, arg3 = "00", data = "00"} |
130 | local err = core.SendCommand(writecmd:getBytes()) |
1fbf8956 |
131 | if err then return oops(err) end |
132 | local response = core.WaitForResponseTimeout(cmds.CMD_ACK,TIMEOUT) |
133 | else |
134 | dbg(cmd) |
135 | core.console( cmd ) |
136 | end |
81740aa5 |
137 | end |
1fbf8956 |
138 | core.clearCommandBuffer() |
81740aa5 |
139 | end |
81740aa5 |
140 | end |
141 | print( string.rep('--',20) ) |
81740aa5 |
142 | end |
143 | |
144 | local function main(args) |
145 | |
146 | print( string.rep('--',20) ) |
147 | print( string.rep('--',20) ) |
148 | |
81740aa5 |
149 | -- Arguments for the script |
13d77ef9 |
150 | for o, arg in getopt.getopt(args, 'h') do |
81740aa5 |
151 | if o == "h" then return help() end |
81740aa5 |
152 | end |
153 | |
154 | core.clearCommandBuffer() |
155 | |
1fbf8956 |
156 | test(1) -- PSK1 |
157 | --test(2) -- PSK2 |
158 | --test(3) -- PSK3 |
81740aa5 |
159 | |
160 | print( string.rep('--',20) ) |
161 | end |
162 | main(args) |
1fbf8956 |
163 | |
164 | -- Where it iterates over |
165 | -- xxxx8xxx = PSK RF/2 with Manchester modulation |
166 | -- xxxx1xxx = PSK RF/2 with PSK1 modulation (phase change when input changes) |
167 | -- xxxx2xxx = PSK RF/2 with PSk2 modulation (phase change on bitclk if input high) |
168 | -- xxxx3xxx = PSK RF/2 with PSk3 modulation (phase change on rising edge of input) |
169 | |
170 | -- XXXXX0XX = PSK RF/2 |
171 | -- XXXXX4XX = PSK RF/4 |
172 | -- XXXXX8XX = PSK RF/8 |