set exit status
diff --git a/src/cmd/9p.c b/src/cmd/9p.c
index 909bfeb..bace6d0 100644
--- a/src/cmd/9p.c
+++ b/src/cmd/9p.c
@@ -355,13 +355,14 @@
 void
 xls(int argc, char **argv)
 {
-	char *name, *xname, *f[4], buf[4096];
+	char *err, *name, *xname, *f[4], buf[4096];
 	int nf, i, j, l;
 	int lflag, dflag, n, len[4];
 	Dir *d;
 	CFid *fid;
 	CFsys *fs;
-	
+
+	err = nil;
 	lflag = dflag = 0;
 	ARGBEGIN{
 	case 'l':
@@ -383,6 +384,7 @@
 		if((d = fsdirstat(fs, xname)) == nil){
 			fprint(2, "dirstat %s: %r\n", name);
 			fsunmount(fs);
+			err = "errors";
 			continue;
 		}
 		if((d->mode&DMDIR) && !dflag){
@@ -390,6 +392,7 @@
 				fprint(2, "open %s: %r\n", name);
 				fsunmount(fs);
 				free(d);
+				err = "errors";
 				continue;
 			}
 			free(d);
@@ -398,6 +401,7 @@
 			if(n < 0){
 				fprint(2, "dirreadall %s: %r\n", name);
 				fsunmount(fs);
+				err = "errors";
 				continue;
 			}
 			qsort(d, n, sizeof d[0], dircmp);
@@ -430,6 +434,6 @@
 		}
 		free(d);
 	}
-	threadexitsall(0);
+	threadexitsall(err);
 }