Skip to content

Commit

Permalink
Merge branch 'master' into master
Browse files Browse the repository at this point in the history
Signed-off-by: Iceman <[email protected]>
  • Loading branch information
iceman1001 authored Oct 14, 2023
2 parents 28c4f66 + 8f62e80 commit 80ac797
Show file tree
Hide file tree
Showing 5 changed files with 83 additions and 2 deletions.
3 changes: 2 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Expand All @@ -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)
Expand Down
1 change: 1 addition & 0 deletions client/experimental_lib/example_c/01make_test.sh
Original file line number Diff line number Diff line change
@@ -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 changes: 3 additions & 0 deletions client/experimental_lib/example_c/02run_test_grab.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
#!/bin/bash

LD_LIBRARY_PATH=../build ./test_grab
67 changes: 67 additions & 0 deletions client/experimental_lib/example_c/test_grab.c
Original file line number Diff line number Diff line change
@@ -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]);
}
}
11 changes: 10 additions & 1 deletion client/src/comms.c
Original file line number Diff line number Diff line change
Expand Up @@ -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;
}
Expand Down

0 comments on commit 80ac797

Please sign in to comment.