aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2003-11-23 19:49:17 +0000
committerrsc <devnull@localhost>2003-11-23 19:49:17 +0000
commit1c253ceb586c4519f42ce115954c4efab787f81a (patch)
tree22281aafc4c33f4ab310a845aec510f013511833 /src
parent50e628cb8f4594b7cbccc17ff3f701ff260a69c0 (diff)
downloadplan9port-1c253ceb586c4519f42ce115954c4efab787f81a.tar.gz
plan9port-1c253ceb586c4519f42ce115954c4efab787f81a.tar.bz2
plan9port-1c253ceb586c4519f42ce115954c4efab787f81a.zip
Annoying changes to work on Sun boxes.
Diffstat (limited to 'src')
-rw-r--r--src/Makefile3
-rw-r--r--src/cmd/mkfile2
-rw-r--r--src/cmd/rc/syn.y2
-rw-r--r--src/cmd/venti/mkfile10
-rw-r--r--src/lib9/_p9dialparse.c10
-rw-r--r--src/lib9/_p9dir.c14
-rw-r--r--src/lib9/announce.c3
-rw-r--r--src/lib9/await.c2
-rw-r--r--src/lib9/date.c16
-rw-r--r--src/lib9/dial.c1
-rw-r--r--src/lib9/dirfwstat.c9
-rw-r--r--src/lib9/dirread.c16
-rw-r--r--src/lib9/mkfile2
-rw-r--r--src/lib9/rfork.c2
-rw-r--r--src/mkfile2
-rw-r--r--src/mkhdr8
16 files changed, 68 insertions, 34 deletions
diff --git a/src/Makefile b/src/Makefile
index b75e3c35..1c8010d4 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -1,5 +1,6 @@
../bin/mk: mkmk.sh
- PATH=`pwd`/../bin:$PATH export PATH
+ PATH=`pwd`/../bin:$$PATH export PATH; \
+ PLAN9=`pwd`/.. export PLAN9; \
sh -x mkmk.sh
all clean install nuke: ../bin/mk
diff --git a/src/cmd/mkfile b/src/cmd/mkfile
index 72a2320a..b34a61b3 100644
--- a/src/cmd/mkfile
+++ b/src/cmd/mkfile
@@ -6,7 +6,7 @@ LDFLAGS=$LDFLAGS -lsec -lregexp9 -l9 -lbio -lfmt -lutf
<$PLAN9/src/mkmany
-BUGGERED='CVS|oplumb|plumb|plumb2|mk|vac'
+BUGGERED='CVS|oplumb|plumb|plumb2|mk|vac|9term'
DIRS=`ls -l |sed -n 's/^d.* //p' |egrep -v "$BUGGERED"`
<$PLAN9/src/mkdirs
diff --git a/src/cmd/rc/syn.y b/src/cmd/rc/syn.y
index c7de3531..38a01036 100644
--- a/src/cmd/rc/syn.y
+++ b/src/cmd/rc/syn.y
@@ -7,7 +7,7 @@
%left BANG SUBSHELL
%left PIPE
%left '^'
-%right '$' COUNT '"'
+%right '$' COUNT '\"'
%left SUB
%{
#include "rc.h"
diff --git a/src/cmd/venti/mkfile b/src/cmd/venti/mkfile
index 48f2c60f..e899ef3f 100644
--- a/src/cmd/venti/mkfile
+++ b/src/cmd/venti/mkfile
@@ -71,16 +71,12 @@ it:V: all
<$PLAN9/src/mkmany
+$SLIB: $LIBOFILES
+ ar rvc $SLIB $LIBOFILES
+
# xml.c:D: mkxml dat.h
# ./mkxml dat.h > xml.c
-$SLIB(%.$O):N: %.$O
-$SLIB: ${LIBOFILES:%=$SLIB(%)}
- names=`echo $newprereq | sed -E 's/'$SLIB'\(([^)]+)\)/\1/g'`
- # names = `{echo $newprereq |sed 's/ /\n/g' |sed -n 's/'$SLIB'\(([^)]+)\)/\1/gp'}
- ar rvc $SLIB $names
-# rm $names
-
ainstall:V: ${TARG:%=%.ainstall}
%.ainstall:V: $O.%
diff --git a/src/lib9/_p9dialparse.c b/src/lib9/_p9dialparse.c
index 93c98425..44594dc0 100644
--- a/src/lib9/_p9dialparse.c
+++ b/src/lib9/_p9dialparse.c
@@ -1,9 +1,9 @@
-#include <u.h>
-#include <libc.h>
-
#include <netdb.h>
#include <sys/un.h>
+#include <u.h>
+#include <libc.h>
+
static char *nets[] = { "tcp", "udp", nil };
#define CLASS(p) ((*(uchar*)(p))>>6)
@@ -59,7 +59,7 @@ _p9dialparse(char *addr, char **pnet, char **punix, u32int *phost, int *pport)
int i;
struct servent *se;
struct hostent *he;
- struct sockaddr_un *sun;
+ struct sockaddr_un *sockun;
if(strncmp(addr, "/net/", 5) == 0)
addr += 5;
@@ -73,7 +73,7 @@ _p9dialparse(char *addr, char **pnet, char **punix, u32int *phost, int *pport)
if((port = strchr(host, '!')) == nil){
if(strcmp(net, "unix")==0 || strcmp(net, "net")==0){
Unix:
- if(strlen(host)+1 > sizeof sun->sun_path){
+ if(strlen(host)+1 > sizeof sockun->sun_path){
werrstr("unix socket name too long");
return -1;
}
diff --git a/src/lib9/_p9dir.c b/src/lib9/_p9dir.c
index 459bd157..0903c57d 100644
--- a/src/lib9/_p9dir.c
+++ b/src/lib9/_p9dir.c
@@ -1,13 +1,15 @@
-#include <u.h>
-#define NOPLAN9DEFINES
-#include <libc.h>
-
#include <sys/stat.h>
+#ifdef _HAVEDISKLABEL
#include <sys/disklabel.h>
+#endif
#include <dirent.h>
#include <pwd.h>
#include <grp.h>
+#include <u.h>
+#define NOPLAN9DEFINES
+#include <libc.h>
+
int
_p9dir(struct stat *st, char *name, Dir *d, char **str, char *estr)
{
@@ -83,7 +85,9 @@ _p9dir(struct stat *st, char *name, Dir *d, char **str, char *estr)
d->muid = "";
d->qid.path = ((uvlong)st->st_dev<<32) | st->st_ino;
+#ifdef _HAVESTGEN
d->qid.vers = st->st_gen;
+#endif
d->mode = st->st_mode&0777;
d->atime = st->st_atime;
d->mtime = st->st_mtime;
@@ -96,6 +100,7 @@ _p9dir(struct stat *st, char *name, Dir *d, char **str, char *estr)
}
/* fetch real size for disks */
+#ifdef _HAVEDISKLABEL
if(S_ISCHR(st->st_mode)){
int fd, n;
struct disklabel lab;
@@ -114,6 +119,7 @@ _p9dir(struct stat *st, char *name, Dir *d, char **str, char *estr)
if(fd >= 0)
close(fd);
}
+#endif
}
return sz;
diff --git a/src/lib9/announce.c b/src/lib9/announce.c
index dc8cbbbf..04c712d9 100644
--- a/src/lib9/announce.c
+++ b/src/lib9/announce.c
@@ -6,6 +6,8 @@
#include <netinet/in.h>
#include <sys/un.h>
+#undef sun
+#define sun sockun
extern int _p9dialparse(char*, char**, char**, u32int*, int*);
static int
@@ -88,7 +90,6 @@ print("announce dir: %s\n", dir);
Unix:
memset(&sun, 0, sizeof sun);
sun.sun_family = AF_UNIX;
- sun.sun_len = sizeof sun;
strcpy(sun.sun_path, unix);
if((s = socket(AF_UNIX, SOCK_STREAM, 0)) < 0)
return -1;
diff --git a/src/lib9/await.c b/src/lib9/await.c
index 67e99b82..ba94c28a 100644
--- a/src/lib9/await.c
+++ b/src/lib9/await.c
@@ -38,7 +38,9 @@ static struct {
SIGVTALRM, "sys: virtual time alarm",
SIGPROF, "sys: profiling timer alarm",
SIGWINCH, "sys: window size change",
+#ifdef SIGINFO
SIGINFO, "sys: status request",
+#endif
SIGUSR1, "sys: usr1",
SIGUSR2, "sys: usr2",
};
diff --git a/src/lib9/date.c b/src/lib9/date.c
index 2e84fd0a..72860aa7 100644
--- a/src/lib9/date.c
+++ b/src/lib9/date.c
@@ -25,8 +25,12 @@ tm2Tm(struct tm *tm, Tm *bigtm)
bigtm->mon = tm->tm_mon;
bigtm->year = tm->tm_year;
bigtm->wday = tm->tm_wday;
+#ifdef _HAVETMZONE
strecpy(bigtm->zone, bigtm->zone+4, tm->tm_zone);
+#endif
+#ifdef _HAVETZOFF
bigtm->tzoff = tm->tm_gmtoff;
+#endif
}
static void
@@ -40,8 +44,12 @@ Tm2tm(Tm *bigtm, struct tm *tm)
tm->tm_mon = bigtm->mon;
tm->tm_year = bigtm->year;
tm->tm_wday = bigtm->wday;
+#ifdef _HAVETMZONE
tm->tm_zone = bigtm->zone;
+#endif
+#ifdef _HAVETZOFF
tm->tm_gmtoff = bigtm->tzoff;
+#endif
}
Tm*
@@ -64,6 +72,14 @@ p9localtime(long t)
return &bigtm;
}
+#if !defined(_HAVETIMEGM) && defined(_HAVETIMEZONEINT)
+static long
+timegm(struct tm *tm)
+{
+ return mktime(tm)-timezone;
+}
+#endif
+
long
p9tm2sec(Tm *bigtm)
{
diff --git a/src/lib9/dial.c b/src/lib9/dial.c
index 1d961b4c..fa19cce8 100644
--- a/src/lib9/dial.c
+++ b/src/lib9/dial.c
@@ -72,7 +72,6 @@ p9dial(char *addr, char *dummy1, char *dummy2, int *dummy3)
Unix:
memset(&su, 0, sizeof su);
- su.sun_len = sizeof su;
su.sun_family = AF_UNIX;
if(strlen(unix)+1 > sizeof su.sun_path){
werrstr("unix socket name too long");
diff --git a/src/lib9/dirfwstat.c b/src/lib9/dirfwstat.c
index 7f6c54aa..7ca51251 100644
--- a/src/lib9/dirfwstat.c
+++ b/src/lib9/dirfwstat.c
@@ -4,6 +4,14 @@
#include <sys/time.h>
+#if !defined(_HAVEFUTIMES) && defined(_HAVEFUTIMESAT)
+static int
+futimes(int fd, struct timeval *tv)
+{
+ return futimesat(fd, 0, tv);
+}
+#endif
+
int
dirfwstat(int fd, Dir *dir)
{
@@ -19,3 +27,4 @@ dirfwstat(int fd, Dir *dir)
tv[1].tv_usec = 0;
return futimes(fd, tv);
}
+
diff --git a/src/lib9/dirread.c b/src/lib9/dirread.c
index f4610f68..5151b132 100644
--- a/src/lib9/dirread.c
+++ b/src/lib9/dirread.c
@@ -24,10 +24,10 @@ countde(char *p, int n)
de = (struct dirent*)p;
if(de->d_reclen <= 4+2+2+1 || p+de->d_reclen > e)
break;
- if(de->d_namlen == 1 && de->d_name[0]=='.')
- de->d_namlen = 0;
- else if(de->d_namlen == 2 && de->d_name[0]=='.' && de->d_name[1]=='.')
- de->d_namlen = 0;
+ if(de->d_name[0]=='.' && de->d_name[1]==0)
+ de->d_name[0] = 0;
+ else if(de->d_name[0]=='.' && de->d_name[1]=='.' && de->d_name[2]==0)
+ de->d_name[0] = 0;
else
m++;
p += de->d_reclen;
@@ -59,7 +59,7 @@ dirpackage(int fd, char *buf, int n, Dir **dp)
for(i=0; i<n; i++){
de = (struct dirent*)p;
if(stat(de->d_name, &st) < 0)
- de->d_namlen = 0;
+ de->d_name[0] = 0;
else
nstr += _p9dir(&st, de->d_name, nil, nil, nil);
p += de->d_reclen;
@@ -78,7 +78,7 @@ dirpackage(int fd, char *buf, int n, Dir **dp)
m = 0;
for(i=0; i<n; i++){
de = (struct dirent*)p;
- if(de->d_namlen != 0 && stat(de->d_name, &st) >= 0)
+ if(de->d_name[0] != 0 && stat(de->d_name, &st) >= 0)
_p9dir(&st, de->d_name, &d[m++], &str, estr);
p += de->d_reclen;
}
@@ -108,7 +108,7 @@ dirread(int fd, Dir **dp)
if(buf == nil)
return -1;
- n = getdents(fd, buf, st.st_blksize);
+ n = getdents(fd, (struct dirent*)buf, st.st_blksize);
if(n < 0){
free(buf);
return -1;
@@ -141,7 +141,7 @@ dirreadall(int fd, Dir **d)
return -1;
}
buf = nbuf;
- n = getdents(fd, buf+ts, st.st_blksize);
+ n = getdents(fd, (struct dirent*)(buf+ts), st.st_blksize);
if(n <= 0)
break;
ts += n;
diff --git a/src/lib9/mkfile b/src/lib9/mkfile
index 9f5971ab..deb69249 100644
--- a/src/lib9/mkfile
+++ b/src/lib9/mkfile
@@ -38,7 +38,7 @@ OFILES=\
getuser.$O\
getwd.$O\
jmp.$O\
- jmp-FreeBSD.$O\
+ jmp-$SYSNAME.$O\
lock.$O\
main.$O\
malloctag.$O\
diff --git a/src/lib9/rfork.c b/src/lib9/rfork.c
index e248cd78..41d3f9d6 100644
--- a/src/lib9/rfork.c
+++ b/src/lib9/rfork.c
@@ -9,7 +9,7 @@ p9rfork(int flags)
return -1;
}
if(flags&RFNOTEG){
- setpgrp(0, 0);
+ setpgid(0, getpid());
flags &= ~RFNOTEG;
}
if(flags){
diff --git a/src/mkfile b/src/mkfile
index 6740a002..a896be23 100644
--- a/src/mkfile
+++ b/src/mkfile
@@ -42,7 +42,7 @@ testmkmk:V:
ls -l ../bin/mk
testcvs:V:
- cvs up -dAP
+ (cd ..; cvs up -dAP)
cp ../bin/_mk ../bin/mk
mk clean
rm ../lib/*.a
diff --git a/src/mkhdr b/src/mkhdr
index 2cc8d973..d1b65729 100644
--- a/src/mkhdr
+++ b/src/mkhdr
@@ -2,14 +2,18 @@ SYSNAME=`uname`
OBJTYPE=`uname -m | sed 's;i.86;386;; s;/.*;;; s; ;;g'`
X11=/usr/X11R6
-LDFLAGS=
+CC=9c
+LD=9l
+AS=9a
CFLAGS=
+LDFLAGS=
AFLAGS=
+O=o
BIN=$PLAN9/bin
LIBDIR=$PLAN9/lib
-<|sed -E '"s/(.*)\+=/\1=$\1 /g"' $PLAN9/src/Make.$SYSNAME-$OBJTYPE
+<$PLAN9/src/mk.$SYSNAME-$OBJTYPE
OS=$O
LD=9l