Skip to content

Commit

Permalink
Added several disabling of the GIL so that other threads can run when…
Browse files Browse the repository at this point in the history
… the spi is I/O bound.
  • Loading branch information
billmccartney committed Jan 7, 2017
1 parent fcd44e6 commit 24b5127
Showing 1 changed file with 8 additions and 0 deletions.
8 changes: 8 additions & 0 deletions spidev_module.c
Original file line number Diff line number Diff line change
Expand Up @@ -400,7 +400,9 @@ SpiDev_xfer2(SpiDevObject *self, PyObject *args)
PyObject *obj;
PyObject *seq;
struct spi_ioc_transfer xfer;
Py_BEGIN_ALLOW_THREADS
memset(&xfer, 0, sizeof(xfer));
Py_END_ALLOW_THREADS
uint8_t *txbuf, *rxbuf;
char wrmsg_text[4096];

Expand All @@ -420,8 +422,10 @@ SpiDev_xfer2(SpiDevObject *self, PyObject *args)
return NULL;
}

Py_BEGIN_ALLOW_THREADS
txbuf = malloc(sizeof(__u8) * len);
rxbuf = malloc(sizeof(__u8) * len);
Py_END_ALLOW_THREADS

for (ii = 0; ii < len; ii++) {
PyObject *val = PySequence_Fast_GET_ITEM(seq, ii);
Expand All @@ -448,6 +452,7 @@ SpiDev_xfer2(SpiDevObject *self, PyObject *args)
seq = PySequence_List(obj);
}

Py_BEGIN_ALLOW_THREADS
xfer.tx_buf = (unsigned long)txbuf;
xfer.rx_buf = (unsigned long)rxbuf;
xfer.len = len;
Expand All @@ -456,6 +461,7 @@ SpiDev_xfer2(SpiDevObject *self, PyObject *args)
xfer.bits_per_word = bits_per_word ? bits_per_word : self->bits_per_word;

status = ioctl(self->fd, SPI_IOC_MESSAGE(1), &xfer);
Py_END_ALLOW_THREADS
if (status < 0) {
PyErr_SetFromErrno(PyExc_IOError);
free(txbuf);
Expand All @@ -474,8 +480,10 @@ SpiDev_xfer2(SpiDevObject *self, PyObject *args)
// Stop generating an extra CS except in mode CS_HOGH
if (self->mode & SPI_CS_HIGH) status = read(self->fd, &rxbuf[0], 0);

Py_BEGIN_ALLOW_THREADS
free(txbuf);
free(rxbuf);
Py_END_ALLOW_THREADS


if (PyTuple_Check(obj)) {
Expand Down

0 comments on commit 24b5127

Please sign in to comment.