xref: /plan9/sys/src/libventi/zero.c (revision 368c31ab13393dea083228fdd1c3445076f83a4b)
16b6b9ac8SDavid du Colombier #include <u.h>
26b6b9ac8SDavid du Colombier #include <libc.h>
36b6b9ac8SDavid du Colombier #include <venti.h>
46b6b9ac8SDavid du Colombier 
5*368c31abSDavid du Colombier void
vtzeroextend(int type,uchar * buf,uint n,uint nn)6*368c31abSDavid du Colombier vtzeroextend(int type, uchar *buf, uint n, uint nn)
76b6b9ac8SDavid du Colombier {
86b6b9ac8SDavid du Colombier 	uchar *p, *ep;
96b6b9ac8SDavid du Colombier 
10*368c31abSDavid du Colombier 	switch(type&7) {
11*368c31abSDavid du Colombier 	case 0:
126b6b9ac8SDavid du Colombier 		memset(buf+n, 0, nn-n);
136b6b9ac8SDavid du Colombier 		break;
14*368c31abSDavid du Colombier 	default:
156b6b9ac8SDavid du Colombier 		p = buf + (n/VtScoreSize)*VtScoreSize;
166b6b9ac8SDavid du Colombier 		ep = buf + (nn/VtScoreSize)*VtScoreSize;
176b6b9ac8SDavid du Colombier 		while(p < ep) {
18*368c31abSDavid du Colombier 			memmove(p, vtzeroscore, VtScoreSize);
196b6b9ac8SDavid du Colombier 			p += VtScoreSize;
206b6b9ac8SDavid du Colombier 		}
216b6b9ac8SDavid du Colombier 		memset(p, 0, buf+nn-p);
226b6b9ac8SDavid du Colombier 		break;
236b6b9ac8SDavid du Colombier 	}
246b6b9ac8SDavid du Colombier }
256b6b9ac8SDavid du Colombier 
26*368c31abSDavid du Colombier uint
vtzerotruncate(int type,uchar * buf,uint n)27*368c31abSDavid du Colombier vtzerotruncate(int type, uchar *buf, uint n)
286b6b9ac8SDavid du Colombier {
296b6b9ac8SDavid du Colombier 	uchar *p;
306b6b9ac8SDavid du Colombier 
31*368c31abSDavid du Colombier 	if(type == VtRootType){
32*368c31abSDavid du Colombier 		if(n < VtRootSize)
33*368c31abSDavid du Colombier 			return n;
34*368c31abSDavid du Colombier 		return VtRootSize;
35*368c31abSDavid du Colombier 	}
36*368c31abSDavid du Colombier 
37*368c31abSDavid du Colombier 	switch(type&7){
38*368c31abSDavid du Colombier 	case 0:
396b6b9ac8SDavid du Colombier 		for(p = buf + n; p > buf; p--) {
406b6b9ac8SDavid du Colombier 			if(p[-1] != 0)
416b6b9ac8SDavid du Colombier 				break;
426b6b9ac8SDavid du Colombier 		}
436b6b9ac8SDavid du Colombier 		return p - buf;
44*368c31abSDavid du Colombier 	default:
456b6b9ac8SDavid du Colombier 		/* ignore slop at end of block */
466b6b9ac8SDavid du Colombier 		p = buf + (n/VtScoreSize)*VtScoreSize;
476b6b9ac8SDavid du Colombier 
486b6b9ac8SDavid du Colombier 		while(p > buf) {
49*368c31abSDavid du Colombier 			if(memcmp(p - VtScoreSize, vtzeroscore, VtScoreSize) != 0)
506b6b9ac8SDavid du Colombier 				break;
516b6b9ac8SDavid du Colombier 			p -= VtScoreSize;
526b6b9ac8SDavid du Colombier 		}
536b6b9ac8SDavid du Colombier 		return p - buf;
546b6b9ac8SDavid du Colombier 	}
556b6b9ac8SDavid du Colombier }
56