put_info->msg_head->flags|=flags;
if(buff->state->readers>0)
put_info->msg_head->flags+=buff->state->readers;
+ else if (buff->state->readers==0)
+ put_info->msg_head->flags+=1;
put_info->msg_head->length=length;
{
ul_cbuff_state_t *state=buff->state;
ul_cbuff_msg_head_t *msg_head;
+ (void)mode;
- msg_head=(ul_cbuff_msg_head_t *)(buff->buff_start+state->head);
- if(state->readers>=0)
- state->readers++;
+ if(state->readers>0)
+ msg_head=(ul_cbuff_msg_head_t *)(buff->buff_start+state->head);
+ else /* no reader yet .. state->readers==0 */
+ msg_head=(ul_cbuff_msg_head_t *)(buff->buff_start+state->lasttail);
+ state->readers++;
tail_info->msg_head=msg_head;
tail_info->data.ptr=NULL;
return 0;
ul_cbuff_inline int
ul_cbuff_tail_incontact(ul_cbuff_t *buff, ul_cbuff_tail_info_t *tail_info)
{
+ (void)buff;
+
if(tail_info->msg_head==NULL){
return 0;
}