2015-10-05 00:01:33 +08:00
|
|
|
-- The getopt-functionality is loaded from pm3/getopt.lua
|
|
|
|
-- Have a look there for further details
|
|
|
|
getopt = require('getopt')
|
|
|
|
bin = require('bin')
|
2020-04-05 16:05:14 +08:00
|
|
|
local ansicolors = require('ansicolors')
|
2018-02-21 03:16:30 +08:00
|
|
|
|
|
|
|
copyright = ''
|
2017-07-12 01:37:59 +08:00
|
|
|
author = "Martin Holst Swende \n @Marshmellow \n @iceman"
|
2020-04-05 16:05:14 +08:00
|
|
|
version = 'v1.0.2'
|
2015-10-05 00:01:33 +08:00
|
|
|
desc =[[
|
2015-12-15 16:34:55 +08:00
|
|
|
This script takes a dumpfile from 'hf mfu dump' and converts it to a format that can be used
|
2015-10-05 00:01:33 +08:00
|
|
|
by the emulator
|
2019-05-08 05:34:05 +08:00
|
|
|
]]
|
|
|
|
example = [[
|
2020-08-14 00:28:56 +08:00
|
|
|
script run hf_mfu_dumptoemulator -i dumpdata-foobar.bin
|
2019-05-08 05:34:05 +08:00
|
|
|
]]
|
|
|
|
usage = [[
|
2020-08-14 00:28:56 +08:00
|
|
|
script run hf_mfu_dumptoemulator [-i <file>] [-o <file>]
|
2020-04-05 16:05:14 +08:00
|
|
|
]]
|
|
|
|
arguments = [[
|
2019-03-09 17:34:43 +08:00
|
|
|
-h This help
|
|
|
|
-i <file> Specifies the dump-file (input). If omitted, 'dumpdata.bin' is used
|
|
|
|
-o <filename> Specifies the output file. If omitted, <uid>.eml is used.
|
2015-10-05 00:01:33 +08:00
|
|
|
|
|
|
|
]]
|
2019-05-08 05:34:05 +08:00
|
|
|
|
2017-12-03 22:24:24 +08:00
|
|
|
local DEBUG = false
|
|
|
|
|
2019-03-09 17:34:43 +08:00
|
|
|
---
|
2015-10-05 00:01:33 +08:00
|
|
|
-- A debug printout-function
|
2017-12-03 22:24:24 +08:00
|
|
|
local function dbg(args)
|
2019-03-09 17:34:43 +08:00
|
|
|
if not DEBUG then return end
|
|
|
|
if type(args) == 'table' then
|
|
|
|
local i = 1
|
|
|
|
while result[i] do
|
|
|
|
dbg(result[i])
|
|
|
|
i = i+1
|
|
|
|
end
|
|
|
|
else
|
|
|
|
print('###', args)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
---
|
2015-10-05 00:01:33 +08:00
|
|
|
-- This is only meant to be used when errors occur
|
2017-12-03 22:24:24 +08:00
|
|
|
local function oops(err)
|
2019-05-08 05:34:05 +08:00
|
|
|
print('ERROR:', err)
|
|
|
|
core.clearCommandBuffer()
|
|
|
|
return nil, err
|
2015-10-05 00:01:33 +08:00
|
|
|
end
|
2019-03-09 17:34:43 +08:00
|
|
|
---
|
2015-10-05 00:01:33 +08:00
|
|
|
-- Usage help
|
2019-05-08 05:34:05 +08:00
|
|
|
local function help()
|
|
|
|
print(copyright)
|
2019-03-09 17:34:43 +08:00
|
|
|
print(author)
|
2019-05-08 05:34:05 +08:00
|
|
|
print(version)
|
|
|
|
print(desc)
|
2020-04-05 16:05:14 +08:00
|
|
|
print(ansicolors.cyan..'Usage'..ansicolors.reset)
|
2019-05-08 05:34:05 +08:00
|
|
|
print(usage)
|
2020-04-05 16:05:14 +08:00
|
|
|
print(ansicolors.cyan..'Arguments'..ansicolors.reset)
|
|
|
|
print(arguments)
|
|
|
|
print(ansicolors.cyan..'Example usage'..ansicolors.reset)
|
|
|
|
print(example)
|
2015-10-05 00:01:33 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
local function convert_to_ascii(hexdata)
|
2019-03-09 17:34:43 +08:00
|
|
|
if string.len(hexdata) % 8 ~= 0 then
|
|
|
|
return oops(("Bad data, length should be a multiple of 8 (was %d)"):format(string.len(hexdata)))
|
|
|
|
end
|
|
|
|
|
|
|
|
local js,i = "[";
|
|
|
|
for i = 1, string.len(hexdata),8 do
|
|
|
|
js = js .."'" ..string.sub(hexdata,i,i+7).."',\n"
|
|
|
|
end
|
|
|
|
js = js .. "]"
|
|
|
|
return js
|
2015-10-05 00:01:33 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
local function readdump(infile)
|
2019-05-08 05:34:05 +08:00
|
|
|
t = infile:read('*all')
|
2019-03-09 17:34:43 +08:00
|
|
|
len = string.len(t)
|
2019-05-08 05:34:05 +08:00
|
|
|
local len,hex = bin.unpack(('H%d'):format(len),t)
|
2019-03-09 17:34:43 +08:00
|
|
|
return hex
|
2015-10-05 00:01:33 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
local function convert_to_emulform(hexdata)
|
2019-03-09 17:34:43 +08:00
|
|
|
if string.len(hexdata) % 8 ~= 0 then
|
2019-05-08 05:34:05 +08:00
|
|
|
return oops(('Bad data, length should be a multiple of 8 (was %d)'):format(string.len(hexdata)))
|
2019-03-09 17:34:43 +08:00
|
|
|
end
|
2019-05-08 05:34:05 +08:00
|
|
|
local ascii,i = '';
|
2019-03-09 17:34:43 +08:00
|
|
|
for i = 1, string.len(hexdata), 8 do
|
2019-05-08 05:34:05 +08:00
|
|
|
ascii = ascii..string.sub(hexdata, i, i+7)..'\n'
|
2019-03-09 17:34:43 +08:00
|
|
|
end
|
|
|
|
return string.sub(ascii, 1, -2)
|
2015-10-05 00:01:33 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
local function main(args)
|
|
|
|
|
2019-05-08 05:34:05 +08:00
|
|
|
local input = 'dumpdata.bin'
|
2019-03-09 17:34:43 +08:00
|
|
|
local output
|
|
|
|
|
|
|
|
for o, a in getopt.getopt(args, 'i:o:h') do
|
2019-05-08 05:34:05 +08:00
|
|
|
if o == 'h' then return help() end
|
|
|
|
if o == 'i' then input = a end
|
|
|
|
if o == 'o' then output = a end
|
2019-03-09 17:34:43 +08:00
|
|
|
end
|
|
|
|
-- Validate the parameters
|
|
|
|
|
2019-05-08 05:34:05 +08:00
|
|
|
local infile = io.open(input, 'rb')
|
2019-03-09 17:34:43 +08:00
|
|
|
if infile == nil then
|
2019-05-08 05:34:05 +08:00
|
|
|
return oops('Could not read file ', input)
|
2019-03-09 17:34:43 +08:00
|
|
|
end
|
|
|
|
local dumpdata = readdump(infile)
|
|
|
|
-- The hex-data is now in ascii-format,
|
|
|
|
|
|
|
|
-- But first, check the uid
|
|
|
|
-- lua uses start index and endindex, not count.
|
|
|
|
-- UID is 3three skip bcc0 then 4bytes.
|
|
|
|
-- 1 lua is one-index.
|
2019-04-21 08:18:00 +08:00
|
|
|
-- 1 + 112 (56*2) new dump format has version/signature/counter data here
|
|
|
|
-- 113,114,115,116,117,118 UID first three bytes
|
|
|
|
-- 119,120 bcc0
|
|
|
|
-- 121--- UID last four bytes
|
|
|
|
local uid = string.sub(dumpdata, 113, 113+5)..string.sub(dumpdata, 113+8, 113+8+7)
|
2019-05-08 05:34:05 +08:00
|
|
|
output = output or (uid .. '.eml')
|
2019-03-09 17:34:43 +08:00
|
|
|
|
|
|
|
-- Format some linebreaks
|
|
|
|
dumpdata = convert_to_emulform(dumpdata)
|
|
|
|
|
2019-05-08 05:34:05 +08:00
|
|
|
local outfile = io.open(output, 'w')
|
2019-03-09 17:34:43 +08:00
|
|
|
if outfile == nil then
|
2019-05-08 05:34:05 +08:00
|
|
|
return oops('Could not write to file ', output)
|
2019-03-09 17:34:43 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
outfile:write(dumpdata:lower())
|
|
|
|
io.close(outfile)
|
2019-05-08 05:34:05 +08:00
|
|
|
print(('Wrote an emulator-dump to the file %s'):format(output))
|
2015-10-05 00:01:33 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
--[[
|
2019-03-09 17:34:43 +08:00
|
|
|
In the future, we may implement so that scripts are invoked directly
|
2015-10-05 00:01:33 +08:00
|
|
|
into a 'main' function, instead of being executed blindly. For future
|
2019-03-09 17:34:43 +08:00
|
|
|
compatibility, I have done so, but I invoke my main from here.
|
2015-10-05 00:01:33 +08:00
|
|
|
--]]
|
|
|
|
main(args)
|