In Android O and later, if an invalid pthread_t is passed to pthread_join,
it calls fatal().
https://github.com/aosp-mirror/platform_bionic/blob/
ed16b344e75f422fb36fbfd91fb30de339475880/libc/bionic/pthread_internal.cpp#L116-L128
This patch addresses it by:
1. Always memset(0) on USB_communications_thread at the end of
CloseProxmark.
2. On Bionic, only call pthread_join on USB_communications_thread if it is
not equal to 0.
void CloseProxmark(void) {
conn.run = false;
void CloseProxmark(void) {
conn.run = false;
+
+#ifdef __BIONIC__
+ // In Android O and later, if an invalid pthread_t is passed to pthread_join, it calls fatal().
+ // https://github.com/aosp-mirror/platform_bionic/blob/ed16b344e75f422fb36fbfd91fb30de339475880/libc/bionic/pthread_internal.cpp#L116-L128
+ //
+ // In Bionic libc, pthread_t is an integer.
+
+ if (USB_communication_thread != 0) {
+ pthread_join(USB_communication_thread, NULL);
+ }
+#else
+ // pthread_t is a struct on other libc, treat as an opaque memory reference
pthread_join(USB_communication_thread, NULL);
pthread_join(USB_communication_thread, NULL);
if (sp) {
uart_close(sp);
if (sp) {
uart_close(sp);
// Clean up our state
sp = NULL;
serial_port_name = NULL;
// Clean up our state
sp = NULL;
serial_port_name = NULL;
+ memset(&USB_communication_thread, 0, sizeof(pthread_t));