xref: /plan9/sys/src/cmd/aquarela/smblog.c (revision 86a363cef6b6fa09d9392d8587eef2e5ef8d657e)
18ccd4a63SDavid du Colombier #include "headers.h"
28ccd4a63SDavid du Colombier 
38ccd4a63SDavid du Colombier static QLock logreflock, logprintlock;
48ccd4a63SDavid du Colombier static int locked;
58ccd4a63SDavid du Colombier 
68ccd4a63SDavid du Colombier void
smbloglock(void)78ccd4a63SDavid du Colombier smbloglock(void)
88ccd4a63SDavid du Colombier {
98ccd4a63SDavid du Colombier 	qlock(&logreflock);
108ccd4a63SDavid du Colombier 	if (locked++ == 0)
118ccd4a63SDavid du Colombier 		qlock(&logprintlock);
128ccd4a63SDavid du Colombier 	qunlock(&logreflock);
138ccd4a63SDavid du Colombier }
148ccd4a63SDavid du Colombier 
158ccd4a63SDavid du Colombier void
smblogunlock(void)168ccd4a63SDavid du Colombier smblogunlock(void)
178ccd4a63SDavid du Colombier {
188ccd4a63SDavid du Colombier 	qlock(&logreflock);
198ccd4a63SDavid du Colombier 	if (locked && --locked == 0)
208ccd4a63SDavid du Colombier 		qunlock(&logprintlock);
218ccd4a63SDavid du Colombier 	qunlock(&logreflock);
228ccd4a63SDavid du Colombier }
238ccd4a63SDavid du Colombier 
248ccd4a63SDavid du Colombier static int
smbloglockedvprint(char * fmt,va_list ap)258ccd4a63SDavid du Colombier smbloglockedvprint(char *fmt, va_list ap)
268ccd4a63SDavid du Colombier {
278ccd4a63SDavid du Colombier 	if (smbglobals.log.fd >= 0)
288ccd4a63SDavid du Colombier 		vfprint(smbglobals.log.fd, fmt, ap);
298ccd4a63SDavid du Colombier 	if (smbglobals.log.print)
308ccd4a63SDavid du Colombier 		vfprint(2, fmt, ap);
318ccd4a63SDavid du Colombier 	return 0;
328ccd4a63SDavid du Colombier }
338ccd4a63SDavid du Colombier 
348ccd4a63SDavid du Colombier int
smblogvprint(int cmd,char * fmt,va_list ap)358ccd4a63SDavid du Colombier smblogvprint(int cmd, char *fmt, va_list ap)
368ccd4a63SDavid du Colombier {
378ccd4a63SDavid du Colombier 	if (cmd < 0 || smboptable[cmd].debug) {
388ccd4a63SDavid du Colombier 		smbloglock();
398ccd4a63SDavid du Colombier 		smbloglockedvprint(fmt, ap);
408ccd4a63SDavid du Colombier 		smblogunlock();
418ccd4a63SDavid du Colombier 	}
428ccd4a63SDavid du Colombier 	return 0;
438ccd4a63SDavid du Colombier }
448ccd4a63SDavid du Colombier 
458ccd4a63SDavid du Colombier int
smblogprint(int cmd,char * fmt,...)468ccd4a63SDavid du Colombier smblogprint(int cmd, char *fmt, ...)
478ccd4a63SDavid du Colombier {
48*86a363ceSDavid du Colombier 	if (cmd < 0 || smbtrans2optable[cmd].debug) {
49*86a363ceSDavid du Colombier 		va_list ap;
50*86a363ceSDavid du Colombier 		va_start(ap, fmt);
51*86a363ceSDavid du Colombier 		smblogvprint(cmd, fmt, ap);
52*86a363ceSDavid du Colombier 		va_end(ap);
53*86a363ceSDavid du Colombier 	}
54*86a363ceSDavid du Colombier 	return 0;
55*86a363ceSDavid du Colombier }
56*86a363ceSDavid du Colombier 
57*86a363ceSDavid du Colombier int
translogprint(int cmd,char * fmt,...)58*86a363ceSDavid du Colombier translogprint(int cmd, char *fmt, ...)
59*86a363ceSDavid du Colombier {
608ccd4a63SDavid du Colombier 	if (cmd < 0 || smboptable[cmd].debug) {
618ccd4a63SDavid du Colombier 		va_list ap;
628ccd4a63SDavid du Colombier 		va_start(ap, fmt);
638ccd4a63SDavid du Colombier 		smblogvprint(cmd, fmt, ap);
648ccd4a63SDavid du Colombier 		va_end(ap);
658ccd4a63SDavid du Colombier 	}
668ccd4a63SDavid du Colombier 	return 0;
678ccd4a63SDavid du Colombier }
688ccd4a63SDavid du Colombier 
698ccd4a63SDavid du Colombier int
smblogprintif(int v,char * fmt,...)708ccd4a63SDavid du Colombier smblogprintif(int v, char *fmt, ...)
718ccd4a63SDavid du Colombier {
728ccd4a63SDavid du Colombier 	if (v) {
738ccd4a63SDavid du Colombier 		va_list ap;
748ccd4a63SDavid du Colombier 		va_start(ap, fmt);
758ccd4a63SDavid du Colombier 		smbloglock();
768ccd4a63SDavid du Colombier 		smbloglockedvprint(fmt, ap);
778ccd4a63SDavid du Colombier 		smblogunlock();
788ccd4a63SDavid du Colombier 		va_end(ap);
798ccd4a63SDavid du Colombier 	}
808ccd4a63SDavid du Colombier 	return 0;
818ccd4a63SDavid du Colombier }
828ccd4a63SDavid du Colombier 
838ccd4a63SDavid du Colombier void
smblogdata(int cmd,int (* print)(int cmd,char * fmt,...),void * ap,long n,long limit)848ccd4a63SDavid du Colombier smblogdata(int cmd, int (*print)(int cmd, char *fmt, ...), void *ap, long n, long limit)
858ccd4a63SDavid du Colombier {
868ccd4a63SDavid du Colombier 	uchar *p = ap;
878ccd4a63SDavid du Colombier 	long i;
888ccd4a63SDavid du Colombier 	long saven;
898ccd4a63SDavid du Colombier 	i = 0;
908ccd4a63SDavid du Colombier 	saven = n;
918ccd4a63SDavid du Colombier 	if (saven > limit)
928ccd4a63SDavid du Colombier 		n = limit;
938ccd4a63SDavid du Colombier 	while (i < n) {
948ccd4a63SDavid du Colombier 		int l = n - i < 16 ? n - i : 16;
958ccd4a63SDavid du Colombier 		int b;
968ccd4a63SDavid du Colombier 		(*print)(cmd, "0x%.4lux  ", i);
978ccd4a63SDavid du Colombier 		for (b = 0; b < l; b += 2) {
988ccd4a63SDavid du Colombier 			(*print)(cmd, " %.2ux", p[i + b]);
998ccd4a63SDavid du Colombier 			if (b < l - 1)
1008ccd4a63SDavid du Colombier 				(*print)(cmd, "%.2ux", p[i + b + 1]);
1018ccd4a63SDavid du Colombier 			else
1028ccd4a63SDavid du Colombier 				(*print)(cmd, "  ");
1038ccd4a63SDavid du Colombier 		}
1048ccd4a63SDavid du Colombier 		while (b < 16) {
1058ccd4a63SDavid du Colombier 			(*print)(cmd, "     ");
1068ccd4a63SDavid du Colombier 			b += 2;
1078ccd4a63SDavid du Colombier 		}
1088ccd4a63SDavid du Colombier 		(*print)(cmd, "        ");
1098ccd4a63SDavid du Colombier 		for (b = 0; b < l; b++)
1108ccd4a63SDavid du Colombier 			if (p[i + b] >= ' ' && p[i + b] <= '~')
1118ccd4a63SDavid du Colombier 				(*print)(cmd, "%c", p[i + b]);
1128ccd4a63SDavid du Colombier 			else
1138ccd4a63SDavid du Colombier 				(*print)(cmd, ".");
1148ccd4a63SDavid du Colombier 		(*print)(cmd, "\n");
1158ccd4a63SDavid du Colombier 		i += l;
1168ccd4a63SDavid du Colombier 	}
1178ccd4a63SDavid du Colombier 	if (saven > limit)
1188ccd4a63SDavid du Colombier 		(*print)(cmd, "0x%.4ux   ...\n0x%.4ux\n", limit, saven);
1198ccd4a63SDavid du Colombier }
120