int ul_cbuff_tail_release(ul_cbuff_t *buff, ul_cbuff_tail_info_t *tail_info);
int ul_cbuff_tail_next(ul_cbuff_t *buff, ul_cbuff_tail_info_t *tail_info);
int ul_cbuff_tail_state_update(ul_cbuff_t *buff, int release_result, ul_cbuff_loc_t loc, ul_cbuff_loc_t loc_next);
+int ul_cbuff_tail_detach_onestep(ul_cbuff_t *buff, ul_cbuff_tail_info_t *tail_info);
void ul_cbuff_data_do_wrap(ul_cbuff_data_info_t *data_info);
int ul_cbuff_data_at_once(ul_cbuff_data_info_t *data_info, void **pptr, int size);
int ul_cbuff_put_data(ul_cbuff_data_info_t *data_info, const void *data, int size);
}
}
+ul_cbuff_inline int
+ul_cbuff_tail_detach_onestep(ul_cbuff_t *buff, ul_cbuff_tail_info_t *tail_info)
+{
+ ul_cbuff_state_t *state=buff->state;
+ ul_cbuff_loc_t loc;
+ ul_cbuff_loc_t loc_next;
+ unsigned msg_readers;
+
+ if(tail_info->msg_head==NULL)
+ return 0;
+
+ loc = ul_cbuff_head_loc(buff, tail_info->msg_head);
+
+ if(loc!=state->head) {
+ if(!ul_cbuff_is_ready(tail_info->msg_head))
+ return 2;
+ msg_readers=tail_info->msg_head->flags&UL_CBUFF_MSG_READERS;
+ loc_next=ul_cbuff_next_loc(buff, tail_info->msg_head);
+ if(msg_readers)
+ tail_info->msg_head->flags--;
+ tail_info->msg_head=(ul_cbuff_msg_head_t *)(buff->buff_start+loc_next);
+ ul_cbuff_tail_state_update(buff, msg_readers<=1? 1: 0, loc, loc_next);
+ return 1;
+ }
+
+ if(state->readers>0)
+ state->readers--;
+ tail_info->msg_head=NULL;
+ tail_info->data.ptr=NULL;
+ return 0;
+}
+
+
ul_cbuff_inline void
ul_cbuff_data_do_wrap(ul_cbuff_data_info_t *data_info)
{