82 |
/* Add a new io request to the table containing pending io requests so it won't block rdesktop */ |
/* Add a new io request to the table containing pending io requests so it won't block rdesktop */ |
83 |
BOOL |
BOOL |
84 |
add_async_iorequest(uint32 device, uint32 file, uint32 id, uint32 major, uint32 length, |
add_async_iorequest(uint32 device, uint32 file, uint32 id, uint32 major, uint32 length, |
85 |
DEVICE_FNS * fns, uint32 total_timeout, uint32 interval_timeout, uint8 * buffer) |
DEVICE_FNS * fns, uint32 total_timeout, uint32 interval_timeout, uint8 * buffer, |
86 |
|
uint32 offset) |
87 |
{ |
{ |
88 |
struct async_iorequest *iorq; |
struct async_iorequest *iorq; |
89 |
|
|
122 |
iorq->timeout = total_timeout; |
iorq->timeout = total_timeout; |
123 |
iorq->itv_timeout = interval_timeout; |
iorq->itv_timeout = interval_timeout; |
124 |
iorq->buffer = buffer; |
iorq->buffer = buffer; |
125 |
|
iorq->offset = offset; |
126 |
return True; |
return True; |
127 |
} |
} |
128 |
|
|
414 |
serial_get_timeout(file, length, &total_timeout, &interval_timeout); |
serial_get_timeout(file, length, &total_timeout, &interval_timeout); |
415 |
if (add_async_iorequest |
if (add_async_iorequest |
416 |
(device, file, id, major, length, fns, total_timeout, interval_timeout, |
(device, file, id, major, length, fns, total_timeout, interval_timeout, |
417 |
pst_buf)) |
pst_buf, offset)) |
418 |
{ |
{ |
419 |
status = STATUS_PENDING; |
status = STATUS_PENDING; |
420 |
break; |
break; |
455 |
in_uint8a(s, pst_buf, length); |
in_uint8a(s, pst_buf, length); |
456 |
|
|
457 |
if (add_async_iorequest |
if (add_async_iorequest |
458 |
(device, file, id, major, length, fns, 0, 0, pst_buf)) |
(device, file, id, major, length, fns, 0, 0, pst_buf, offset)) |
459 |
{ |
{ |
460 |
status = STATUS_PENDING; |
status = STATUS_PENDING; |
461 |
break; |
break; |
796 |
/* never read larger chunks than 8k - chances are that it will block */ |
/* never read larger chunks than 8k - chances are that it will block */ |
797 |
status = fns->read(iorq->fd, |
status = fns->read(iorq->fd, |
798 |
iorq->buffer + iorq->partial_len, |
iorq->buffer + iorq->partial_len, |
799 |
req_size, 0, &result); |
req_size, iorq->offset, &result); |
800 |
iorq->partial_len += result; |
iorq->partial_len += result; |
801 |
|
iorq->offset += result; |
802 |
|
|
803 |
#if WITH_DEBUG_RDP5 |
#if WITH_DEBUG_RDP5 |
804 |
DEBUG(("RDPDR: %d bytes of data read\n", result)); |
DEBUG(("RDPDR: %d bytes of data read\n", result)); |
848 |
/* never write larger chunks than 8k - chances are that it will block */ |
/* never write larger chunks than 8k - chances are that it will block */ |
849 |
status = fns->write(iorq->fd, |
status = fns->write(iorq->fd, |
850 |
iorq->buffer + |
iorq->buffer + |
851 |
iorq->partial_len, req_size, 0, |
iorq->partial_len, req_size, |
852 |
&result); |
iorq->offset, &result); |
853 |
iorq->partial_len += result; |
iorq->partial_len += result; |
854 |
|
iorq->offset += result; |
855 |
#if WITH_DEBUG_RDP5 |
#if WITH_DEBUG_RDP5 |
856 |
DEBUG(("RDPDR: %d bytes of data written\n", |
DEBUG(("RDPDR: %d bytes of data written\n", |
857 |
result)); |
result)); |