forked from M-Labs/artiq
runtime/session: simplify buffer management
This commit is contained in:
parent
9b62e7e77b
commit
9fceae7515
@ -64,8 +64,6 @@ enum {
|
|||||||
void session_start(void)
|
void session_start(void)
|
||||||
{
|
{
|
||||||
buffer_in_index = 0;
|
buffer_in_index = 0;
|
||||||
buffer_out_index_data = 0;
|
|
||||||
buffer_out_index_mem = 0;
|
|
||||||
memset(&buffer_out[4], 0, 4);
|
memset(&buffer_out[4], 0, 4);
|
||||||
kloader_stop_kernel();
|
kloader_stop_kernel();
|
||||||
user_kernel_state = USER_KERNEL_NONE;
|
user_kernel_state = USER_KERNEL_NONE;
|
||||||
@ -437,8 +435,11 @@ void session_poll(void **data, int *len)
|
|||||||
l = get_out_packet_len();
|
l = get_out_packet_len();
|
||||||
}
|
}
|
||||||
|
|
||||||
*len = l - buffer_out_index_data;
|
if(l > 0) {
|
||||||
*data = &buffer_out[buffer_out_index_data];
|
*len = l - buffer_out_index_data;
|
||||||
|
*data = &buffer_out[buffer_out_index_data];
|
||||||
|
} else
|
||||||
|
*len = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void session_ack_data(int len)
|
void session_ack_data(int len)
|
||||||
@ -449,9 +450,6 @@ void session_ack_data(int len)
|
|||||||
void session_ack_mem(int len)
|
void session_ack_mem(int len)
|
||||||
{
|
{
|
||||||
buffer_out_index_mem += len;
|
buffer_out_index_mem += len;
|
||||||
if(buffer_out_index_mem >= get_out_packet_len()) {
|
if(buffer_out_index_mem >= get_out_packet_len())
|
||||||
memset(&buffer_out[4], 0, 4);
|
memset(&buffer_out[4], 0, 4);
|
||||||
buffer_out_index_data = 0;
|
|
||||||
buffer_out_index_mem = 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user