mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-08-21 22:03:42 -07:00
Merge branch 'master' into master
Signed-off-by: Iceman <iceman@iuse.se>
This commit is contained in:
commit
80ac7972fd
5 changed files with 83 additions and 2 deletions
|
@ -3,6 +3,8 @@ 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...
|
||||
|
||||
## [unreleased][unreleased]
|
||||
- Changed the timeout of local TCP connections (@wh201906)
|
||||
- Finalized implementation of configcard generation for keyroll when cardhelper is not present (@Antiklesys)
|
||||
- Added documentation for compiling on iOS (@The-SamminAter)
|
||||
- Fixed `hf iclass wrbl` - pagemap bit map for secured is now handled better (@iceman1001)
|
||||
- Changed `hf iclass view/decrypt` to detect SIO lengths better and show if legacy credentials are encrypted (@nvx)
|
||||
|
@ -16,7 +18,6 @@ This project uses the changelog in accordance with [keepchangelog](http://keepac
|
|||
- Added `hf iclass creditepurse` command to allow crediting the epurse debit value (@nvx)
|
||||
- Modified `hf iclass configcard` to only support online mode (@Antiklesys)
|
||||
- Modified `hf iclass configcard` command to generate config cards without a cardhelper module by porting the contents of blocks 6 & 7 from nfc-iclass (@Antiklesys)
|
||||
- Finalized implementation of configcard generation for keyroll when cardhelper is not present (@Antiklesys)
|
||||
|
||||
## [Raccoon.4.17140][2023-09-09]
|
||||
- Changed text and adjust pm3_test case for mf_aes_brute (@doegox)
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
#!/bin/bash
|
||||
|
||||
gcc -o test test.c -I../../include -lpm3rrg_rdv4 -L../build -lpthread
|
||||
gcc -o test_grab test_grab.c -I../../include -lpm3rrg_rdv4 -L../build -lpthread
|
||||
|
|
3
client/experimental_lib/example_c/02run_test_grab.sh
Executable file
3
client/experimental_lib/example_c/02run_test_grab.sh
Executable file
|
@ -0,0 +1,3 @@
|
|||
#!/bin/bash
|
||||
|
||||
LD_LIBRARY_PATH=../build ./test_grab
|
67
client/experimental_lib/example_c/test_grab.c
Normal file
67
client/experimental_lib/example_c/test_grab.c
Normal file
|
@ -0,0 +1,67 @@
|
|||
#include "pm3.h"
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
|
||||
int pipefd[2];
|
||||
char buf[8196 + 1];
|
||||
size_t n;
|
||||
|
||||
if (pipe(pipefd) == -1) {
|
||||
exit(-1);
|
||||
}
|
||||
|
||||
int pid = fork();
|
||||
if (pid == -1) {
|
||||
perror("fork");
|
||||
exit(-1);
|
||||
}
|
||||
|
||||
// child
|
||||
if (pid == 0) {
|
||||
printf("[INFO] inside child\n");
|
||||
|
||||
// Redirect stdout to the write end of the pipe
|
||||
dup2(pipefd[1], STDOUT_FILENO);
|
||||
|
||||
close(pipefd[0]); // Child: close read end of the pipe
|
||||
close(pipefd[1]); // Close original write end
|
||||
|
||||
pm3 *p;
|
||||
p = pm3_open("/dev/ttyS9");
|
||||
//printf("Device: %s\n", pm3_name_get(p));
|
||||
|
||||
// Execute the command
|
||||
pm3_console(p, "hw status");
|
||||
pm3_close(p);
|
||||
_exit(-1);
|
||||
} else {
|
||||
|
||||
printf("[INFO] inside parent\n");
|
||||
// Parent: close write end of the pipe
|
||||
close(pipefd[1]);
|
||||
|
||||
// Read from the pipe
|
||||
while (1) {
|
||||
n = read(pipefd[0], buf, sizeof(buf));
|
||||
if (n == -1) {
|
||||
continue;
|
||||
}
|
||||
if (n == 0) {
|
||||
break;
|
||||
} else {
|
||||
// null termination
|
||||
buf[n] = 0;
|
||||
if (strstr(buf, "Unique ID") != NULL) {
|
||||
printf("%s", buf);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Close read end
|
||||
close(pipefd[0]);
|
||||
}
|
||||
}
|
|
@ -678,7 +678,16 @@ int TestProxmark(pm3_device_t *dev) {
|
|||
if (g_conn.send_via_fpc_usart) {
|
||||
PrintAndLogEx(INFO, "PM3 UART serial baudrate: " _YELLOW_("%u") "\n", g_conn.uart_speed);
|
||||
} else {
|
||||
int res = uart_reconfigure_timeouts(is_tcp_conn ? UART_TCP_CLIENT_RX_TIMEOUT_MS : UART_USB_CLIENT_RX_TIMEOUT_MS);
|
||||
int res;
|
||||
if (is_tcp_conn) {
|
||||
if (memcmp(g_conn.serial_port_name + 4, "localhost", 9) == 0 || memcmp(g_conn.serial_port_name + 4, "127.0.0.1", 9) == 0) {
|
||||
res = uart_reconfigure_timeouts(UART_USB_CLIENT_RX_TIMEOUT_MS * 2);
|
||||
} else {
|
||||
res = uart_reconfigure_timeouts(UART_TCP_CLIENT_RX_TIMEOUT_MS);
|
||||
}
|
||||
} else {
|
||||
res = uart_reconfigure_timeouts(UART_USB_CLIENT_RX_TIMEOUT_MS);
|
||||
}
|
||||
if (res != PM3_SUCCESS) {
|
||||
return res;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue