2020-02-15 20:01:48 +00:00
|
|
|
U0 LinkedLstDel(U8 **_lst)
|
|
|
|
{//Free entire linked-list.
|
|
|
|
U8 **tmpl;
|
|
|
|
while (_lst) {
|
|
|
|
tmpl=*_lst;
|
|
|
|
Free(_lst);
|
|
|
|
_lst=tmpl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
U8 *LinkedLstCopy(U8 **_lst,CTask *mem_task=NULL)
|
|
|
|
{//MAlloc ident copy of entire linked-list.
|
|
|
|
U8 *res=NULL,**tmpl=&res;
|
|
|
|
while (_lst) {
|
|
|
|
tmpl=*tmpl=MAllocIdent(_lst,mem_task);
|
|
|
|
_lst=*_lst;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
I64 LinkedLstCnt(U8 **_lst)
|
|
|
|
{//Count of nodes in linked-list.
|
|
|
|
I64 res=0;
|
|
|
|
while (_lst) {
|
|
|
|
res++;
|
|
|
|
_lst=*_lst;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
I64 LinkedLstSize(U8 **_lst)
|
|
|
|
{//Mem size of all nodes in linked-list.
|
|
|
|
I64 res=0;
|
|
|
|
while (_lst) {
|
|
|
|
res+=MSize2(_lst);
|
|
|
|
_lst=*_lst;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
U0 QueueDel(CQueue *head,Bool querem=FALSE)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Free entries in queue, not head.
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueue *tmpq=head->next,*tmpq1;
|
2020-02-15 20:01:48 +00:00
|
|
|
while (tmpq!=head) {
|
|
|
|
tmpq1=tmpq->next;
|
|
|
|
if (querem)
|
2020-02-15 22:53:02 +00:00
|
|
|
QueueRem(tmpq);
|
2020-02-15 20:01:48 +00:00
|
|
|
Free(tmpq);
|
|
|
|
tmpq=tmpq1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueue *QueueCopy(CQueue *head,CTask *mem_task=NULL)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//MAlloc ident copy of entire queue and head.
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueue *res=MAllocIdent(head,mem_task),*tmpq=head->next,*tmpq1;
|
|
|
|
QueueInit(res);
|
2020-02-15 20:01:48 +00:00
|
|
|
while (tmpq!=head) {
|
|
|
|
tmpq1=MAllocIdent(tmpq,mem_task);
|
2020-02-15 22:53:02 +00:00
|
|
|
QueueInsert(tmpq1,res->last);
|
2020-02-15 20:01:48 +00:00
|
|
|
tmpq=tmpq->next;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
I64 QueueCnt(CQueue *head)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Count of nodes in queue, not head.
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueue *tmpq=head->next;
|
2020-02-15 20:01:48 +00:00
|
|
|
I64 res=0;
|
|
|
|
while (tmpq!=head) {
|
|
|
|
res++;
|
|
|
|
tmpq=tmpq->next;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
I64 QueueSize(CQueue *head)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Mem size of all nodes in queue, not head.
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueue *tmpq=head->next;
|
2020-02-15 20:01:48 +00:00
|
|
|
I64 res=0;
|
|
|
|
while (tmpq!=head) {
|
|
|
|
res+=MSize2(tmpq);
|
|
|
|
tmpq=tmpq->next;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueueVectU8 *QueueVectU8New(I64 min_idx=0)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Create new queue vecter.
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueueVectU8 *res=MAlloc(sizeof(CQueueVectU8));
|
|
|
|
QueueInit(res);
|
2020-02-15 20:01:48 +00:00
|
|
|
res->total_cnt=res->node_cnt=0;
|
|
|
|
res->min_idx=min_idx;
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
U0 QueueVectU8Put(CQueueVectU8 *v,I64 idx,U8 ch)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Put U8 at idx i.
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueueVectU8 *tmpv;
|
2020-02-15 20:01:48 +00:00
|
|
|
idx-=v->min_idx;
|
|
|
|
if (idx<0) return;
|
|
|
|
if (idx<v->total_cnt) {
|
|
|
|
tmpv=v;
|
|
|
|
do {
|
|
|
|
idx-=tmpv->node_cnt;
|
|
|
|
if (idx<0) {
|
|
|
|
tmpv->body[idx+tmpv->node_cnt]=ch;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
tmpv=tmpv->next;
|
|
|
|
} while (tmpv!=v);
|
|
|
|
} else
|
|
|
|
idx-=v->total_cnt;
|
|
|
|
|
|
|
|
while (TRUE) {
|
|
|
|
tmpv=v->last;
|
|
|
|
if (tmpv->node_cnt>=QUE_VECT_U8_CNT) {
|
2020-02-15 22:53:02 +00:00
|
|
|
tmpv=MAlloc(sizeof(CQueueVectU8));
|
2020-02-15 20:01:48 +00:00
|
|
|
tmpv->node_cnt=0;
|
2020-02-15 22:53:02 +00:00
|
|
|
QueueInsert(tmpv,v->last);
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
if (idx--) {
|
|
|
|
tmpv->body[tmpv->node_cnt++]=0;
|
|
|
|
v->total_cnt++;
|
|
|
|
} else {
|
|
|
|
tmpv->body[tmpv->node_cnt++]=ch;
|
|
|
|
v->total_cnt++;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
U0 QueueVectU8Del(CQueueVectU8 *v)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Free entire queue vector.
|
|
|
|
if (v) {
|
2020-02-15 22:53:02 +00:00
|
|
|
QueueDel(v);
|
2020-02-15 20:01:48 +00:00
|
|
|
Free(v);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-15 22:53:02 +00:00
|
|
|
I64 QueueVectU8Get(CQueueVectU8 *v,I64 idx)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Get U8 at idx i.
|
2020-02-15 22:53:02 +00:00
|
|
|
CQueueVectU8 *tmpv;
|
2020-02-15 20:01:48 +00:00
|
|
|
idx-=v->min_idx;
|
|
|
|
if (!(0<=idx<v->total_cnt)) return 0;
|
|
|
|
tmpv=v;
|
|
|
|
do {
|
|
|
|
idx-=tmpv->node_cnt;
|
|
|
|
if (idx<0)
|
|
|
|
return tmpv->body[idx+tmpv->node_cnt];
|
|
|
|
tmpv=tmpv->next;
|
|
|
|
} while (tmpv!=v);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
CFifoU8 *FifoU8New(I64 size,CTask *mem_task=NULL)
|
|
|
|
{//Create new fifo.
|
|
|
|
CFifoU8 *f;
|
|
|
|
if (!mem_task) mem_task=Fs;
|
|
|
|
f=MAlloc(sizeof(CFifoU8),mem_task);
|
|
|
|
f->buf=MAlloc(size,mem_task);
|
|
|
|
f->mask=size-1;
|
|
|
|
f->in_ptr=0;
|
|
|
|
f->out_ptr=0;
|
|
|
|
return f;
|
|
|
|
}
|
|
|
|
|
|
|
|
U0 FifoU8Del(CFifoU8 *f)
|
|
|
|
{//Free fifo.
|
|
|
|
Free(f->buf);
|
|
|
|
Free(f);
|
|
|
|
}
|
|
|
|
|
|
|
|
Bool FifoU8Ins(CFifoU8 *f,U8 b)
|
|
|
|
{//Insert U8 into fifo.
|
|
|
|
I64 new_in_ptr;
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
new_in_ptr=(f->in_ptr+1)&f->mask;
|
|
|
|
if (new_in_ptr==f->out_ptr) {
|
|
|
|
POPFD
|
|
|
|
return FALSE;
|
|
|
|
} else {
|
|
|
|
f->buf[f->in_ptr]=b;
|
|
|
|
f->in_ptr=new_in_ptr;
|
|
|
|
POPFD
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Bool FifoU8Rem(CFifoU8 *f,U8 *_b)
|
|
|
|
{//Remove U8 from fifo.
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
if (f->in_ptr==f->out_ptr) {
|
|
|
|
POPFD
|
|
|
|
return FALSE;
|
|
|
|
} else {
|
|
|
|
*_b=f->buf[f->out_ptr];
|
|
|
|
f->out_ptr=(f->out_ptr+1)&f->mask;
|
|
|
|
POPFD
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Bool FifoU8Peek(CFifoU8 *f,U8 *_b)
|
|
|
|
{//Peek at front of fifo and don't remove.
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
if (f->in_ptr==f->out_ptr) {
|
|
|
|
POPFD
|
|
|
|
return FALSE;
|
|
|
|
} else {
|
|
|
|
*_b=f->buf[f->out_ptr];
|
|
|
|
POPFD
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
U0 FifoU8Flush(CFifoU8 *f)
|
|
|
|
{//Flush fifo getting rid of all U8's.
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
f->out_ptr=f->in_ptr;
|
|
|
|
POPFD
|
|
|
|
}
|
|
|
|
|
|
|
|
I64 FifoU8Cnt(CFifoU8 *f)
|
|
|
|
{//Count of U8's in fifo.
|
|
|
|
I64 res;
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
if (f->out_ptr>f->in_ptr)
|
|
|
|
res=f->mask+1-(f->out_ptr-f->in_ptr);
|
|
|
|
else
|
|
|
|
res=f->in_ptr-f->out_ptr;
|
|
|
|
POPFD
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
CFifoI64 *FifoI64New(I64 size,CTask *mem_task=NULL)
|
|
|
|
{//Create new fifo.
|
|
|
|
CFifoI64 *f;
|
|
|
|
if (!mem_task) mem_task=Fs;
|
|
|
|
f=MAlloc(sizeof(CFifoI64),mem_task);
|
|
|
|
f->buf=MAlloc(size*sizeof(I64),mem_task);
|
|
|
|
f->mask=size-1;
|
|
|
|
f->in_ptr=0;
|
|
|
|
f->out_ptr=0;
|
|
|
|
return f;
|
|
|
|
}
|
|
|
|
|
|
|
|
U0 FifoI64Del(CFifoI64 *f)
|
|
|
|
{//Free fifo.
|
|
|
|
Free(f->buf);
|
|
|
|
Free(f);
|
|
|
|
}
|
|
|
|
|
|
|
|
Bool FifoI64Ins(CFifoI64 *f,I64 q)
|
|
|
|
{//Insert I64 into fifo.
|
|
|
|
I64 new_in_ptr;
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
new_in_ptr=(f->in_ptr+1)&f->mask;
|
|
|
|
if (new_in_ptr==f->out_ptr) {
|
|
|
|
POPFD
|
|
|
|
return FALSE;
|
|
|
|
} else {
|
|
|
|
f->buf[f->in_ptr]=q;
|
|
|
|
f->in_ptr=new_in_ptr;
|
|
|
|
POPFD
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Bool FifoI64Rem(CFifoI64 *f,I64 *_q)
|
|
|
|
{//Remove I64 from fifo.
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
if (f->in_ptr==f->out_ptr) {
|
|
|
|
POPFD
|
|
|
|
return FALSE;
|
|
|
|
} else {
|
|
|
|
*_q=f->buf[f->out_ptr];
|
|
|
|
f->out_ptr=(f->out_ptr+1)&f->mask;
|
|
|
|
POPFD
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Bool FifoI64Peek(CFifoI64 *f,I64 *_q)
|
|
|
|
{//Peek at front of fifo and don't remove.
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
if (f->in_ptr==f->out_ptr) {
|
|
|
|
POPFD
|
|
|
|
return FALSE;
|
|
|
|
} else {
|
|
|
|
*_q=f->buf[f->out_ptr];
|
|
|
|
POPFD
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
U0 FifoI64Flush(CFifoI64 *f)
|
|
|
|
{//Flush fifo getting rid of all I64's.
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
f->out_ptr=f->in_ptr;
|
|
|
|
POPFD
|
|
|
|
}
|
|
|
|
|
|
|
|
I64 FifoI64Cnt(CFifoI64 *f)
|
|
|
|
{//Count of I64's in fifo.
|
|
|
|
I64 res;
|
|
|
|
PUSHFD
|
|
|
|
CLI
|
|
|
|
if (f->out_ptr>f->in_ptr)
|
|
|
|
res=f->mask+1-(f->out_ptr-f->in_ptr);
|
|
|
|
else
|
|
|
|
res=f->in_ptr-f->out_ptr;
|
|
|
|
POPFD
|
|
|
|
return res;
|
|
|
|
}
|