mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-08-21 05:43:48 -07:00
Fix issue #844
This commit is contained in:
parent
54634b33b0
commit
9ea6665a24
3 changed files with 131 additions and 3 deletions
|
@ -3,7 +3,9 @@ All notable changes to this project will be documented in this file.
|
||||||
This project uses the changelog in accordance with [keepchangelog](http://keepachangelog.com/). Please use this to write notable changes, which is not the same as git commit log...
|
This project uses the changelog in accordance with [keepchangelog](http://keepachangelog.com/). Please use this to write notable changes, which is not the same as git commit log...
|
||||||
|
|
||||||
## [unreleased][unreleased]
|
## [unreleased][unreleased]
|
||||||
- Fix `hf 15 sim` - Added basic response to GET_SYSTEM_INFO and READBLOCK requests in order to fix iso15693 tag sim
|
- Fix issue #844 - `lf t55xx config` => recompute block0 (@cyberpunk-re)
|
||||||
|
- Add script hf_mf_unbrick_baduid.lua to revive mifare cards with bad BCC (@cyberpunk-re)
|
||||||
|
- Fix `hf 15 sim` - Added basic response to GET_SYSTEM_INFO and READBLOCK requests in order to fix iso15693 tag sim (@cyberpunk-re)
|
||||||
- Added `mf mfu sim t 7 n <numreads>` - MFU emulation now supports automatic exit after <num> blocks read. (@cyberpunk-re)
|
- Added `mf mfu sim t 7 n <numreads>` - MFU emulation now supports automatic exit after <num> blocks read. (@cyberpunk-re)
|
||||||
- Added T55xx Guide to assist in learning how to use the T55xx chip (@mwalker33)
|
- Added T55xx Guide to assist in learning how to use the T55xx chip (@mwalker33)
|
||||||
- Fix 'hf iclass wrbl' - dealing with tags in unsecured vs secured pagemode now is correct (@iceman1001)
|
- Fix 'hf iclass wrbl' - dealing with tags in unsecured vs secured pagemode now is correct (@iceman1001)
|
||||||
|
|
125
client/luascripts/hf_mf_unbrick_baduid.lua
Normal file
125
client/luascripts/hf_mf_unbrick_baduid.lua
Normal file
|
@ -0,0 +1,125 @@
|
||||||
|
local getopt = require('getopt')
|
||||||
|
local ansicolors = require('ansicolors')
|
||||||
|
|
||||||
|
copyright = ''
|
||||||
|
author = 'cyberpunk-re'
|
||||||
|
version = 'v1.0.0'
|
||||||
|
desc = [[
|
||||||
|
This script brings back to life a mifare UID modifiable card which has bad data written to block 0 or block 1, typically having a bad BCC (Block Check Character). It should workd on Mifare classic 1k/4k and Mifare Ultralight UID Modifiable and Direct write tags.
|
||||||
|
]]
|
||||||
|
example = [[
|
||||||
|
-- target a Ultralight based card
|
||||||
|
1. script run hf_mf_unbrick_baduid -u
|
||||||
|
|
||||||
|
]]
|
||||||
|
usage = [[
|
||||||
|
script run hf_mf_unbrick_baduid [-h] [-u]
|
||||||
|
]]
|
||||||
|
arguments = [[
|
||||||
|
-h this help
|
||||||
|
-u unbrick UID Modifiable/Direct Write Ultralight tag with 7 bytes UID.
|
||||||
|
]]
|
||||||
|
|
||||||
|
-- Helper functions borrowed from Iceman script hf_mf_magicrevive.lua
|
||||||
|
|
||||||
|
---
|
||||||
|
-- A debug printout-function
|
||||||
|
local function dbg(args)
|
||||||
|
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
|
||||||
|
---
|
||||||
|
-- This is only meant to be used when errors occur
|
||||||
|
local function oops(err)
|
||||||
|
print('ERROR:', err)
|
||||||
|
core.clearCommandBuffer()
|
||||||
|
return nil, err
|
||||||
|
end
|
||||||
|
---
|
||||||
|
-- Usage help
|
||||||
|
local function help()
|
||||||
|
print(copyright)
|
||||||
|
print(author)
|
||||||
|
print(version)
|
||||||
|
print(desc)
|
||||||
|
print(ansicolors.cyan..'Usage'..ansicolors.reset)
|
||||||
|
print(usage)
|
||||||
|
print(ansicolors.cyan..'Arguments'..ansicolors.reset)
|
||||||
|
print(arguments)
|
||||||
|
print(ansicolors.cyan..'Example usage'..ansicolors.reset)
|
||||||
|
print(example)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function cmdUltralight()
|
||||||
|
return {
|
||||||
|
[0] = 'hf 14a config b 2',
|
||||||
|
[1] = 'hf 14a raw -k -a 43',
|
||||||
|
[2] = 'hf 14a raw -c -a A2005380712A',
|
||||||
|
[3] = 'hf 14a raw -k -a -b 7 40',
|
||||||
|
[4] = 'hf 14a raw -k -a 43',
|
||||||
|
[5] = 'hf 14a raw -c -a A2010200D980',
|
||||||
|
[6] = 'hf 14a raw -k -a -b 7 40',
|
||||||
|
[7] = 'hf 14a raw -k -a 43',
|
||||||
|
[8] = 'hf 14a raw -c -a A2025B480000',
|
||||||
|
[9] = 'hf 14a config b 0',
|
||||||
|
}
|
||||||
|
end
|
||||||
|
local function cmdClassic()
|
||||||
|
return {
|
||||||
|
[0] = 'hf 14a raw -k -a -b 7 40',
|
||||||
|
[1] = 'hf 14a raw -k -a 43',
|
||||||
|
[2] = 'hf 14a raw -c -k -a A000',
|
||||||
|
[3] = 'hf 14a raw -c -k -a 01020304049802000000000000001001',
|
||||||
|
[4] = 'hf 14a raw -c -a 5000',
|
||||||
|
}
|
||||||
|
end
|
||||||
|
local function cmdRestoreST()
|
||||||
|
local arr = {}
|
||||||
|
for i = 0, 15 do
|
||||||
|
local blk = 3 + (4*i)
|
||||||
|
arr[i] = 'hf mf csetbl '..blk..' FFFFFFFFFFFFFF078000FFFFFFFFFFFF'
|
||||||
|
end
|
||||||
|
return arr
|
||||||
|
end
|
||||||
|
local function sendCmds( cmds )
|
||||||
|
for i = 0, #cmds do
|
||||||
|
if cmds[i] then
|
||||||
|
print ( cmds[i] )
|
||||||
|
core.console( cmds[i] )
|
||||||
|
core.clearCommandBuffer()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
---
|
||||||
|
-- The main entry point
|
||||||
|
function main(args)
|
||||||
|
|
||||||
|
local i
|
||||||
|
local cmds = {}
|
||||||
|
local isUltralight = false
|
||||||
|
|
||||||
|
-- Read the parameters
|
||||||
|
for o, a in getopt.getopt(args, 'hu') do
|
||||||
|
if o == 'h' then return help() end
|
||||||
|
if o == 'u' then isUltralight = true end
|
||||||
|
end
|
||||||
|
|
||||||
|
core.clearCommandBuffer()
|
||||||
|
|
||||||
|
if isUltralight then
|
||||||
|
sendCmds ( cmdUltralight() )
|
||||||
|
else
|
||||||
|
sendCmds( cmdClassic() )
|
||||||
|
sendCmds( cmdRestoreST() )
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
main(args)
|
|
@ -739,6 +739,7 @@ static int CmdT55xxSetConfig(const char *Cmd) {
|
||||||
for (; i < 9; i++) {
|
for (; i < 9; i++) {
|
||||||
if (rates[i] == bitRate) {
|
if (rates[i] == bitRate) {
|
||||||
config.bitrate = i;
|
config.bitrate = i;
|
||||||
|
config.block0 = ((config.block0 & ~(0x1c0000)) | (i << 18));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -789,6 +790,7 @@ static int CmdT55xxSetConfig(const char *Cmd) {
|
||||||
PrintAndLogEx(WARNING, "Unknown modulation '%s'", modulation);
|
PrintAndLogEx(WARNING, "Unknown modulation '%s'", modulation);
|
||||||
errors = true;
|
errors = true;
|
||||||
}
|
}
|
||||||
|
config.block0 = ((config.block0 & ~(0x1f0000)) | (config.modulation << 12));
|
||||||
break;
|
break;
|
||||||
case 'i':
|
case 'i':
|
||||||
if ((param_getchar(Cmd, cmdp + 1) == '0') || (param_getchar(Cmd, cmdp + 1) == '1')) {
|
if ((param_getchar(Cmd, cmdp + 1) == '0') || (param_getchar(Cmd, cmdp + 1) == '1')) {
|
||||||
|
@ -822,6 +824,7 @@ static int CmdT55xxSetConfig(const char *Cmd) {
|
||||||
config.ST = true;
|
config.ST = true;
|
||||||
cmdp += 1;
|
cmdp += 1;
|
||||||
}
|
}
|
||||||
|
config.block0 = ((config.block0 & ~(0x8)) | (config.ST << 3));
|
||||||
break;
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
errors = param_getdec(Cmd, cmdp + 1, &downlink_mode);
|
errors = param_getdec(Cmd, cmdp + 1, &downlink_mode);
|
||||||
|
@ -843,8 +846,6 @@ static int CmdT55xxSetConfig(const char *Cmd) {
|
||||||
|
|
||||||
if (gotconf) {
|
if (gotconf) {
|
||||||
SetConfigWithBlock0Ex(block0, config.offset, config.Q5);
|
SetConfigWithBlock0Ex(block0, config.offset, config.Q5);
|
||||||
} else {
|
|
||||||
config.block0 = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return printConfiguration(config);
|
return printConfiguration(config);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue