From 1c6490cddcd6b270781dd81ed2743fae623d2cfc Mon Sep 17 00:00:00 2001 From: iceman1001 Date: Wed, 18 Mar 2015 20:29:18 +0100 Subject: [PATCH] FIX: test_t55x7_psk.lua now correctly handles bitrate/modulation/clockrate combinations for PSK1. Uncomment lines in main to test PSK2, PSK3. --- client/lualibs/commands.lua | 2 +- client/scripts/test_t55x7_psk.lua | 68 +++++++++++++++++-------------- 2 files changed, 39 insertions(+), 31 deletions(-) diff --git a/client/lualibs/commands.lua b/client/lualibs/commands.lua index ef9b8f18..8b3a22fd 100644 --- a/client/lualibs/commands.lua +++ b/client/lualibs/commands.lua @@ -217,6 +217,6 @@ function Command:getBytes() local data = self.data local cmd = self.cmd local arg1, arg2, arg3 = self.arg1, self.arg2, self.arg3 - return bin.pack("LLLLH",cmd, arg1, arg2, arg3,data); + return bin.pack("LLLLH",cmd, arg1, arg2, arg3, data); end return _commands diff --git a/client/scripts/test_t55x7_psk.lua b/client/scripts/test_t55x7_psk.lua index 2909ff83..eb3da351 100644 --- a/client/scripts/test_t55x7_psk.lua +++ b/client/scripts/test_t55x7_psk.lua @@ -43,9 +43,6 @@ Arguments: local TIMEOUT = 2000 -- Shouldn't take longer than 2 seconds local DEBUG = true -- the debug flag ---BLOCK 0 = 00088040 PSK -local config1 = '0014' -local config2 = '40' -- local procedurecmds = { -- [1] = '%s%s%s%s', @@ -57,8 +54,15 @@ local config2 = '40' -- [6] = 'data pskindalademod', -- } +-- --BLOCK 0 = 00 08 80 40 PSK + -- ----------- + -- 08------- bitrate + -- 8----- modulation PSK1 + -- 0---- PSK ClockRate + -- 40 max 2 blocks + local procedurecmds = { - [1] = '%s%s%s%s', + [1] = '00%02X%X%X40', [2] = 'lf t55xx detect', --[3] = '', [3] = 'lf t55xx info', @@ -102,31 +106,36 @@ function ExitMsg(msg) end function test(modulation) - local y - for y = 0, 8, 4 do - for _ = 1, #procedurecmds do - local cmd = procedurecmds[_] - - if #cmd == 0 then - - elseif _ == 1 then - - dbg("Writing to T55x7 TAG") - - local config = cmd:format( config1, modulation , y, config2) - dbg(('lf t55xx write 0 %s'):format(config)) + local bitrate + local clockrate + for bitrate = 0x0, 0x1d, 0x4 do + + for clockrate = 0,8,4 do + + for _ = 1, #procedurecmds do + local cmd = procedurecmds[_] + + if #cmd == 0 then - config = tonumber(config,16) - local writecommand = Command:new{cmd = cmds.CMD_T55XX_WRITE_BLOCK, arg1 = config ,arg2 = 0, arg3 = 0} - local err = core.SendCommand(writecommand:getBytes()) - if err then return oops(err) end - local response = core.WaitForResponseTimeout(cmds.CMD_ACK,TIMEOUT) - else - dbg(cmd) - core.console( cmd ) + elseif _ == 1 then + + dbg("Writing to T55x7 TAG") + + local config = cmd:format(bitrate, modulation, clockrate) + dbg(('lf t55xx write 0 %s'):format(config)) + + config = tonumber(config,16) + local writecommand = Command:new{cmd = cmds.CMD_T55XX_WRITE_BLOCK, arg1 = config ,arg2 = 0, arg3 = 0} + local err = core.SendCommand(writecommand:getBytes()) + if err then return oops(err) end + local response = core.WaitForResponseTimeout(cmds.CMD_ACK,TIMEOUT) + else + dbg(cmd) + core.console( cmd ) + end end + core.clearCommandBuffer() end - core.clearCommandBuffer() end print( string.rep('--',20) ) end @@ -143,10 +152,9 @@ local function main(args) core.clearCommandBuffer() - test(1) - test(2) - test(3) - test(8) + test(1) -- PSK1 + --test(2) -- PSK2 + --test(3) -- PSK3 print( string.rep('--',20) ) end -- 2.39.5