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