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