radare2/shlr/windbg/transport.c
GustavoLCR a484d2c6e9 Allow breaking for WinDbg ##debug
* Fix OOB read in windbg_reg_read
* Add locks to prevent collision
* Enable timeouts on the pipe backend
2019-11-25 18:04:16 +01:00

103 lines
1.8 KiB
C

// Copyright (c) 2014-2017, The Lemon Man, All rights reserved. LGPLv3
#include <stdio.h>
#include <r_util.h>
#include "transport.h"
extern io_backend_t iob_pipe;
static io_backend_t *io_backends[] = {
// #if __WINDOWS__
// #warning TODO: add proper IO backend for windows here
// #else
&iob_pipe,
// #endif
NULL,
};
static io_backend_t *sel_backend = &iob_pipe;
int iob_select(const char *name) {
io_backend_t *iob;
iob = io_backends[0];
if (!iob) {
return 0;
}
if (sel_backend && sel_backend->deinit) {
sel_backend->deinit ();
}
sel_backend = iob;
if (sel_backend->init) {
sel_backend->init ();
}
return 1;
}
void *iob_open(const char *path) {
if (!sel_backend) {
return NULL;
}
return sel_backend->open (path);
}
int iob_close(void *fp) {
if (!sel_backend) {
return E_NOIF;
}
return sel_backend->close (fp);
}
int iob_config(void *fp, void *cfg) {
if (!sel_backend) {
return E_NOIF;
}
return sel_backend->config (fp, cfg);
}
int iob_write(void *fp, const uint8_t *buf, const uint32_t buf_len) {
uint32_t done;
static RThreadLock *lock = NULL;
if (!lock) {
lock = r_th_lock_new (true);
}
if (!sel_backend) {
return E_NOIF;
}
r_th_lock_enter (lock);
for (done = 0; done < buf_len;) {
int ret = sel_backend->write (fp, buf + done, buf_len - done, 100);
if (ret < 1) {
break;
}
done += ret;
}
r_th_lock_leave (lock);
return done;
}
int iob_read(void *fp, uint8_t *buf, const uint32_t buf_len) {
uint32_t done;
static RThreadLock *lock = NULL;
if (!lock) {
lock = r_th_lock_new (true);
}
if (!sel_backend) {
return E_NOIF;
}
r_th_lock_enter (lock);
for (done = 0; done < buf_len;) {
int ret = sel_backend->read (fp, buf + done, buf_len - done, 100);
if (ret < 0) {
break;
}
done += ret;
}
r_th_lock_leave (lock);
return done;
}