import E script from bell labs
This commit is contained in:
parent
dbe0a995f0
commit
6b402b83cf
42 changed files with 359 additions and 218 deletions
|
@ -1,39 +1,10 @@
|
||||||
# we start with the namespace of the console...
|
bind /cfg /usr/web/cfg
|
||||||
|
bind /386 /usr/web/386
|
||||||
|
bind /amd64 /usr/web/amd64
|
||||||
|
|
||||||
# man2html expects man pages under /sys/man
|
bind /sys/src/9 /usr/web/sys/src/9
|
||||||
mount #s/boot /n/emelieother other
|
|
||||||
bind /n/emelieother/plan9/sys/man /usr/web/sys/man
|
|
||||||
#bind /n/emelieother/plan9/sys/doc /usr/web/sys/doc
|
|
||||||
#bind /sys/man /usr/web/sys/man
|
|
||||||
bind /sys/doc /usr/web/sys/doc
|
|
||||||
|
|
||||||
# just so people will find something under plan9
|
mount #s/etcd /n/etcd
|
||||||
bind /usr/web/plan9dist /usr/web/plan9
|
bind /n/etcd/www /usr/web/etc
|
||||||
|
|
||||||
# users
|
|
||||||
bind /usr/mike/www /usr/web/incoming/mike
|
|
||||||
|
|
||||||
# netlib
|
|
||||||
bind /netlib/pub /usr/web/netlib
|
|
||||||
mount -b #s/netlib.depend.pub /usr/web/netlib.depend
|
|
||||||
# don't need to bind to /usr/web/math etc. because of /sys/lib/http-rewrite
|
|
||||||
|
|
||||||
# who what why when where
|
|
||||||
mount /srv/alice /n/alice
|
|
||||||
bind -b /n/alice/cm /usr/web/cm
|
|
||||||
bind /usr/web/cm/who /usr/web/who
|
|
||||||
bind -b /usr/web/cm/physics/who /usr/web/who
|
|
||||||
bind -b /usr/web/cm/blrsv/who /usr/web/who
|
|
||||||
bind -b /usr/web/cm/ss/who /usr/web/who
|
|
||||||
bind -b /usr/web/cm/ms/who /usr/web/who
|
|
||||||
bind -b /usr/web/cm/china/who /usr/web/who
|
|
||||||
bind -b /usr/web/cm/cs/who /usr/web/who
|
|
||||||
bind /usr/web/cm/ms/what/wavelet /usr/web/wavelet
|
|
||||||
|
|
||||||
# formerly ftp.research.bell-labs.com
|
|
||||||
bind -b /n/alice/usr/ftp /usr/web/dist
|
|
||||||
|
|
||||||
# wiki (questions to rsc)
|
|
||||||
mount -b #s/wiki.plan9 /usr/web/wiki/plan9
|
|
||||||
|
|
||||||
# httpd will bind /usr/web onto /
|
# httpd will bind /usr/web onto /
|
||||||
|
|
11
lib/vgadb
11
lib/vgadb
|
@ -435,6 +435,7 @@ ctlr
|
||||||
ctlr=geode linear=1
|
ctlr=geode linear=1
|
||||||
|
|
||||||
ctlr
|
ctlr
|
||||||
|
vid=0x8086 did=0x0126 # Intel 2nd Gen Core
|
||||||
vid=0x8086 did=0x0166 # Intel 3rd Gen Core
|
vid=0x8086 did=0x0166 # Intel 3rd Gen Core
|
||||||
vid=0x8086 did=0x2a42 # Intel 4 Series Mobile
|
vid=0x8086 did=0x2a42 # Intel 4 Series Mobile
|
||||||
link=vga
|
link=vga
|
||||||
|
@ -1694,6 +1695,16 @@ s2231wD=1680x1050
|
||||||
vrs=1053 vre=1059 vt=1080
|
vrs=1053 vre=1059 vt=1080
|
||||||
hsync=+ vsync=-
|
hsync=+ vsync=-
|
||||||
|
|
||||||
|
#
|
||||||
|
# Lenovo T420 (LCD) LVDS
|
||||||
|
#
|
||||||
|
#t420=1366x768 # 60Hz
|
||||||
|
# clock=69.3
|
||||||
|
# shb=1398 ehb=1430 ht=1470
|
||||||
|
# vrs=771 vre=776 vt=786
|
||||||
|
# hsync=- vsync=-
|
||||||
|
# lcd=1
|
||||||
|
|
||||||
#
|
#
|
||||||
# Lenovo X230 (LCD) LVDS
|
# Lenovo X230 (LCD) LVDS
|
||||||
#
|
#
|
||||||
|
|
|
@ -71,6 +71,12 @@ case *.vac
|
||||||
vacfs -m /n/`{basename $1 .vac} `{cat $score}
|
vacfs -m /n/`{basename $1 .vac} `{cat $score}
|
||||||
case wiki
|
case wiki
|
||||||
srv -m 'net!plan9.bell-labs.com!wiki' wiki /mnt/wiki
|
srv -m 'net!plan9.bell-labs.com!wiki' wiki /mnt/wiki
|
||||||
|
case ingenic
|
||||||
|
ftpfs -qKm /n/ingenic -a $user@$sysname ftp.ingenic.com
|
||||||
|
case kernel
|
||||||
|
ftpfs -qKm /n/kernel -a $user@sysname ftp.kernel.org
|
||||||
|
case qrstuv
|
||||||
|
srv -nqmC tcp!fs.9paste.net qrstuv
|
||||||
case *
|
case *
|
||||||
switch($#*){
|
switch($#*){
|
||||||
case 1
|
case 1
|
||||||
|
|
16
rc/bin/E
Executable file
16
rc/bin/E
Executable file
|
@ -0,0 +1,16 @@
|
||||||
|
#!/bin/rc
|
||||||
|
# E file - B file, wait until it changes, exit
|
||||||
|
rfork e
|
||||||
|
if (! ~ $#* 1) {
|
||||||
|
echo usage: $0 file >[1=2]
|
||||||
|
exit usage
|
||||||
|
}
|
||||||
|
if (! test -e $1) {
|
||||||
|
echo $0: $1: no such file >[1=2]
|
||||||
|
exit no-file
|
||||||
|
}
|
||||||
|
otm = `{mtime $1 | awk '{print $1}'}
|
||||||
|
B $1
|
||||||
|
while (~ $otm `{mtime $1 | awk '{print $1}'})
|
||||||
|
sleep 1
|
||||||
|
exit ''
|
|
@ -1,2 +1,2 @@
|
||||||
#!/bin/rc
|
#!/bin/rc
|
||||||
exec /rc/bin/ape/grep $*
|
exec /$objtype/bin/ape/grep -E $*
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
#!/bin/rc
|
#!/bin/rc
|
||||||
exec /rc/bin/ape/grep $*
|
exec /$objtype/bin/ape/grep -F $*
|
||||||
|
|
|
@ -20,4 +20,4 @@ if(~ $force n && test -e $2){
|
||||||
exit 'usage'
|
exit 'usage'
|
||||||
}
|
}
|
||||||
|
|
||||||
exec cp -gux $1 $2
|
exec cp -R $1 $2
|
||||||
|
|
|
@ -55,18 +55,22 @@ if(test -r /net/ipselftab){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(! test -e /net/dns)
|
if(! test -e /net/dns){
|
||||||
|
echo dns...
|
||||||
ndb/dns -r
|
ndb/dns -r
|
||||||
|
}
|
||||||
|
|
||||||
|
echo timesync...
|
||||||
if(! ps|grep -s timesync){
|
if(! ps|grep -s timesync){
|
||||||
if(~ $#ntp 0)
|
if(~ $#ntp 0)
|
||||||
. <{ndb/ipquery sys $sysname ntp | sed 's, +,\n,g'}
|
. <{ndb/ipquery sys $sysname ntp | sed 's, +,\n,g'}
|
||||||
if(~ $#ntp 0)
|
if(~ $#ntp 0)
|
||||||
ntp=pool.ntp.org
|
ntp=pool.ntp.org
|
||||||
aux/timesync -n $ntp
|
#aux/timesync -n $ntp
|
||||||
sleep 2
|
sleep 2
|
||||||
}
|
}
|
||||||
|
|
||||||
|
echo listen...
|
||||||
if(~ $#auth 0){
|
if(~ $#auth 0){
|
||||||
auth=`{ndb/query sys $sysname auth}
|
auth=`{ndb/query sys $sysname auth}
|
||||||
. <{ndb/ipquery sys $sysname auth | sed 's, +,\n,g'}
|
. <{ndb/ipquery sys $sysname auth | sed 's, +,\n,g'}
|
||||||
|
@ -89,6 +93,7 @@ case *
|
||||||
if(test -f /dev/apm)
|
if(test -f /dev/apm)
|
||||||
aux/apm
|
aux/apm
|
||||||
|
|
||||||
|
echo cpustart...
|
||||||
if(test -e /cfg/$sysname/cpustart)
|
if(test -e /cfg/$sysname/cpustart)
|
||||||
. /cfg/$sysname/cpustart
|
. /cfg/$sysname/cpustart
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
#!/bin/rc
|
#!/bin/rc
|
||||||
netdir=`{echo $3 | sed 's;/[0-9]+$;!*!0;'}
|
#netdir=`{echo $3 | sed 's;/[0-9]+$;!*!0;'}
|
||||||
exec /bin/cpu -A $netdir -R
|
#exec /bin/cpu -A $netdir -R
|
||||||
|
exec /bin/cpu -R
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#!/bin/rc
|
#!/bin/rc
|
||||||
rfork en
|
rfork en
|
||||||
source=https://code.9front.org/hg/plan9front
|
|
||||||
cd /
|
cd /
|
||||||
if(! test -d .hg)
|
if(! test -d .hg)
|
||||||
bind -ac /dist/plan9front /
|
bind -ac /dist/plan9front /
|
||||||
|
|
|
@ -403,6 +403,16 @@ PEMChain*readcertchain(char *filename);
|
||||||
int aes_xts_encrypt(ulong tweak[], ulong ecb[], vlong sectorNumber, uchar *input, uchar *output, ulong len) ;
|
int aes_xts_encrypt(ulong tweak[], ulong ecb[], vlong sectorNumber, uchar *input, uchar *output, ulong len) ;
|
||||||
int aes_xts_decrypt(ulong tweak[], ulong ecb[], vlong sectorNumber, uchar *input, uchar *output, ulong len);
|
int aes_xts_decrypt(ulong tweak[], ulong ecb[], vlong sectorNumber, uchar *input, uchar *output, ulong len);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ECC
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* ids for ecnamedcurve */
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
Secp256r1 = 23,
|
||||||
|
};
|
||||||
|
|
||||||
typedef struct ECpoint{
|
typedef struct ECpoint{
|
||||||
int inf;
|
int inf;
|
||||||
mpint *x;
|
mpint *x;
|
||||||
|
@ -424,10 +434,15 @@ typedef struct ECdomain{
|
||||||
mpint *h;
|
mpint *h;
|
||||||
} ECdomain;
|
} ECdomain;
|
||||||
|
|
||||||
|
ECdomain* ecnamedcurve(int);
|
||||||
|
void ecfreepoint(ECpoint*);
|
||||||
|
void ecfreepriv(ECpriv*);
|
||||||
|
void ecfreedomain(ECdomain*);
|
||||||
void ecassign(ECdomain *, ECpoint *old, ECpoint *new);
|
void ecassign(ECdomain *, ECpoint *old, ECpoint *new);
|
||||||
void ecadd(ECdomain *, ECpoint *a, ECpoint *b, ECpoint *s);
|
void ecadd(ECdomain *, ECpoint *a, ECpoint *b, ECpoint *s);
|
||||||
void ecmul(ECdomain *, ECpoint *a, mpint *k, ECpoint *s);
|
void ecmul(ECdomain *, ECpoint *a, mpint *k, ECpoint *s);
|
||||||
ECpoint* strtoec(ECdomain *, char *, char **, ECpoint *);
|
ECpoint* betoec(ECdomain*, uchar*, int, ECpoint*);
|
||||||
|
ECpoint* strtoec(ECdomain *, char *, char **, ECpoint*);
|
||||||
ECpriv* ecgen(ECdomain *, ECpriv*);
|
ECpriv* ecgen(ECdomain *, ECpriv*);
|
||||||
int ecverify(ECdomain *, ECpoint *);
|
int ecverify(ECdomain *, ECpoint *);
|
||||||
int ecpubverify(ECdomain *, ECpub *);
|
int ecpubverify(ECdomain *, ECpub *);
|
||||||
|
@ -457,5 +472,8 @@ mpint* dh_new(DHstate *dh, mpint *p, mpint *g);
|
||||||
/* calculate shared key: k = pub ^ x % p */
|
/* calculate shared key: k = pub ^ x % p */
|
||||||
mpint* dh_finish(DHstate *dh, mpint *pub);
|
mpint* dh_finish(DHstate *dh, mpint *pub);
|
||||||
|
|
||||||
|
/* constant-time comparison similar to memcmp(2) */
|
||||||
|
int constcmp(uchar *x, uchar *y, int len);
|
||||||
|
|
||||||
/* password-based key derivation function 2 (RFC 2898) */
|
/* password-based key derivation function 2 (RFC 2898) */
|
||||||
void pbkdf2_hmac_sha1(uchar *p, ulong plen, uchar *s, ulong slen, ulong rounds, uchar *d, ulong dlen);
|
void pbkdf2_hmac_sha1(uchar *p, ulong plen, uchar *s, ulong slen, ulong rounds, uchar *d, ulong dlen);
|
||||||
|
|
|
@ -246,7 +246,7 @@ class fncache(object):
|
||||||
'''fill the entries from the fncache file'''
|
'''fill the entries from the fncache file'''
|
||||||
self.entries = set()
|
self.entries = set()
|
||||||
try:
|
try:
|
||||||
fp = self.opener('fncache', mode='rb')
|
fp = self.opener('fncache', mode='r')
|
||||||
except IOError:
|
except IOError:
|
||||||
# skip nonexistent file
|
# skip nonexistent file
|
||||||
return
|
return
|
||||||
|
|
|
@ -763,7 +763,7 @@ def mktempcopy(name, emptyok=False, createmode=None):
|
||||||
return temp
|
return temp
|
||||||
try:
|
try:
|
||||||
try:
|
try:
|
||||||
ifp = posixfile(name, "rb")
|
ifp = posixfile(name, "r")
|
||||||
except IOError, inst:
|
except IOError, inst:
|
||||||
if inst.errno == errno.ENOENT:
|
if inst.errno == errno.ENOENT:
|
||||||
return temp
|
return temp
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
enum {
|
enum {
|
||||||
Debug = 0,
|
Debug = 1,
|
||||||
};
|
};
|
||||||
|
|
||||||
extern void fatal(char*);
|
extern void fatal(char*);
|
||||||
|
|
|
@ -30,12 +30,15 @@ $objtype
|
||||||
ndb
|
ndb
|
||||||
dnsgetip
|
dnsgetip
|
||||||
hjfs
|
hjfs
|
||||||
|
p
|
||||||
|
ps
|
||||||
rc
|
rc
|
||||||
rm
|
rm
|
||||||
sed
|
sed
|
||||||
sleep
|
sleep
|
||||||
srv
|
srv
|
||||||
test
|
test
|
||||||
|
tlsclient
|
||||||
unmount
|
unmount
|
||||||
nusb
|
nusb
|
||||||
usbd
|
usbd
|
||||||
|
|
|
@ -66,7 +66,7 @@ fn main{
|
||||||
if(~ $#nobootprompt 0){
|
if(~ $#nobootprompt 0){
|
||||||
echo
|
echo
|
||||||
showlocaldevs
|
showlocaldevs
|
||||||
ask bootargs ' is (tcp, il, local!device)' $"bootargs
|
ask bootargs ' is (tcp, tcptls, il, local!device)' $"bootargs
|
||||||
}
|
}
|
||||||
if not bootargs=$nobootprompt
|
if not bootargs=$nobootprompt
|
||||||
nobootprompt=()
|
nobootprompt=()
|
||||||
|
|
|
@ -48,6 +48,12 @@ fn connecttcp{
|
||||||
fs=$fs(1)
|
fs=$fs(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn connecttcptls{
|
||||||
|
while(! ~ $#fs 0 && ! srv -qe 'tlsclient -t <{echo $fsthumb} tcp!'^$fs(1)^!5564 boot)
|
||||||
|
fs=$fs(2-);
|
||||||
|
fs=$fs(1)
|
||||||
|
}
|
||||||
|
|
||||||
fn connectil{
|
fn connectil{
|
||||||
while(! ~ $#fs 0 && ! srv -q il!$fs(1)^!17008 boot)
|
while(! ~ $#fs 0 && ! srv -q il!$fs(1)^!17008 boot)
|
||||||
fs=$fs(2-);
|
fs=$fs(2-);
|
||||||
|
@ -55,5 +61,7 @@ fn connectil{
|
||||||
}
|
}
|
||||||
|
|
||||||
mtcp=(confignet connecttcp)
|
mtcp=(confignet connecttcp)
|
||||||
|
mtcptls=(confignet connecttcptls)
|
||||||
mil=(confignet connectil)
|
mil=(confignet connectil)
|
||||||
mt=(mtcp mil $mt)
|
mt=(mtcp mtcptls mil $mt)
|
||||||
|
|
||||||
|
|
|
@ -2164,8 +2164,10 @@ iwlrecover(void *arg)
|
||||||
if(ctlr->power)
|
if(ctlr->power)
|
||||||
poweroff(ctlr);
|
poweroff(ctlr);
|
||||||
|
|
||||||
if((csr32r(ctlr, Gpc) & RfKill) == 0)
|
if((csr32r(ctlr, Gpc) & RfKill) == 0){
|
||||||
|
print("#l%d: rfkill on, not resetting\n", edev->ctlrno);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if(reset(ctlr) != nil)
|
if(reset(ctlr) != nil)
|
||||||
break;
|
break;
|
||||||
|
@ -2447,6 +2449,7 @@ iwlpci(void)
|
||||||
case 0x4238: /* Centrino Ultimate-N 6300 variant 2 */
|
case 0x4238: /* Centrino Ultimate-N 6300 variant 2 */
|
||||||
case 0x08ae: /* Centrino Wireless-N 100 */
|
case 0x08ae: /* Centrino Wireless-N 100 */
|
||||||
case 0x0083: /* Centrino Wireless-N 1000 */
|
case 0x0083: /* Centrino Wireless-N 1000 */
|
||||||
|
case 0x0891: /* Centrino Wireless-N 2200 */
|
||||||
case 0x0887: /* Centrino Wireless-N 2230 */
|
case 0x0887: /* Centrino Wireless-N 2230 */
|
||||||
case 0x0888: /* Centrino Wireless-N 2230 */
|
case 0x0888: /* Centrino Wireless-N 2230 */
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -152,8 +152,10 @@ chandevreset(void)
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
todinit(); /* avoid later reentry causing infinite recursion */
|
todinit(); /* avoid later reentry causing infinite recursion */
|
||||||
for(i=0; devtab[i] != nil; i++)
|
for(i=0; devtab[i] != nil; i++){
|
||||||
|
//print("%c: %s: reset\n", devtab[i]->dc, devtab[i]->name);
|
||||||
devtab[i]->reset();
|
devtab[i]->reset();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void closeproc(void*);
|
static void closeproc(void*);
|
||||||
|
|
|
@ -1439,7 +1439,7 @@ checkdigestb(Dstate *s, Block *bin)
|
||||||
*p = n;
|
*p = n;
|
||||||
(*s->hf)(msgid, 4, digest, &ss);
|
(*s->hf)(msgid, 4, digest, &ss);
|
||||||
|
|
||||||
if(memcmp(digest, bin->rp, s->diglen) != 0)
|
if(constcmp(digest, bin->rp, s->diglen) != 0)
|
||||||
error("bad digest");
|
error("bad digest");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -825,7 +825,7 @@ if(tr->debug) pdump(unpad_len, p, "decrypted:");
|
||||||
(*tr->packMac)(in->sec, in->sec->mackey, seq, header, p, len, hmac);
|
(*tr->packMac)(in->sec, in->sec->mackey, seq, header, p, len, hmac);
|
||||||
if(unpad_len < in->sec->maclen)
|
if(unpad_len < in->sec->maclen)
|
||||||
rcvError(tr, EBadRecordMac, "short record mac");
|
rcvError(tr, EBadRecordMac, "short record mac");
|
||||||
if(memcmp(hmac, p+len, in->sec->maclen) != 0)
|
if(constcmp(hmac, p+len, in->sec->maclen) != 0)
|
||||||
rcvError(tr, EBadRecordMac, "record mac mismatch");
|
rcvError(tr, EBadRecordMac, "record mac mismatch");
|
||||||
b->rp = p;
|
b->rp = p;
|
||||||
b->wp = p+len;
|
b->wp = p+len;
|
||||||
|
|
|
@ -173,6 +173,9 @@ sched(void)
|
||||||
up->state = Running;
|
up->state = Running;
|
||||||
up->mach = MACHP(m->machno);
|
up->mach = MACHP(m->machno);
|
||||||
m->proc = up;
|
m->proc = up;
|
||||||
|
//print("poolcheck sched %s\n", p->text);
|
||||||
|
//#include <pool.h>
|
||||||
|
//poolcheck(mainmem);
|
||||||
mmuswitch(up);
|
mmuswitch(up);
|
||||||
gotolabel(&up->sched);
|
gotolabel(&up->sched);
|
||||||
}
|
}
|
||||||
|
|
|
@ -114,7 +114,7 @@ syscallfmt(ulong syscallno, uintptr pc, va_list list)
|
||||||
a = va_arg(list, char*);
|
a = va_arg(list, char*);
|
||||||
fmtuserstring(&fmt, a, "");
|
fmtuserstring(&fmt, a, "");
|
||||||
argv = va_arg(list, char**);
|
argv = va_arg(list, char**);
|
||||||
evenaddr(PTR2UINT(argv));
|
evenaddr((uintptr)argv);
|
||||||
for(;;){
|
for(;;){
|
||||||
validaddr((uintptr)argv, sizeof(char**), 0);
|
validaddr((uintptr)argv, sizeof(char**), 0);
|
||||||
a = *(char **)argv;
|
a = *(char **)argv;
|
||||||
|
|
|
@ -10,7 +10,6 @@ char *trivial[] = {
|
||||||
"change me",
|
"change me",
|
||||||
"passwd",
|
"passwd",
|
||||||
"no passwd",
|
"no passwd",
|
||||||
"anonymous",
|
|
||||||
0
|
0
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include <bio.h>
|
#include <bio.h>
|
||||||
#include <ndb.h>
|
#include <ndb.h>
|
||||||
#include <thread.h>
|
#include <thread.h>
|
||||||
|
#include <9p.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This fs presents a 1 level file system. It contains
|
* This fs presents a 1 level file system. It contains
|
||||||
|
@ -12,7 +13,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
typedef struct Console Console;
|
typedef struct Console Console;
|
||||||
typedef struct Fid Fid;
|
typedef struct Aux Aux;
|
||||||
typedef struct Request Request;
|
typedef struct Request Request;
|
||||||
typedef struct Reqlist Reqlist;
|
typedef struct Reqlist Reqlist;
|
||||||
typedef struct Fs Fs;
|
typedef struct Fs Fs;
|
||||||
|
@ -28,7 +29,7 @@ enum
|
||||||
|
|
||||||
Bufsize= 32*1024, /* chars buffered per reader */
|
Bufsize= 32*1024, /* chars buffered per reader */
|
||||||
Maxcons= 64, /* maximum consoles */
|
Maxcons= 64, /* maximum consoles */
|
||||||
Nhash= 64, /* Fid hash buckets */
|
Nhash= 64, /* Aux hash buckets */
|
||||||
};
|
};
|
||||||
|
|
||||||
#define TYPE(x) (((ulong)x.path) & 0xf)
|
#define TYPE(x) (((ulong)x.path) & 0xf)
|
||||||
|
@ -38,7 +39,7 @@ enum
|
||||||
struct Request
|
struct Request
|
||||||
{
|
{
|
||||||
Request *next;
|
Request *next;
|
||||||
Fid *fid;
|
Aux *fid;
|
||||||
Fs *fs;
|
Fs *fs;
|
||||||
Fcall f;
|
Fcall f;
|
||||||
uchar buf[1];
|
uchar buf[1];
|
||||||
|
@ -51,11 +52,11 @@ struct Reqlist
|
||||||
Request *last;
|
Request *last;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Fid
|
struct Aux
|
||||||
{
|
{
|
||||||
Lock;
|
Lock;
|
||||||
Fid *next; /* hash list */
|
Aux *next; /* hash list */
|
||||||
Fid *cnext; /* list of Fid's on a console */
|
Aux *cnext; /* list of Aux's on a console */
|
||||||
int fid;
|
int fid;
|
||||||
int ref;
|
int ref;
|
||||||
|
|
||||||
|
@ -93,7 +94,7 @@ struct Console
|
||||||
int cfd;
|
int cfd;
|
||||||
int sfd;
|
int sfd;
|
||||||
|
|
||||||
Fid *flist; /* open fids to broadcast to */
|
Aux *flist; /* open fids to broadcast to */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Fs
|
struct Fs
|
||||||
|
@ -102,7 +103,7 @@ struct Fs
|
||||||
|
|
||||||
int fd; /* to kernel mount point */
|
int fd; /* to kernel mount point */
|
||||||
int messagesize;
|
int messagesize;
|
||||||
Fid *hash[Nhash];
|
Aux *hash[Nhash];
|
||||||
Console *cons[Maxcons];
|
Console *cons[Maxcons];
|
||||||
int ncons;
|
int ncons;
|
||||||
};
|
};
|
||||||
|
@ -112,30 +113,30 @@ extern Fs* fsmount(char*);
|
||||||
|
|
||||||
extern void fsreader(void*);
|
extern void fsreader(void*);
|
||||||
extern void fsrun(void*);
|
extern void fsrun(void*);
|
||||||
extern Fid* fsgetfid(Fs*, int);
|
extern Aux* fsgetfid(Fs*, int);
|
||||||
extern void fsputfid(Fs*, Fid*);
|
extern void fsputfid(Fs*, Aux*);
|
||||||
extern int fsdirgen(Fs*, Qid, int, Dir*, uchar*, int);
|
extern int fsdirgen(Fs*, Qid, int, Dir*, uchar*, int);
|
||||||
extern void fsreply(Fs*, Request*, char*);
|
extern void fsreply(Fs*, Request*, char*);
|
||||||
extern void fskick(Fs*, Fid*);
|
extern void fskick(Fs*, Aux*);
|
||||||
extern int fsreopen(Fs*, Console*);
|
extern int fsreopen(Fs*, Console*);
|
||||||
|
|
||||||
extern void fsversion(Fs*, Request*, Fid*);
|
extern void fsversion(Fs*, Request*, Aux*);
|
||||||
extern void fsflush(Fs*, Request*, Fid*);
|
extern void fsflush(Fs*, Request*, Aux*);
|
||||||
extern void fsauth(Fs*, Request*, Fid*);
|
extern void fsauth(Fs*, Request*, Aux*);
|
||||||
extern void fsattach(Fs*, Request*, Fid*);
|
extern void fsattach(Fs*, Request*, Aux*);
|
||||||
extern void fswalk(Fs*, Request*, Fid*);
|
extern void fswalk(Fs*, Request*, Aux*);
|
||||||
extern void fsclwalk(Fs*, Request*, Fid*);
|
extern void fsclwalk(Fs*, Request*, Aux*);
|
||||||
extern void fsopen(Fs*, Request*, Fid*);
|
extern void fsopen(Fs*, Request*, Aux*);
|
||||||
extern void fscreate(Fs*, Request*, Fid*);
|
extern void fscreate(Fs*, Request*, Aux*);
|
||||||
extern void fsread(Fs*, Request*, Fid*);
|
extern void fsread(Fs*, Request*, Aux*);
|
||||||
extern void fswrite(Fs*, Request*, Fid*);
|
extern void fswrite(Fs*, Request*, Aux*);
|
||||||
extern void fsclunk(Fs*, Request*, Fid*);
|
extern void fsclunk(Fs*, Request*, Aux*);
|
||||||
extern void fsremove(Fs*, Request*, Fid*);
|
extern void fsremove(Fs*, Request*, Aux*);
|
||||||
extern void fsstat(Fs*, Request*, Fid*);
|
extern void fsstat(Fs*, Request*, Aux*);
|
||||||
extern void fswstat(Fs*, Request*, Fid*);
|
extern void fswstat(Fs*, Request*, Aux*);
|
||||||
|
|
||||||
|
|
||||||
void (*fcall[])(Fs*, Request*, Fid*) =
|
void (*fcall[])(Fs*, Request*, Aux*) =
|
||||||
{
|
{
|
||||||
[Tflush] fsflush,
|
[Tflush] fsflush,
|
||||||
[Tversion] fsversion,
|
[Tversion] fsversion,
|
||||||
|
@ -199,7 +200,7 @@ Ndb *db;
|
||||||
* any request that can get queued for a delayed reply
|
* any request that can get queued for a delayed reply
|
||||||
*/
|
*/
|
||||||
Request*
|
Request*
|
||||||
allocreq(Fs *fs, int bufsize)
|
alloccreq(Fs *fs, int bufsize)
|
||||||
{
|
{
|
||||||
Request *r;
|
Request *r;
|
||||||
|
|
||||||
|
@ -343,10 +344,10 @@ fsdirgen(Fs *fs, Qid parent, int i, Dir *d, uchar *buf, int nbuf)
|
||||||
Fs*
|
Fs*
|
||||||
fsmount(char *mntpt)
|
fsmount(char *mntpt)
|
||||||
{
|
{
|
||||||
|
int pfd[2];
|
||||||
|
|
||||||
Fs *fs;
|
Fs *fs;
|
||||||
int pfd[2], srv;
|
Dir d;
|
||||||
char buf[32];
|
|
||||||
int n;
|
|
||||||
static void *v[2];
|
static void *v[2];
|
||||||
|
|
||||||
fs = emalloc(sizeof(Fs));
|
fs = emalloc(sizeof(Fs));
|
||||||
|
@ -359,21 +360,19 @@ fsmount(char *mntpt)
|
||||||
v[1] = pfd;
|
v[1] = pfd;
|
||||||
proccreate(fsrun, v, 16*1024);
|
proccreate(fsrun, v, 16*1024);
|
||||||
|
|
||||||
/* Typically mounted before /srv exists */
|
if(postfd("consoles", pfd[1]) < 0)
|
||||||
if(access("#s/consoles", AEXIST) < 0){
|
sysfatal("post: %r");
|
||||||
srv = create("#s/consoles", OWRITE, 0666);
|
|
||||||
if(srv < 0)
|
|
||||||
fatal("post: %r");
|
|
||||||
|
|
||||||
n = sprint(buf, "%d", pfd[1]);
|
nulldir(&d);
|
||||||
if(write(srv, buf, n) < 0)
|
d.mode = 0666;
|
||||||
fatal("write srv: %r");
|
dirwstat("/srv/consoles", &d);
|
||||||
|
|
||||||
close(srv);
|
if(mntpt){
|
||||||
}
|
if(amount(pfd[1], mntpt, MBEFORE, "") == -1)
|
||||||
|
sysfatal("mount %s: %r", mntpt);
|
||||||
mount(pfd[1], -1, mntpt, MBEFORE, "");
|
}else
|
||||||
close(pfd[1]);
|
close(pfd[1]);
|
||||||
|
|
||||||
return fs;
|
return fs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -516,7 +515,7 @@ console(Fs* fs, char *name, char *dev, int speed, int cronly, int ondemand)
|
||||||
* the reader may miss data but always sees an in order sequence.
|
* the reader may miss data but always sees an in order sequence.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
fromconsole(Fid *f, char *p, int n)
|
fromconsole(Aux *f, char *p, int n)
|
||||||
{
|
{
|
||||||
char *rp, *wp, *ep;
|
char *rp, *wp, *ep;
|
||||||
int pass;
|
int pass;
|
||||||
|
@ -552,10 +551,10 @@ fromconsole(Fid *f, char *p, int n)
|
||||||
* broadcast a list of members to all listeners
|
* broadcast a list of members to all listeners
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
bcastmembers(Fs *fs, Console *c, char *msg, Fid *f)
|
bcastmembers(Fs *fs, Console *c, char *msg, Aux *f)
|
||||||
{
|
{
|
||||||
int n;
|
int n;
|
||||||
Fid *fl;
|
Aux *fl;
|
||||||
char buf[512];
|
char buf[512];
|
||||||
|
|
||||||
sprint(buf, "[%s%s", msg, f->user);
|
sprint(buf, "[%s%s", msg, f->user);
|
||||||
|
@ -590,7 +589,7 @@ void
|
||||||
fsreader(void *v)
|
fsreader(void *v)
|
||||||
{
|
{
|
||||||
int n;
|
int n;
|
||||||
Fid *fl;
|
Aux *fl;
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
Fs *fs;
|
Fs *fs;
|
||||||
Console *c;
|
Console *c;
|
||||||
|
@ -653,8 +652,6 @@ readdb(Fs *fs)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int dbmtime;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* a request processor (one per Fs)
|
* a request processor (one per Fs)
|
||||||
*/
|
*/
|
||||||
|
@ -663,8 +660,7 @@ fsrun(void *v)
|
||||||
{
|
{
|
||||||
int n, t;
|
int n, t;
|
||||||
Request *r;
|
Request *r;
|
||||||
Fid *f;
|
Aux *f;
|
||||||
Dir *d;
|
|
||||||
void **a = v;
|
void **a = v;
|
||||||
Fs* fs;
|
Fs* fs;
|
||||||
int *pfd;
|
int *pfd;
|
||||||
|
@ -672,15 +668,12 @@ fsrun(void *v)
|
||||||
fs = a[0];
|
fs = a[0];
|
||||||
pfd = a[1];
|
pfd = a[1];
|
||||||
fs->fd = pfd[0];
|
fs->fd = pfd[0];
|
||||||
|
readdb(fs);
|
||||||
notify(handler);
|
notify(handler);
|
||||||
for(;;){
|
for(;;){
|
||||||
d = dirstat(consoledb);
|
if(ndbchanged(db))
|
||||||
if(d != nil && d->mtime != dbmtime){
|
|
||||||
dbmtime = d->mtime;
|
|
||||||
readdb(fs);
|
readdb(fs);
|
||||||
}
|
r = alloccreq(fs, messagesize);
|
||||||
free(d);
|
|
||||||
r = allocreq(fs, messagesize);
|
|
||||||
while((n = read9pmsg(fs->fd, r->buf, messagesize)) == 0)
|
while((n = read9pmsg(fs->fd, r->buf, messagesize)) == 0)
|
||||||
;
|
;
|
||||||
if(n < 0)
|
if(n < 0)
|
||||||
|
@ -705,10 +698,10 @@ fsrun(void *v)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Fid*
|
Aux*
|
||||||
fsgetfid(Fs *fs, int fid)
|
fsgetfid(Fs *fs, int fid)
|
||||||
{
|
{
|
||||||
Fid *f, *nf;
|
Aux *f, *nf;
|
||||||
|
|
||||||
lock(fs);
|
lock(fs);
|
||||||
for(f = fs->hash[fid%Nhash]; f; f = f->next){
|
for(f = fs->hash[fid%Nhash]; f; f = f->next){
|
||||||
|
@ -719,7 +712,7 @@ fsgetfid(Fs *fs, int fid)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
nf = emalloc(sizeof(Fid));
|
nf = emalloc(sizeof(Aux));
|
||||||
nf->next = fs->hash[fid%Nhash];
|
nf->next = fs->hash[fid%Nhash];
|
||||||
fs->hash[fid%Nhash] = nf;
|
fs->hash[fid%Nhash] = nf;
|
||||||
nf->fid = fid;
|
nf->fid = fid;
|
||||||
|
@ -731,9 +724,9 @@ fsgetfid(Fs *fs, int fid)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsputfid(Fs *fs, Fid *f)
|
fsputfid(Fs *fs, Aux *f)
|
||||||
{
|
{
|
||||||
Fid **l, *nf;
|
Aux **l, *nf;
|
||||||
|
|
||||||
lock(fs);
|
lock(fs);
|
||||||
if(--f->ref > 0){
|
if(--f->ref > 0){
|
||||||
|
@ -751,13 +744,13 @@ fsputfid(Fs *fs, Fid *f)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsauth(Fs *fs, Request *r, Fid*)
|
fsauth(Fs *fs, Request *r, Aux*)
|
||||||
{
|
{
|
||||||
fsreply(fs, r, "consolefs: authentication not required");
|
fsreply(fs, r, "consolefs: authentication not required");
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsversion(Fs *fs, Request *r, Fid*)
|
fsversion(Fs *fs, Request *r, Aux*)
|
||||||
{
|
{
|
||||||
|
|
||||||
if(r->f.msize < 256){
|
if(r->f.msize < 256){
|
||||||
|
@ -778,7 +771,7 @@ fsversion(Fs *fs, Request *r, Fid*)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsflush(Fs *fs, Request *r, Fid *f)
|
fsflush(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
Request *or;
|
Request *or;
|
||||||
|
|
||||||
|
@ -786,12 +779,15 @@ fsflush(Fs *fs, Request *r, Fid *f)
|
||||||
if(or != nil){
|
if(or != nil){
|
||||||
fsputfid(fs, or->fid);
|
fsputfid(fs, or->fid);
|
||||||
free(or);
|
free(or);
|
||||||
}
|
|
||||||
fsreply(fs, r, nil);
|
fsreply(fs, r, nil);
|
||||||
|
} else {
|
||||||
|
fsputfid(fs, f);
|
||||||
|
free(r);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsattach(Fs *fs, Request *r, Fid *f)
|
fsattach(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
f->qid.type = QTDIR;
|
f->qid.type = QTDIR;
|
||||||
f->qid.path = QID(0, Ttopdir);
|
f->qid.path = QID(0, Ttopdir);
|
||||||
|
@ -813,13 +809,13 @@ fsattach(Fs *fs, Request *r, Fid *f)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fswalk(Fs *fs, Request *r, Fid *f)
|
fswalk(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
char *name;
|
char *name;
|
||||||
Dir d;
|
Dir d;
|
||||||
int i, n, nqid, nwname;
|
int i, n, nqid, nwname;
|
||||||
Qid qid, wqid[MAXWELEM];
|
Qid qid, wqid[MAXWELEM];
|
||||||
Fid *nf;
|
Aux *nf;
|
||||||
char *err;
|
char *err;
|
||||||
|
|
||||||
if(f->attached == 0){
|
if(f->attached == 0){
|
||||||
|
@ -932,7 +928,7 @@ int m2p[] ={
|
||||||
void
|
void
|
||||||
bcastmsg(Fs *fs, Console *c, char *msg, int n)
|
bcastmsg(Fs *fs, Console *c, char *msg, int n)
|
||||||
{
|
{
|
||||||
Fid *fl;
|
Aux *fl;
|
||||||
|
|
||||||
for(fl = c->flist; fl; fl = fl->cnext){
|
for(fl = c->flist; fl; fl = fl->cnext){
|
||||||
fromconsole(fl, msg, n);
|
fromconsole(fl, msg, n);
|
||||||
|
@ -941,7 +937,7 @@ bcastmsg(Fs *fs, Console *c, char *msg, int n)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsopen(Fs *fs, Request *r, Fid *f)
|
fsopen(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
int mode;
|
int mode;
|
||||||
Console *c;
|
Console *c;
|
||||||
|
@ -1009,13 +1005,13 @@ fsopen(Fs *fs, Request *r, Fid *f)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fscreate(Fs *fs, Request *r, Fid*)
|
fscreate(Fs *fs, Request *r, Aux*)
|
||||||
{
|
{
|
||||||
fsreply(fs, r, Eperm);
|
fsreply(fs, r, Eperm);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsread(Fs *fs, Request *r, Fid *f)
|
fsread(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
uchar *p, *e;
|
uchar *p, *e;
|
||||||
int i, m, off;
|
int i, m, off;
|
||||||
|
@ -1078,7 +1074,7 @@ fsread(Fs *fs, Request *r, Fid *f)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fswrite(Fs *fs, Request *r, Fid *f)
|
fswrite(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
int i, eol = 0;
|
int i, eol = 0;
|
||||||
|
|
||||||
|
@ -1141,9 +1137,9 @@ fswrite(Fs *fs, Request *r, Fid *f)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsclunk(Fs *fs, Request *r, Fid *f)
|
fsclunk(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
Fid **l, *fl;
|
Aux **l, *fl;
|
||||||
Request *nr;
|
Request *nr;
|
||||||
|
|
||||||
if(f->open && TYPE(f->qid) == Qdata){
|
if(f->open && TYPE(f->qid) == Qdata){
|
||||||
|
@ -1170,13 +1166,13 @@ fsclunk(Fs *fs, Request *r, Fid *f)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsremove(Fs *fs, Request *r, Fid*)
|
fsremove(Fs *fs, Request *r, Aux*)
|
||||||
{
|
{
|
||||||
fsreply(fs, r, Eperm);
|
fsreply(fs, r, Eperm);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fsstat(Fs *fs, Request *r, Fid *f)
|
fsstat(Fs *fs, Request *r, Aux *f)
|
||||||
{
|
{
|
||||||
int i, n;
|
int i, n;
|
||||||
Qid q;
|
Qid q;
|
||||||
|
@ -1198,7 +1194,7 @@ fsstat(Fs *fs, Request *r, Fid *f)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
fswstat(Fs *fs, Request *r, Fid*)
|
fswstat(Fs *fs, Request *r, Aux*)
|
||||||
{
|
{
|
||||||
fsreply(fs, r, Eperm);
|
fsreply(fs, r, Eperm);
|
||||||
}
|
}
|
||||||
|
@ -1226,7 +1222,7 @@ fsreply(Fs *fs, Request *r, char *err)
|
||||||
* called whenever input or a read request has been received
|
* called whenever input or a read request has been received
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
fskick(Fs *fs, Fid *f)
|
fskick(Fs *fs, Aux *f)
|
||||||
{
|
{
|
||||||
Request *r;
|
Request *r;
|
||||||
char *p, *rp, *wp, *ep;
|
char *p, *rp, *wp, *ep;
|
||||||
|
|
|
@ -224,7 +224,7 @@ main(int argc, char **argv)
|
||||||
if(system == nil) {
|
if(system == nil) {
|
||||||
p = getenv("cpu");
|
p = getenv("cpu");
|
||||||
if(p == 0)
|
if(p == 0)
|
||||||
fatal("set $cpu");
|
p = "$cpu";
|
||||||
system = p;
|
system = p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -33,13 +33,13 @@
|
||||||
|
|
||||||
/* ---------------- Cache sizes ---------------- */
|
/* ---------------- Cache sizes ---------------- */
|
||||||
|
|
||||||
#define ARCH_CACHE1_SIZE 131072
|
#define ARCH_CACHE1_SIZE 2097152
|
||||||
#define ARCH_CACHE2_SIZE 4194304
|
#define ARCH_CACHE2_SIZE 4194304
|
||||||
|
|
||||||
/* ---------------- Miscellaneous ---------------- */
|
/* ---------------- Miscellaneous ---------------- */
|
||||||
|
|
||||||
#define ARCH_IS_BIG_ENDIAN 0
|
#define ARCH_IS_BIG_ENDIAN 0
|
||||||
#define ARCH_PTRS_ARE_SIGNED 0
|
#define ARCH_PTRS_ARE_SIGNED 1
|
||||||
#define ARCH_FLOATS_ARE_IEEE 1
|
#define ARCH_FLOATS_ARE_IEEE 1
|
||||||
#define ARCH_ARITH_RSHIFT 2
|
#define ARCH_ARITH_RSHIFT 2
|
||||||
#define ARCH_CAN_SHIFT_FULL_LONG 0
|
#define ARCH_CAN_SHIFT_FULL_LONG 0
|
||||||
|
|
|
@ -240,10 +240,10 @@ static void
|
||||||
printtype(Hio *hout, HContent *type, HContent *enc)
|
printtype(Hio *hout, HContent *type, HContent *enc)
|
||||||
{
|
{
|
||||||
hprint(hout, "Content-Type: %s/%s", type->generic, type->specific);
|
hprint(hout, "Content-Type: %s/%s", type->generic, type->specific);
|
||||||
/*
|
|
||||||
if(cistrcmp(type->generic, "text") == 0)
|
if(cistrcmp(type->generic, "text") == 0)
|
||||||
hprint(hout, ";charset=utf-8");
|
hprint(hout, ";charset=utf-8");
|
||||||
*/
|
|
||||||
hprint(hout, "\r\n");
|
hprint(hout, "\r\n");
|
||||||
if(enc != nil)
|
if(enc != nil)
|
||||||
hprint(hout, "Content-Encoding: %s\r\n", enc->generic);
|
hprint(hout, "Content-Encoding: %s\r\n", enc->generic);
|
||||||
|
@ -351,6 +351,8 @@ checkreq(HConnect *c, HContent *type, HContent *enc, long mtime, char *etag)
|
||||||
if(c->req.vermaj >= 1 && c->req.vermin >= 1 && !hcheckcontent(enc, c->head.okencode, "Content-Encoding", 0))
|
if(c->req.vermaj >= 1 && c->req.vermin >= 1 && !hcheckcontent(enc, c->head.okencode, "Content-Encoding", 0))
|
||||||
return notaccept(c, type, enc, "Content-Encoding");
|
return notaccept(c, type, enc, "Content-Encoding");
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* can use weak match only with get or head;
|
* can use weak match only with get or head;
|
||||||
* this always uses strong matches
|
* this always uses strong matches
|
||||||
|
|
|
@ -54,6 +54,7 @@ enum
|
||||||
*/
|
*/
|
||||||
Bandtblksz = Bandtmtu - 40 - 8,
|
Bandtblksz = Bandtmtu - 40 - 8,
|
||||||
Bcavium = 1432, /* cavium's u-boot demands this size */
|
Bcavium = 1432, /* cavium's u-boot demands this size */
|
||||||
|
Bci20 = 1468, /* ci20 u-boot */
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct Opt Opt;
|
typedef struct Opt Opt;
|
||||||
|
@ -329,7 +330,7 @@ options(int fd, char *buf, int bufsz, char *file, ushort oper, char *p, int dlen
|
||||||
syslog(dbg, flog, "tftpd %d %s tsize is %,lld",
|
syslog(dbg, flog, "tftpd %d %s tsize is %,lld",
|
||||||
pid, file, size);
|
pid, file, size);
|
||||||
} else if (oper == Tftp_READ && cistrcmp(p, "blksize") == 0 &&
|
} else if (oper == Tftp_READ && cistrcmp(p, "blksize") == 0 &&
|
||||||
blksize > Bandtblksz && blksize != Bcavium) {
|
blksize > Bandtblksz && blksize != Bcavium && blksize != Bci20) {
|
||||||
*op->valp = blksize = Bandtblksz;
|
*op->valp = blksize = Bandtblksz;
|
||||||
olen = emitn(blksize, bp, ep);
|
olen = emitn(blksize, bp, ep);
|
||||||
syslog(dbg, flog, "tftpd %d overriding blksize to %d",
|
syslog(dbg, flog, "tftpd %d overriding blksize to %d",
|
||||||
|
|
|
@ -163,7 +163,7 @@ again: /* rogue processes */
|
||||||
uarg = 1;
|
uarg = 1;
|
||||||
} else {
|
} else {
|
||||||
jobs = 0;
|
jobs = 0;
|
||||||
Exit();
|
sysfatal("%s", buf);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(w = j->t; w; w = w->next){
|
for(w = j->t; w; w = w->next){
|
||||||
|
|
|
@ -12,4 +12,3 @@ snprint(char *buf, int len, char *fmt, ...)
|
||||||
va_end(args);
|
va_end(args);
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -164,7 +164,7 @@ controlsetthread(void *v)
|
||||||
Rune buf[2][20], *rp;
|
Rune buf[2][20], *rp;
|
||||||
|
|
||||||
cs = v;
|
cs = v;
|
||||||
threadsetname("controlsetthread 0x%p", cs);
|
threadsetname("controlsetthread %#p", cs);
|
||||||
|
|
||||||
alts[AKey].c = cs->kbdc;
|
alts[AKey].c = cs->kbdc;
|
||||||
alts[AKey].v = &rp;
|
alts[AKey].v = &rp;
|
||||||
|
@ -324,6 +324,7 @@ ctlerror(char *fmt, ...)
|
||||||
vfprint(2, fmt, arg);
|
vfprint(2, fmt, arg);
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
write(2, "\n", 1);
|
write(2, "\n", 1);
|
||||||
|
abort();
|
||||||
threadexitsall(buf);
|
threadexitsall(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -376,6 +377,8 @@ ctlstrdup(char *s)
|
||||||
t = strdup(s);
|
t = strdup(s);
|
||||||
if(t == nil)
|
if(t == nil)
|
||||||
ctlerror("control strdup(%q) failed: %r", s);
|
ctlerror("control strdup(%q) failed: %r", s);
|
||||||
|
|
||||||
|
setmalloctag(t, getcallerpc(&s));
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,4 +29,3 @@ newwindow(char *str)
|
||||||
return mount(fd, -1, "/dev", MBEFORE, buf);
|
return mount(fd, -1, "/dev", MBEFORE, buf);
|
||||||
return bind("/mnt/wsys", "/dev", MBEFORE);
|
return bind("/mnt/wsys", "/dev", MBEFORE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -836,6 +836,9 @@ format(char *mnemonic, Instr *i, char *f)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'm':
|
case 'm':
|
||||||
|
if(i->function != 0)
|
||||||
|
bprint(i, "M(%s),%d", cop0regs[i->rd], i->function);
|
||||||
|
else
|
||||||
bprint(i, "M(%s)", cop0regs[i->rd]);
|
bprint(i, "M(%s)", cop0regs[i->rd]);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
18
sys/src/libsec/port/const.c
Normal file
18
sys/src/libsec/port/const.c
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
#include <u.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* returns 0 if the the len bytes in x are equal to len bytes in y,
|
||||||
|
* otherwise returns -1.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
constcmp(uchar *x, uchar *y, int len)
|
||||||
|
{
|
||||||
|
uint z;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for(z = 0, i = 0; i < len; i++) {
|
||||||
|
z |= x[i] ^ y[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
return (1 & ((z - 1) >> 8)) - 1;
|
||||||
|
}
|
|
@ -3,6 +3,76 @@
|
||||||
#include <libsec.h>
|
#include <libsec.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
|
ECdomain *
|
||||||
|
ecnamedcurve(int id)
|
||||||
|
{
|
||||||
|
ECdomain *dom;
|
||||||
|
dom = malloc(sizeof(ECdomain));
|
||||||
|
if(dom == nil)
|
||||||
|
return nil;
|
||||||
|
|
||||||
|
switch(id) {
|
||||||
|
default:
|
||||||
|
free(dom);
|
||||||
|
return nil;
|
||||||
|
case Secp256r1:
|
||||||
|
dom->p = strtomp("FFFFFFFF00000001000000000000000000000000FFFFFFFFFFFFFFFFFFFFFFFF", nil, 16, nil);
|
||||||
|
dom->a = strtomp("FFFFFFFF00000001000000000000000000000000FFFFFFFFFFFFFFFFFFFFFFFC", nil, 16, nil);
|
||||||
|
dom->b = strtomp("5AC635D8AA3A93E7B3EBBD55769886BC651D06B0CC53B0F63BCE3C3E27D2604B", nil, 16, nil);
|
||||||
|
dom->G = strtoec(dom, "036B17D1F2E12C4247F8BCE6E563A440F277037D812DEB33A0F4A13945D898C296", nil, nil);
|
||||||
|
dom->n = strtomp("FFFFFFFF00000000FFFFFFFFFFFFFFFFBCE6FAADA7179E84F3B9CAC2FC632551", nil, 16, nil);
|
||||||
|
dom->h = uitomp(1, nil);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(dom->p == nil || dom->a == nil || dom->b == nil || dom->G == nil || dom->n == nil || dom->h == nil) {
|
||||||
|
ecfreedomain(dom);
|
||||||
|
return nil;
|
||||||
|
}
|
||||||
|
|
||||||
|
return dom;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ecfreepoint(ECpoint *pt)
|
||||||
|
{
|
||||||
|
if(pt != nil) {
|
||||||
|
mpfree(pt->x);
|
||||||
|
mpfree(pt->y);
|
||||||
|
}
|
||||||
|
|
||||||
|
free(pt);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ecfreepriv(ECpriv *priv)
|
||||||
|
{
|
||||||
|
if(priv != nil) {
|
||||||
|
mpfree(priv->x);
|
||||||
|
mpfree(priv->y);
|
||||||
|
mpfree(priv->d);
|
||||||
|
}
|
||||||
|
|
||||||
|
free(priv);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ecfreedomain(ECdomain *dom)
|
||||||
|
{
|
||||||
|
if(dom != nil) {
|
||||||
|
mpfree(dom->p);
|
||||||
|
mpfree(dom->a);
|
||||||
|
mpfree(dom->b);
|
||||||
|
if(dom->G != nil) {
|
||||||
|
ecfreepoint(dom->G);
|
||||||
|
}
|
||||||
|
mpfree(dom->n);
|
||||||
|
mpfree(dom->h);
|
||||||
|
}
|
||||||
|
|
||||||
|
free(dom);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
ecassign(ECdomain *, ECpoint *a, ECpoint *b)
|
ecassign(ECdomain *, ECpoint *a, ECpoint *b)
|
||||||
{
|
{
|
||||||
|
@ -329,6 +399,54 @@ mpsqrt(mpint *n, mpint *p, mpint *r)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// converts the bytes in buf to an ECpoint x y pair.
|
||||||
|
// the domain is used to determine the number of bytes in x and y in the buffer.
|
||||||
|
ECpoint*
|
||||||
|
betoec(ECdomain *dom, uchar *buf, int blen, ECpoint *ret)
|
||||||
|
{
|
||||||
|
int allocd, bytelen;
|
||||||
|
|
||||||
|
allocd = 0;
|
||||||
|
bytelen = (mpsignif(dom->p)+7) >> 3;
|
||||||
|
|
||||||
|
// sanity check arguments
|
||||||
|
if(dom == nil || buf == nil)
|
||||||
|
return nil;
|
||||||
|
|
||||||
|
// check if input is too short for two mpints
|
||||||
|
if(blen != 1+2*bytelen)
|
||||||
|
return nil;
|
||||||
|
|
||||||
|
// check that point is in uncompressed format
|
||||||
|
if(buf[0] != 4)
|
||||||
|
return nil;
|
||||||
|
|
||||||
|
if(ret == nil) {
|
||||||
|
// allocate return pointer and mpints
|
||||||
|
allocd = 1;
|
||||||
|
ret = mallocz(sizeof(*ret), 1);
|
||||||
|
if(ret == nil)
|
||||||
|
return nil;
|
||||||
|
ret->x = mpnew(0);
|
||||||
|
ret->y = mpnew(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// uncompressed form
|
||||||
|
if(betomp(buf+1, bytelen, ret->x) == nil)
|
||||||
|
goto err;
|
||||||
|
if(betomp(buf+1+bytelen, bytelen, ret->y) == nil)
|
||||||
|
goto err;
|
||||||
|
if(!ecverify(dom, ret))
|
||||||
|
goto err;
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
err:
|
||||||
|
if(allocd){
|
||||||
|
ecfreepoint(ret);
|
||||||
|
}
|
||||||
|
return nil;
|
||||||
|
}
|
||||||
|
|
||||||
ECpoint*
|
ECpoint*
|
||||||
strtoec(ECdomain *dom, char *s, char **rptr, ECpoint *ret)
|
strtoec(ECdomain *dom, char *s, char **rptr, ECpoint *ret)
|
||||||
{
|
{
|
||||||
|
@ -382,11 +500,8 @@ strtoec(ECdomain *dom, char *s, char **rptr, ECpoint *ret)
|
||||||
err:
|
err:
|
||||||
if(rptr)
|
if(rptr)
|
||||||
*rptr = s;
|
*rptr = s;
|
||||||
if(allocd){
|
if(allocd)
|
||||||
mpfree(ret->x);
|
ecfreepoint(ret);
|
||||||
mpfree(ret->y);
|
|
||||||
free(ret);
|
|
||||||
}
|
|
||||||
return nil;
|
return nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,7 @@ CFILES = des.c desmodes.c desECB.c desCBC.c des3ECB.c des3CBC.c\
|
||||||
ripemd.c\
|
ripemd.c\
|
||||||
dh.c\
|
dh.c\
|
||||||
pbkdf2.c\
|
pbkdf2.c\
|
||||||
|
const.c\
|
||||||
|
|
||||||
ALLOFILES=${CFILES:%.c=%.$O}
|
ALLOFILES=${CFILES:%.c=%.$O}
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@ okThumbprint(uchar *sum, Thumbprint *table)
|
||||||
return 0;
|
return 0;
|
||||||
hd = tablehead(sum, table);
|
hd = tablehead(sum, table);
|
||||||
for(p = hd->next; p; p = p->next){
|
for(p = hd->next; p; p = p->next){
|
||||||
if(memcmp(sum, p->sha1, SHA1dlen) == 0)
|
if(constcmp(sum, p->sha1, SHA1dlen) == 0)
|
||||||
return 1;
|
return 1;
|
||||||
if(p == hd)
|
if(p == hd)
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -854,99 +854,57 @@ ectobytes(int type, ECpoint *p)
|
||||||
static Bytes*
|
static Bytes*
|
||||||
tlsSecECDHEc(TlsSec *sec, uchar *srandom, int vers, int curve, Bytes *Ys)
|
tlsSecECDHEc(TlsSec *sec, uchar *srandom, int vers, int curve, Bytes *Ys)
|
||||||
{
|
{
|
||||||
Namedcurve *nc, *enc;
|
|
||||||
Bytes *epm;
|
Bytes *epm;
|
||||||
ECdomain dom;
|
ECdomain *dom;
|
||||||
ECpoint G, K, Y;
|
ECpoint K, *Y;
|
||||||
ECpriv Q;
|
ECpriv *Q;
|
||||||
|
|
||||||
|
epm = nil;
|
||||||
|
Y = nil;
|
||||||
|
Q = nil;
|
||||||
|
|
||||||
if(Ys == nil)
|
if(Ys == nil)
|
||||||
return nil;
|
return nil;
|
||||||
|
|
||||||
enc = &namedcurves[nelem(namedcurves)];
|
|
||||||
for(nc = namedcurves; nc != enc; nc++)
|
|
||||||
if(nc->tlsid == curve)
|
|
||||||
break;
|
|
||||||
|
|
||||||
if(nc == enc)
|
|
||||||
return nil;
|
|
||||||
|
|
||||||
memmove(sec->srandom, srandom, RandomSize);
|
memmove(sec->srandom, srandom, RandomSize);
|
||||||
if(setVers(sec, vers) < 0)
|
if(setVers(sec, vers) < 0)
|
||||||
return nil;
|
return nil;
|
||||||
|
|
||||||
epm = nil;
|
dom = ecnamedcurve(curve);
|
||||||
|
if(dom == nil)
|
||||||
|
return nil;
|
||||||
|
|
||||||
memset(&dom, 0, sizeof(dom));
|
|
||||||
dom.p = strtomp(nc->p, nil, 16, nil);
|
|
||||||
dom.a = strtomp(nc->a, nil, 16, nil);
|
|
||||||
dom.b = strtomp(nc->b, nil, 16, nil);
|
|
||||||
dom.n = strtomp(nc->n, nil, 16, nil);
|
|
||||||
dom.h = strtomp(nc->h, nil, 16, nil);
|
|
||||||
|
|
||||||
memset(&G, 0, sizeof(G));
|
|
||||||
G.x = mpnew(0);
|
|
||||||
G.y = mpnew(0);
|
|
||||||
|
|
||||||
memset(&Q, 0, sizeof(Q));
|
|
||||||
Q.x = mpnew(0);
|
|
||||||
Q.y = mpnew(0);
|
|
||||||
Q.d = mpnew(0);
|
|
||||||
|
|
||||||
memset(&K, 0, sizeof(K));
|
memset(&K, 0, sizeof(K));
|
||||||
K.x = mpnew(0);
|
K.x = mpnew(0);
|
||||||
K.y = mpnew(0);
|
K.y = mpnew(0);
|
||||||
|
|
||||||
memset(&Y, 0, sizeof(Y));
|
|
||||||
Y.x = mpnew(0);
|
|
||||||
Y.y = mpnew(0);
|
|
||||||
|
|
||||||
if(dom.p == nil || dom.a == nil || dom.b == nil || dom.n == nil || dom.h == nil)
|
|
||||||
goto Out;
|
|
||||||
if(Q.x == nil || Q.y == nil || Q.d == nil)
|
|
||||||
goto Out;
|
|
||||||
if(G.x == nil || G.y == nil)
|
|
||||||
goto Out;
|
|
||||||
if(K.x == nil || K.y == nil)
|
if(K.x == nil || K.y == nil)
|
||||||
goto Out;
|
goto Out;
|
||||||
if(Y.x == nil || Y.y == nil)
|
|
||||||
|
Y = betoec(dom, Ys->data, Ys->len, nil);
|
||||||
|
if(Y == nil)
|
||||||
goto Out;
|
goto Out;
|
||||||
|
|
||||||
dom.G = strtoec(&dom, nc->G, nil, &G);
|
Q = ecgen(dom, nil);
|
||||||
if(dom.G == nil)
|
if(Q == nil)
|
||||||
goto Out;
|
goto Out;
|
||||||
|
|
||||||
if(bytestoec(&dom, Ys, &Y) == nil)
|
ecmul(dom, Y, Q->d, &K);
|
||||||
goto Out;
|
|
||||||
|
|
||||||
if(ecgen(&dom, &Q) == nil)
|
|
||||||
goto Out;
|
|
||||||
|
|
||||||
ecmul(&dom, &Y, Q.d, &K);
|
|
||||||
setMasterSecret(sec, mptobytes(K.x));
|
setMasterSecret(sec, mptobytes(K.x));
|
||||||
|
|
||||||
/* 0x04 = uncompressed public key */
|
/* 0x04 = uncompressed public key */
|
||||||
epm = ectobytes(0x04, &Q);
|
epm = ectobytes(0x04, Q);
|
||||||
|
|
||||||
Out:
|
Out:
|
||||||
mpfree(Y.x);
|
ecfreepriv(Q);
|
||||||
mpfree(Y.y);
|
|
||||||
|
ecfreepoint(Y);
|
||||||
|
|
||||||
mpfree(K.x);
|
mpfree(K.x);
|
||||||
mpfree(K.y);
|
mpfree(K.y);
|
||||||
|
|
||||||
mpfree(Q.x);
|
ecfreedomain(dom);
|
||||||
mpfree(Q.y);
|
|
||||||
mpfree(Q.d);
|
|
||||||
|
|
||||||
mpfree(G.x);
|
|
||||||
mpfree(G.y);
|
|
||||||
|
|
||||||
mpfree(dom.p);
|
|
||||||
mpfree(dom.a);
|
|
||||||
mpfree(dom.b);
|
|
||||||
mpfree(dom.n);
|
|
||||||
mpfree(dom.h);
|
|
||||||
|
|
||||||
return epm;
|
return epm;
|
||||||
}
|
}
|
||||||
|
@ -1957,7 +1915,7 @@ setVersion(TlsConnection *c, int version)
|
||||||
static int
|
static int
|
||||||
finishedMatch(TlsConnection *c, Finished *f)
|
finishedMatch(TlsConnection *c, Finished *f)
|
||||||
{
|
{
|
||||||
return memcmp(f->verify, c->finished.verify, f->n) == 0;
|
return constcmp(f->verify, c->finished.verify, f->n) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// free memory associated with TlsConnection struct
|
// free memory associated with TlsConnection struct
|
||||||
|
|
|
@ -2212,7 +2212,7 @@ verify_signature(Bytes* signature, RSApub *pk, uchar *edigest, int edigestlen, E
|
||||||
err = "bad digest length";
|
err = "bad digest length";
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
if(memcmp(digest->data, edigest, edigestlen) != 0)
|
if(constcmp(digest->data, edigest, edigestlen) != 0)
|
||||||
err = "digests did not match";
|
err = "digests did not match";
|
||||||
|
|
||||||
end:
|
end:
|
||||||
|
|
|
@ -71,7 +71,7 @@ threadsetname(char *fmt, ...)
|
||||||
va_start(arg, fmt);
|
va_start(arg, fmt);
|
||||||
t->cmdname = vsmprint(fmt, arg);
|
t->cmdname = vsmprint(fmt, arg);
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
if(t->cmdname && p->nthreads == 1){
|
if(t->cmdname){
|
||||||
snprint(buf, sizeof buf, "#p/%lud/args", _tos->pid); //getpid());
|
snprint(buf, sizeof buf, "#p/%lud/args", _tos->pid); //getpid());
|
||||||
if((fd = open(buf, OWRITE)) >= 0){
|
if((fd = open(buf, OWRITE)) >= 0){
|
||||||
write(fd, t->cmdname, strlen(t->cmdname)+1);
|
write(fd, t->cmdname, strlen(t->cmdname)+1);
|
||||||
|
|
|
@ -31,7 +31,7 @@ main(int argc, char **argv)
|
||||||
if(setjmp(_mainjmp))
|
if(setjmp(_mainjmp))
|
||||||
_schedinit(p);
|
_schedinit(p);
|
||||||
|
|
||||||
//_threaddebuglevel = (DBGSCHED|DBGCHAN|DBGREND)^~0;
|
//_threaddebuglevel = (DBGSCHED|DBGCHAN|DBGREND);
|
||||||
_systhreadinit();
|
_systhreadinit();
|
||||||
_qlockinit(_threadrendezvous);
|
_qlockinit(_threadrendezvous);
|
||||||
_sysfatal = _threadsysfatal;
|
_sysfatal = _threadsysfatal;
|
||||||
|
|
Loading…
Reference in a new issue