PERFORCE change 40013 for review
Sam Leffler
sam at FreeBSD.org
Mon Oct 20 11:22:32 PDT 2003
http://perforce.freebsd.org/chv.cgi?CH=40013
Change 40013 by sam at sam_ebb on 2003/10/20 11:22:16
IFC @ 40008
Affected files ...
.. //depot/projects/netperf/sys/alpha/alpha/machdep.c#6 integrate
.. //depot/projects/netperf/sys/amd64/amd64/machdep.c#6 integrate
.. //depot/projects/netperf/sys/cam/cam_periph.c#4 integrate
.. //depot/projects/netperf/sys/cam/scsi/scsi_cd.c#9 integrate
.. //depot/projects/netperf/sys/compat/linprocfs/linprocfs.c#9 integrate
.. //depot/projects/netperf/sys/compat/linux/linux_ioctl.c#2 integrate
.. //depot/projects/netperf/sys/compat/svr4/svr4_filio.c#2 integrate
.. //depot/projects/netperf/sys/compat/svr4/svr4_misc.c#3 integrate
.. //depot/projects/netperf/sys/compat/svr4/svr4_signal.c#2 integrate
.. //depot/projects/netperf/sys/compat/svr4/svr4_stream.c#2 integrate
.. //depot/projects/netperf/sys/compat/svr4/svr4_sysvec.c#3 integrate
.. //depot/projects/netperf/sys/compat/svr4/svr4_util.h#2 integrate
.. //depot/projects/netperf/sys/conf/files#14 integrate
.. //depot/projects/netperf/sys/crypto/rijndael/Makefile#1 branch
.. //depot/projects/netperf/sys/crypto/rijndael/rijndael-alg-fst.c#3 integrate
.. //depot/projects/netperf/sys/crypto/rijndael/rijndael-alg-fst.h#3 integrate
.. //depot/projects/netperf/sys/crypto/rijndael/rijndael-api-fst.c#5 integrate
.. //depot/projects/netperf/sys/crypto/rijndael/rijndael-api-fst.h#3 integrate
.. //depot/projects/netperf/sys/crypto/rijndael/test00.c#1 branch
.. //depot/projects/netperf/sys/dev/acpica/acpi.c#10 integrate
.. //depot/projects/netperf/sys/dev/ata/ata-lowlevel.c#9 integrate
.. //depot/projects/netperf/sys/dev/ata/ata-pci.c#5 integrate
.. //depot/projects/netperf/sys/dev/ata/ata-queue.c#7 integrate
.. //depot/projects/netperf/sys/dev/ata/atapi-cd.c#9 integrate
.. //depot/projects/netperf/sys/dev/ep/if_ep.c#5 integrate
.. //depot/projects/netperf/sys/dev/ep/if_ep_eisa.c#3 integrate
.. //depot/projects/netperf/sys/dev/ep/if_ep_isa.c#4 integrate
.. //depot/projects/netperf/sys/dev/ep/if_ep_mca.c#3 integrate
.. //depot/projects/netperf/sys/dev/ep/if_ep_pccard.c#4 integrate
.. //depot/projects/netperf/sys/dev/ep/if_epreg.h#2 integrate
.. //depot/projects/netperf/sys/dev/ep/if_epvar.h#2 integrate
.. //depot/projects/netperf/sys/dev/firewire/sbp.c#8 integrate
.. //depot/projects/netperf/sys/dev/firewire/sbp_targ.c#1 branch
.. //depot/projects/netperf/sys/dev/ips/ips_commands.c#3 integrate
.. //depot/projects/netperf/sys/dev/matcd/matcd.c#3 integrate
.. //depot/projects/netperf/sys/dev/mcd/mcd.c#3 integrate
.. //depot/projects/netperf/sys/dev/md/md.c#6 integrate
.. //depot/projects/netperf/sys/dev/null/null.c#4 integrate
.. //depot/projects/netperf/sys/dev/ofw/ofw_disk.c#3 integrate
.. //depot/projects/netperf/sys/dev/raidframe/rf_freebsdkintf.c#4 integrate
.. //depot/projects/netperf/sys/dev/scd/scd.c#3 integrate
.. //depot/projects/netperf/sys/dev/streams/streams.c#3 integrate
.. //depot/projects/netperf/sys/dev/vinum/vinumrequest.c#3 integrate
.. //depot/projects/netperf/sys/fs/devfs/devfs_vnops.c#2 integrate
.. //depot/projects/netperf/sys/fs/hpfs/hpfs_vnops.c#3 integrate
.. //depot/projects/netperf/sys/fs/msdosfs/msdosfs_vnops.c#4 integrate
.. //depot/projects/netperf/sys/fs/nwfs/nwfs_vnops.c#2 integrate
.. //depot/projects/netperf/sys/fs/procfs/procfs_map.c#4 integrate
.. //depot/projects/netperf/sys/fs/smbfs/smbfs_vnops.c#4 integrate
.. //depot/projects/netperf/sys/fs/specfs/spec_vnops.c#7 integrate
.. //depot/projects/netperf/sys/fs/udf/udf_vnops.c#3 integrate
.. //depot/projects/netperf/sys/geom/geom_dev.c#7 integrate
.. //depot/projects/netperf/sys/geom/geom_disk.c#5 integrate
.. //depot/projects/netperf/sys/geom/geom_io.c#6 integrate
.. //depot/projects/netperf/sys/gnu/ext2fs/ext2_bmap.c#2 integrate
.. //depot/projects/netperf/sys/gnu/ext2fs/ext2_inode.c#3 integrate
.. //depot/projects/netperf/sys/gnu/ext2fs/ext2_vnops.c#2 integrate
.. //depot/projects/netperf/sys/i386/i386/machdep.c#8 integrate
.. //depot/projects/netperf/sys/i386/i386/vm_machdep.c#4 integrate
.. //depot/projects/netperf/sys/ia64/ia64/machdep.c#12 integrate
.. //depot/projects/netperf/sys/ia64/include/vmparam.h#3 integrate
.. //depot/projects/netperf/sys/isa/fd.c#5 integrate
.. //depot/projects/netperf/sys/isofs/cd9660/cd9660_vnops.c#3 integrate
.. //depot/projects/netperf/sys/kern/init_sysent.c#3 integrate
.. //depot/projects/netperf/sys/kern/kern_descrip.c#6 integrate
.. //depot/projects/netperf/sys/kern/kern_event.c#2 integrate
.. //depot/projects/netperf/sys/kern/kern_exec.c#6 integrate
.. //depot/projects/netperf/sys/kern/kern_idle.c#3 integrate
.. //depot/projects/netperf/sys/kern/kern_physio.c#3 integrate
.. //depot/projects/netperf/sys/kern/subr_disk.c#3 integrate
.. //depot/projects/netperf/sys/kern/sys_pipe.c#7 integrate
.. //depot/projects/netperf/sys/kern/syscalls.c#3 integrate
.. //depot/projects/netperf/sys/kern/syscalls.master#3 integrate
.. //depot/projects/netperf/sys/kern/tty_cons.c#6 integrate
.. //depot/projects/netperf/sys/kern/uipc_syscalls.c#6 integrate
.. //depot/projects/netperf/sys/kern/vfs_bio.c#10 integrate
.. //depot/projects/netperf/sys/kern/vfs_cluster.c#3 integrate
.. //depot/projects/netperf/sys/kern/vfs_syscalls.c#7 integrate
.. //depot/projects/netperf/sys/modules/firewire/Makefile#2 integrate
.. //depot/projects/netperf/sys/modules/firewire/sbp_targ/Makefile#1 branch
.. //depot/projects/netperf/sys/net/bpf.h#2 integrate
.. //depot/projects/netperf/sys/netinet/tcp_input.c#4 edit
.. //depot/projects/netperf/sys/netinet6/ah_core.c#5 integrate
.. //depot/projects/netperf/sys/netinet6/esp_core.c#6 integrate
.. //depot/projects/netperf/sys/netinet6/in6.c#9 integrate
.. //depot/projects/netperf/sys/netinet6/in6_rmx.c#8 integrate
.. //depot/projects/netperf/sys/netinet6/ip6_forward.c#8 integrate
.. //depot/projects/netperf/sys/netinet6/ip6_mroute.c#4 integrate
.. //depot/projects/netperf/sys/netinet6/ip6_output.c#15 integrate
.. //depot/projects/netperf/sys/netinet6/nd6.c#12 integrate
.. //depot/projects/netperf/sys/netinet6/nd6.h#5 integrate
.. //depot/projects/netperf/sys/netinet6/nd6_rtr.c#8 integrate
.. //depot/projects/netperf/sys/nfsclient/nfs_bio.c#4 integrate
.. //depot/projects/netperf/sys/nfsclient/nfs_vnops.c#6 integrate
.. //depot/projects/netperf/sys/opencrypto/cryptodev.c#3 integrate
.. //depot/projects/netperf/sys/pc98/i386/machdep.c#6 integrate
.. //depot/projects/netperf/sys/pc98/pc98/fd.c#4 integrate
.. //depot/projects/netperf/sys/pc98/pc98/wd.c#2 integrate
.. //depot/projects/netperf/sys/pc98/pc98/wd_cd.c#2 integrate
.. //depot/projects/netperf/sys/pci/if_dc.c#8 integrate
.. //depot/projects/netperf/sys/pci/if_sis.c#11 integrate
.. //depot/projects/netperf/sys/powerpc/powerpc/machdep.c#3 integrate
.. //depot/projects/netperf/sys/sparc64/sparc64/machdep.c#5 integrate
.. //depot/projects/netperf/sys/sys/bio.h#2 integrate
.. //depot/projects/netperf/sys/sys/buf.h#4 integrate
.. //depot/projects/netperf/sys/sys/cdio.h#2 integrate
.. //depot/projects/netperf/sys/sys/conf.h#4 integrate
.. //depot/projects/netperf/sys/sys/mbuf.h#4 integrate
.. //depot/projects/netperf/sys/sys/proc.h#6 integrate
.. //depot/projects/netperf/sys/sys/syscall.h#3 integrate
.. //depot/projects/netperf/sys/sys/syscall.mk#3 integrate
.. //depot/projects/netperf/sys/sys/sysproto.h#3 integrate
.. //depot/projects/netperf/sys/ufs/ffs/ffs_inode.c#3 integrate
.. //depot/projects/netperf/sys/ufs/ufs/ufs_bmap.c#2 integrate
.. //depot/projects/netperf/sys/ufs/ufs/ufs_vnops.c#4 integrate
.. //depot/projects/netperf/sys/vm/swap_pager.c#6 integrate
.. //depot/projects/netperf/sys/vm/vm_contig.c#4 integrate
.. //depot/projects/netperf/sys/vm/vm_map.c#9 integrate
.. //depot/projects/netperf/sys/vm/vm_object.c#7 integrate
.. //depot/projects/netperf/sys/vm/vm_pageout.c#8 integrate
.. //depot/projects/netperf/sys/vm/vm_pageout.h#3 integrate
.. //depot/projects/netperf/sys/vm/vm_pager.c#3 integrate
.. //depot/projects/netperf/sys/vm/vnode_pager.c#8 integrate
Differences ...
==== //depot/projects/netperf/sys/alpha/alpha/machdep.c#6 (text+ko) ====
@@ -88,7 +88,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/alpha/alpha/machdep.c,v 1.212 2003/08/25 03:43:07 marcel Exp $");
+__FBSDID("$FreeBSD: src/sys/alpha/alpha/machdep.c,v 1.213 2003/10/19 02:36:06 peter Exp $");
#include "opt_compat.h"
#include "opt_ddb.h"
@@ -1731,6 +1731,12 @@
prom_halt(1);
}
+void
+cpu_idle(void)
+{
+ /* Insert code to halt (until next interrupt) for the idle loop */
+}
+
/*
* Clear registers on exec
*/
==== //depot/projects/netperf/sys/amd64/amd64/machdep.c#6 (text+ko) ====
@@ -38,7 +38,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/machdep.c,v 1.593 2003/09/23 00:45:55 peter Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/machdep.c,v 1.594 2003/10/18 22:25:07 njl Exp $");
#include "opt_atalk.h"
#include "opt_compat.h"
@@ -455,6 +455,17 @@
SYSCTL_INT(_machdep, OID_AUTO, cpu_idle_hlt, CTLFLAG_RW,
&cpu_idle_hlt, 0, "Idle loop HLT enable");
+static void
+cpu_idle_default(void)
+{
+ /*
+ * we must absolutely guarentee that hlt is the
+ * absolute next instruction after sti or we
+ * introduce a timing window.
+ */
+ __asm __volatile("sti; hlt");
+}
+
/*
* Note that we have to be careful here to avoid a race between checking
* sched_runnable() and actually halting. If we don't do this, we may waste
@@ -467,19 +478,16 @@
if (cpu_idle_hlt) {
disable_intr();
- if (sched_runnable()) {
+ if (sched_runnable())
enable_intr();
- } else {
- /*
- * we must absolutely guarentee that hlt is the
- * absolute next instruction after sti or we
- * introduce a timing window.
- */
- __asm __volatile("sti; hlt");
- }
+ else
+ (*cpu_idle_hook)();
}
}
+/* Other subsystems (e.g., ACPI) can hook this later. */
+void (*cpu_idle_hook)(void) = cpu_idle_default;
+
/*
* Clear registers on exec
*/
==== //depot/projects/netperf/sys/cam/cam_periph.c#4 (text+ko) ====
@@ -28,7 +28,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/cam/cam_periph.c,v 1.53 2003/09/21 08:42:32 thomas Exp $");
+__FBSDID("$FreeBSD: src/sys/cam/cam_periph.c,v 1.54 2003/10/18 11:01:11 phk Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -638,9 +638,6 @@
/* set the transfer length, we know it's < DFLTPHYS */
mapinfo->bp[i]->b_bufsize = lengths[i];
- /* set the flags */
- mapinfo->bp[i]->b_flags = B_PHYS;
-
/* set the direction */
mapinfo->bp[i]->b_iocmd = flags[i];
@@ -656,10 +653,8 @@
for (j = 0; j < i; ++j) {
*data_ptrs[j] = mapinfo->bp[j]->b_saveaddr;
vunmapbuf(mapinfo->bp[j]);
- mapinfo->bp[j]->b_flags &= ~B_PHYS;
relpbuf(mapinfo->bp[j], NULL);
}
- mapinfo->bp[i]->b_flags &= ~B_PHYS;
relpbuf(mapinfo->bp[i], NULL);
PRELE(curproc);
return(EACCES);
@@ -720,9 +715,6 @@
/* unmap the buffer */
vunmapbuf(mapinfo->bp[i]);
- /* clear the flags we set above */
- mapinfo->bp[i]->b_flags &= ~B_PHYS;
-
/* release the buffer */
relpbuf(mapinfo->bp[i], NULL);
}
==== //depot/projects/netperf/sys/cam/scsi/scsi_cd.c#9 (text+ko) ====
@@ -46,7 +46,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/cam/scsi/scsi_cd.c,v 1.86 2003/10/07 14:46:59 thomas Exp $");
+__FBSDID("$FreeBSD: src/sys/cam/scsi/scsi_cd.c,v 1.87 2003/10/18 17:24:05 phk Exp $");
#include "opt_cd.h"
@@ -1518,8 +1518,8 @@
/* read */bp->bio_cmd == BIO_READ,
/* byte2 */ 0,
/* minimum_cmd_size */ 10,
- /* lba */ bp->bio_blkno /
- (softc->params.blksize / DEV_BSIZE),
+ /* lba */ bp->bio_offset /
+ softc->params.blksize,
bp->bio_bcount / softc->params.blksize,
/* data_ptr */ bp->bio_data,
/* dxfer_len */ bp->bio_bcount,
==== //depot/projects/netperf/sys/compat/linprocfs/linprocfs.c#9 (text+ko) ====
@@ -40,7 +40,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/compat/linprocfs/linprocfs.c,v 1.76 2003/10/08 18:05:59 gallatin Exp $");
+__FBSDID("$FreeBSD: src/sys/compat/linprocfs/linprocfs.c,v 1.78 2003/10/20 04:10:20 cognet Exp $");
#include <sys/param.h>
#include <sys/queue.h>
@@ -822,11 +822,98 @@
static int
linprocfs_doprocmaps(PFS_FILL_ARGS)
{
- sbuf_printf(sb, "doprocmaps\n%c", '\0');
-
- return (0);
-}
-
+ char mebuffer[512];
+ vm_map_t map = &p->p_vmspace->vm_map;
+ vm_map_entry_t entry;
+ vm_object_t obj, tobj, lobj;
+ vm_ooffset_t off = 0;
+ char *name = "", *freename = NULL;
+ size_t len;
+ ino_t ino;
+ int ref_count, shadow_count, flags;
+ int error;
+
+ PROC_LOCK(p);
+ error = p_candebug(td, p);
+ PROC_UNLOCK(p);
+ if (error)
+ return (error);
+
+ if (uio->uio_rw != UIO_READ)
+ return (EOPNOTSUPP);
+
+ if (uio->uio_offset != 0)
+ return (0);
+
+ error = 0;
+ if (map != &curthread->td_proc->p_vmspace->vm_map)
+ vm_map_lock_read(map);
+ for (entry = map->header.next;
+ ((uio->uio_resid > 0) && (entry != &map->header));
+ entry = entry->next) {
+ name = "";
+ freename = NULL;
+ if (entry->eflags & MAP_ENTRY_IS_SUB_MAP)
+ continue;
+ obj = entry->object.vm_object;
+ for (lobj = tobj = obj; tobj; tobj = tobj->backing_object)
+ lobj = tobj;
+ ino = 0;
+ if (lobj) {
+ VM_OBJECT_LOCK(lobj);
+ off = IDX_TO_OFF(lobj->size);
+ if (lobj->type == OBJT_VNODE && lobj->handle) {
+ vn_fullpath(td, (struct vnode *)lobj->handle,
+ &name, &freename);
+ ino = ((struct vnode *)
+ lobj->handle)->v_cachedid;
+ }
+ flags = obj->flags;
+ ref_count = obj->ref_count;
+ shadow_count = obj->shadow_count;
+ VM_OBJECT_UNLOCK(lobj);
+ } else {
+ flags = 0;
+ ref_count = 0;
+ shadow_count = 0;
+ }
+
+ /*
+ * format:
+ * start, end, access, offset, major, minor, inode, name.
+ */
+ snprintf(mebuffer, sizeof mebuffer,
+ "%08lx-%08lx %s%s%s%s %08lx %02x:%02x %lu%s%s\n",
+ (u_long)entry->start, (u_long)entry->end,
+ (entry->protection & VM_PROT_READ)?"r":"-",
+ (entry->protection & VM_PROT_WRITE)?"w":"-",
+ (entry->protection & VM_PROT_EXECUTE)?"x":"-",
+ "p",
+ (u_long)off,
+ 0,
+ 0,
+ (u_long)ino,
+ *name ? " " : "",
+ name
+ );
+ if (freename)
+ free(freename, M_TEMP);
+ len = strlen(mebuffer);
+ if (len > uio->uio_resid)
+ len = uio->uio_resid; /*
+ * XXX We should probably return
+ * EFBIG here, as in procfs.
+ */
+ error = uiomove(mebuffer, len, uio);
+ if (error)
+ break;
+ }
+ if (map != &curthread->td_proc->p_vmspace->vm_map)
+ vm_map_unlock_read(map);
+
+ return (error);
+}
+
/*
* Filler function for proc/net/dev
*/
==== //depot/projects/netperf/sys/compat/linux/linux_ioctl.c#2 (text+ko) ====
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/compat/linux/linux_ioctl.c,v 1.109 2003/06/28 19:32:07 marcel Exp $");
+__FBSDID("$FreeBSD: src/sys/compat/linux/linux_ioctl.c,v 1.110 2003/10/20 09:51:00 sos Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -1408,24 +1408,7 @@
/* LINUX_CDROMREADMODE2 */
/* LINUX_CDROMREADMODE1 */
-
- case LINUX_CDROMREADAUDIO: {
- struct l_cdrom_read_audio lra;
- struct ioc_read_audio bra;
-
- error = copyin((void *)args->arg, &lra, sizeof(lra));
- if (error)
- break;
- bra.address_format = lra.addr_format;
- linux_to_bsd_msf_lba(bra.address_format, &lra.addr,
- &bra.address);
- bra.nframes = lra.nframes;
- bra.buffer = lra.buf;
- error = fo_ioctl(fp, CDIOCREADAUDIO, (caddr_t)&bra,
- td->td_ucred, td);
- break;
- }
-
+ /* LINUX_CDROMREADAUDIO */
/* LINUX_CDROMEJECT_SW */
/* LINUX_CDROMMULTISESSION */
/* LINUX_CDROM_GET_UPC */
==== //depot/projects/netperf/sys/compat/svr4/svr4_filio.c#2 (text+ko) ====
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_filio.c,v 1.29 2003/06/10 21:35:15 obrien Exp $");
+__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_filio.c,v 1.30 2003/10/20 10:38:48 tjr Exp $");
#include <sys/param.h>
#include <sys/proc.h>
@@ -40,6 +40,8 @@
#include <sys/poll.h>
#include <sys/malloc.h>
#include <sys/mutex.h>
+#include <sys/resource.h>
+#include <sys/resourcevar.h>
#include <sys/sysproto.h>
@@ -64,6 +66,11 @@
int idx = 0, cerr;
u_long siz;
+ mtx_assert(&Giant, MA_OWNED);
+ if (uap->nfds > td->td_proc->p_rlimit[RLIMIT_NOFILE].rlim_cur &&
+ uap->nfds > FD_SETSIZE)
+ return (EINVAL);
+
pa.fds = uap->fds;
pa.nfds = uap->nfds;
pa.timeout = uap->timeout;
==== //depot/projects/netperf/sys/compat/svr4/svr4_misc.c#3 (text+ko) ====
@@ -33,7 +33,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_misc.c,v 1.66 2003/08/06 18:40:49 phk Exp $");
+__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_misc.c,v 1.67 2003/10/20 10:38:48 tjr Exp $");
#include "opt_mac.h"
@@ -444,6 +444,9 @@
u_long *cookiebuf = NULL, *cookie;
int ncookies = 0, *retval = td->td_retval;
+ if (uap->nbytes < 0)
+ return (EINVAL);
+
if ((error = getvnode(td->td_proc->p_fd, uap->fd, &fp)) != 0)
return (error);
@@ -1734,6 +1737,7 @@
{
struct nameidata nd;
int error, *retval = td->td_retval;
+ unsigned int ncopy;
NDINIT(&nd, LOOKUP, NOFOLLOW | SAVENAME, UIO_USERSPACE,
uap->path, td);
@@ -1741,12 +1745,11 @@
if ((error = namei(&nd)) != 0)
return error;
- if ((error = copyout(nd.ni_cnd.cn_pnbuf, uap->buf,
- uap->bufsiz)) != 0)
+ ncopy = min(uap->bufsiz, strlen(nd.ni_cnd.cn_pnbuf) + 1);
+ if ((error = copyout(nd.ni_cnd.cn_pnbuf, uap->buf, ncopy)) != 0)
goto bad;
- *retval = strlen(nd.ni_cnd.cn_pnbuf) < uap->bufsiz ?
- strlen(nd.ni_cnd.cn_pnbuf) + 1 : uap->bufsiz;
+ *retval = ncopy;
bad:
NDFREE(&nd, NDF_ONLY_PNBUF);
vput(nd.ni_vp);
==== //depot/projects/netperf/sys/compat/svr4/svr4_signal.c#2 (text+ko) ====
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_signal.c,v 1.28 2003/06/10 21:35:15 obrien Exp $");
+__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_signal.c,v 1.29 2003/10/20 10:38:48 tjr Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -269,6 +269,9 @@
struct sigaction *nbsap;
int error;
+ if (uap->signum < 0 || uap->signum >= SVR4_NSIG)
+ return (EINVAL);
+
DPRINTF(("@@@ svr4_sys_sigaction(%d, %d, %d)\n", td->td_proc->p_pid,
uap->signum,
SVR4_SVR42BSD_SIG(uap->signum)));
@@ -337,9 +340,14 @@
p = td->td_proc;
DPRINTF(("@@@ svr4_sys_signal(%d)\n", p->p_pid));
- signum = SVR4_SVR42BSD_SIG(SVR4_SIGNO(uap->signum));
- if (signum <= 0 || signum > SVR4_NSIG)
+ signum = SVR4_SIGNO(uap->signum);
+ if (signum < 0 || signum >= SVR4_NSIG) {
+ if (SVR4_SIGCALL(uap->signum) == SVR4_SIGNAL_MASK ||
+ SVR4_SIGCALL(uap->signum) == SVR4_SIGDEFER_MASK)
+ td->td_retval[0] = (int)SVR4_SIG_ERR;
return (EINVAL);
+ }
+ signum = SVR4_SVR42BSD_SIG(signum);
switch (SVR4_SIGCALL(uap->signum)) {
case SVR4_SIGDEFER_MASK:
@@ -509,6 +517,8 @@
{
struct kill_args ka;
+ if (uap->signum < 0 || uap->signum >= SVR4_NSIG)
+ return (EINVAL);
ka.pid = uap->pid;
ka.signum = SVR4_SVR42BSD_SIG(uap->signum);
return kill(td, &ka);
==== //depot/projects/netperf/sys/compat/svr4/svr4_stream.c#2 (text+ko) ====
@@ -36,7 +36,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_stream.c,v 1.45 2003/06/10 21:35:15 obrien Exp $");
+__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_stream.c,v 1.46 2003/10/20 10:38:48 tjr Exp $");
#define COMPAT_43 1
@@ -406,22 +406,32 @@
const char *str;
struct svr4_strioctl *ioc;
{
- u_char *ptr = (u_char *) malloc(ioc->len, M_TEMP, M_WAITOK);
+ u_char *ptr = NULL;
+ int len;
int error;
+ len = ioc->len;
+ if (len > 1024)
+ len = 1024;
+
+ if (len > 0) {
+ ptr = (u_char *) malloc(len, M_TEMP, M_WAITOK);
+ if ((error = copyin(ioc->buf, ptr, len)) != 0) {
+ free((char *) ptr, M_TEMP);
+ return error;
+ }
+ }
+
uprintf("%s cmd = %ld, timeout = %d, len = %d, buf = %p { ",
str, ioc->cmd, ioc->timeout, ioc->len, ioc->buf);
- if ((error = copyin(ioc->buf, ptr, ioc->len)) != 0) {
- free((char *) ptr, M_TEMP);
- return error;
- }
-
- bufprint(ptr, ioc->len);
+ if (ptr != NULL)
+ bufprint(ptr, len);
uprintf("}\n");
- free((char *) ptr, M_TEMP);
+ if (ptr != NULL)
+ free((char *) ptr, M_TEMP);
return 0;
}
@@ -435,6 +445,9 @@
int maxlen = str->maxlen;
int len = str->len;
+ if (maxlen > 8192)
+ maxlen = 8192;
+
if (maxlen < 0)
maxlen = 0;
@@ -521,7 +534,8 @@
size_t l = strlen(path) + 1;
void *tpath;
- tpath = stackgap_alloc(&sg, l);
+ if ((tpath = stackgap_alloc(&sg, l)) == NULL)
+ return ENAMETOOLONG;
la.ub = stackgap_alloc(&sg, sizeof(struct stat));
if ((error = copyout(path, tpath, l)) != 0)
@@ -760,6 +774,9 @@
if (st == NULL)
return EINVAL;
+ if (ioc->len < 0 || ioc->len > sizeof(lst))
+ return EINVAL;
+
if ((error = copyin(ioc->buf, &lst, ioc->len)) != 0)
return error;
@@ -961,6 +978,9 @@
memset(&info, 0, sizeof(info));
+ if (ioc->len < 0 || ioc->len > sizeof(info))
+ return EINVAL;
+
if ((error = copyin(ioc->buf, &info, ioc->len)) != 0)
return error;
@@ -1009,6 +1029,9 @@
return EINVAL;
}
+ if (ioc->len < 0 || ioc->len > sizeof(bnd))
+ return EINVAL;
+
if ((error = copyin(ioc->buf, &bnd, ioc->len)) != 0)
return error;
@@ -1137,7 +1160,7 @@
struct sockaddr_in sain;
struct sockaddr_un saun;
struct svr4_strmcmd sc;
- int sasize;
+ int sasize, oldsasize;
caddr_t sg;
int *lenp;
@@ -1225,11 +1248,16 @@
return error;
}
+ oldsasize = sasize;
+
if ((error = copyin(lenp, &sasize, sizeof(*lenp))) != 0) {
DPRINTF(("ti_ioctl: error copying in socket size\n"));
return error;
}
+ if (sasize < 0 || sasize > oldsasize)
+ return EINVAL;
+
switch (st->s_family) {
case AF_INET:
sockaddr_to_netaddr_in(&sc, &sain);
@@ -1794,7 +1822,7 @@
return EINVAL;
}
- if (ctl.len > sizeof(sc)) {
+ if (ctl.len < 0 || ctl.len > sizeof(sc)) {
DPRINTF(("putmsg: Bad control size %d != %d\n", ctl.len,
sizeof(struct svr4_strmcmd)));
return EINVAL;
@@ -1962,6 +1990,8 @@
if (uap->ctl != NULL) {
if ((error = copyin(uap->ctl, &ctl, sizeof(ctl))) != 0)
return error;
+ if (ctl.len < 0)
+ return EINVAL;
}
else {
ctl.len = -1;
@@ -2147,6 +2177,9 @@
if (ctl.maxlen > 36 && ctl.len < 36)
ctl.len = 36;
+ if (ctl.len > sizeof(sc))
+ ctl.len = sizeof(sc);
+
if ((error = copyin(ctl.buf, &sc, ctl.len)) != 0)
return error;
==== //depot/projects/netperf/sys/compat/svr4/svr4_sysvec.c#3 (text+ko) ====
@@ -29,7 +29,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_sysvec.c,v 1.34 2003/09/25 01:10:23 peter Exp $");
+__FBSDID("$FreeBSD: src/sys/compat/svr4/svr4_sysvec.c,v 1.35 2003/10/20 10:38:48 tjr Exp $");
/* XXX we use functions that might not exist. */
#include "opt_compat.h"
@@ -364,8 +364,10 @@
*pbuf = buf;
else {
sz = &ptr[len] - buf;
- *pbuf = stackgap_alloc(sgp, sz + 1);
- error = copyout(buf, *pbuf, sz);
+ if ((*pbuf = stackgap_alloc(sgp, sz + 1)) != NULL)
+ error = copyout(buf, *pbuf, sz);
+ else
+ error = ENAMETOOLONG;
free(buf, M_TEMP);
}
==== //depot/projects/netperf/sys/compat/svr4/svr4_util.h#2 (text+ko) ====
@@ -25,7 +25,7 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
- * $FreeBSD: src/sys/compat/svr4/svr4_util.h,v 1.6 2002/03/20 05:41:38 alfred Exp $
+ * $FreeBSD: src/sys/compat/svr4/svr4_util.h,v 1.7 2003/10/20 10:38:48 tjr Exp $
*/
#ifndef _SVR4_UTIL_H_
@@ -63,7 +63,10 @@
size_t sz;
{
void *p = (void *) *sgp;
- *sgp += ALIGN(sz);
+ sz = ALIGN(sz);
+ if (*sgp + sz > (caddr_t)(PS_STRINGS - szsigcode))
+ return NULL;
+ *sgp += sz;
return p;
}
==== //depot/projects/netperf/sys/conf/files#14 (text+ko) ====
@@ -1,4 +1,4 @@
-# $FreeBSD: src/sys/conf/files,v 1.834 2003/10/15 08:53:04 phk Exp $
+# $FreeBSD: src/sys/conf/files,v 1.836 2003/10/19 21:28:33 ume Exp $
#
# The long compile-with and dependency lines are required because of
# limitations in config: backslash-newline doesn't work in strings, and
@@ -416,6 +416,7 @@
dev/firewire/fwohci_pci.c optional firewire pci
dev/firewire/if_fwe.c optional fwe
dev/firewire/sbp.c optional sbp
+dev/firewire/sbp_targ.c optional sbp_targ
dev/fxp/if_fxp.c optional fxp
dev/gem/if_gem.c optional gem
dev/gem/if_gem_pci.c optional gem pci
@@ -1438,12 +1439,12 @@
netinet/tcp_timer.c optional inet
netinet/tcp_usrreq.c optional inet
netinet/udp_usrreq.c optional inet
-netinet6/ah_aesxcbcmac.c optional ipsec
+#netinet6/ah_aesxcbcmac.c optional ipsec
netinet6/ah_core.c optional ipsec
netinet6/ah_input.c optional ipsec
netinet6/ah_output.c optional ipsec
netinet6/dest6.c optional inet6
-netinet6/esp_aesctr.c optional ipsec ipsec_esp
+#netinet6/esp_aesctr.c optional ipsec ipsec_esp
netinet6/esp_core.c optional ipsec ipsec_esp
netinet6/esp_input.c optional ipsec ipsec_esp
netinet6/esp_output.c optional ipsec ipsec_esp
==== //depot/projects/netperf/sys/crypto/rijndael/rijndael-alg-fst.c#3 (text+ko) ====
@@ -1,31 +1,19 @@
-/* $KAME: rijndael-alg-fst.c,v 1.10 2003/07/15 10:47:16 itojun Exp $ */
-/**
- * rijndael-alg-fst.c
+/* $KAME: rijndael-alg-fst.c,v 1.7 2001/05/27 00:23:23 itojun Exp $ */
+
+/*
+ * rijndael-alg-fst.c v2.3 April '2000
*
- * @version 3.0 (December 2000)
+ * Optimised ANSI C code
*
- * Optimised ANSI C code for the Rijndael cipher (now AES)
+ * authors: v1.0: Antoon Bosselaers
+ * v2.0: Vincent Rijmen
+ * v2.3: Paulo Barreto
*
- * @author Vincent Rijmen <vincent.rijmen at esat.kuleuven.ac.be>
- * @author Antoon Bosselaers <antoon.bosselaers at esat.kuleuven.ac.be>
- * @author Paulo Barreto <paulo.barreto at terra.com.br>
- *
- * This code is hereby placed in the public domain.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ''AS IS'' AND ANY EXPRESS
- * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
- * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
- * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
- * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
- * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ * This code is placed in the public domain.
*/
+
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/crypto/rijndael/rijndael-alg-fst.c,v 1.5 2003/10/12 21:05:05 ume Exp $");
+__FBSDID("$FreeBSD: src/sys/crypto/rijndael/rijndael-alg-fst.c,v 1.6 2003/10/19 21:28:33 ume Exp $");
#include <sys/cdefs.h>
#include <sys/types.h>
@@ -34,1191 +22,1426 @@
#else
#include <string.h>
#endif
-
#include <crypto/rijndael/rijndael-alg-fst.h>
#include <crypto/rijndael/rijndael_local.h>
-/*
-Te0[x] = S [x].[02, 01, 01, 03];
-Te1[x] = S [x].[03, 02, 01, 01];
-Te2[x] = S [x].[01, 03, 02, 01];
-Te3[x] = S [x].[01, 01, 03, 02];
-Te4[x] = S [x].[01, 01, 01, 01];
+const u8 S[256] = {
+ 99, 124, 119, 123, 242, 107, 111, 197, 48, 1, 103, 43, 254, 215, 171, 118,
+202, 130, 201, 125, 250, 89, 71, 240, 173, 212, 162, 175, 156, 164, 114, 192,
+183, 253, 147, 38, 54, 63, 247, 204, 52, 165, 229, 241, 113, 216, 49, 21,
+ 4, 199, 35, 195, 24, 150, 5, 154, 7, 18, 128, 226, 235, 39, 178, 117,
+ 9, 131, 44, 26, 27, 110, 90, 160, 82, 59, 214, 179, 41, 227, 47, 132,
+ 83, 209, 0, 237, 32, 252, 177, 91, 106, 203, 190, 57, 74, 76, 88, 207,
+208, 239, 170, 251, 67, 77, 51, 133, 69, 249, 2, 127, 80, 60, 159, 168,
+ 81, 163, 64, 143, 146, 157, 56, 245, 188, 182, 218, 33, 16, 255, 243, 210,
+205, 12, 19, 236, 95, 151, 68, 23, 196, 167, 126, 61, 100, 93, 25, 115,
+ 96, 129, 79, 220, 34, 42, 144, 136, 70, 238, 184, 20, 222, 94, 11, 219,
+224, 50, 58, 10, 73, 6, 36, 92, 194, 211, 172, 98, 145, 149, 228, 121,
+231, 200, 55, 109, 141, 213, 78, 169, 108, 86, 244, 234, 101, 122, 174, 8,
+186, 120, 37, 46, 28, 166, 180, 198, 232, 221, 116, 31, 75, 189, 139, 138,
+112, 62, 181, 102, 72, 3, 246, 14, 97, 53, 87, 185, 134, 193, 29, 158,
+225, 248, 152, 17, 105, 217, 142, 148, 155, 30, 135, 233, 206, 85, 40, 223,
+140, 161, 137, 13, 191, 230, 66, 104, 65, 153, 45, 15, 176, 84, 187, 22
+};
+
+#ifdef INTERMEDIATE_VALUE_KAT
+static const u8 Si[256] = {
+ 82, 9, 106, 213, 48, 54, 165, 56, 191, 64, 163, 158, 129, 243, 215, 251,
+124, 227, 57, 130, 155, 47, 255, 135, 52, 142, 67, 68, 196, 222, 233, 203,
+ 84, 123, 148, 50, 166, 194, 35, 61, 238, 76, 149, 11, 66, 250, 195, 78,
+ 8, 46, 161, 102, 40, 217, 36, 178, 118, 91, 162, 73, 109, 139, 209, 37,
+114, 248, 246, 100, 134, 104, 152, 22, 212, 164, 92, 204, 93, 101, 182, 146,
+108, 112, 72, 80, 253, 237, 185, 218, 94, 21, 70, 87, 167, 141, 157, 132,
+144, 216, 171, 0, 140, 188, 211, 10, 247, 228, 88, 5, 184, 179, 69, 6,
+208, 44, 30, 143, 202, 63, 15, 2, 193, 175, 189, 3, 1, 19, 138, 107,
+ 58, 145, 17, 65, 79, 103, 220, 234, 151, 242, 207, 206, 240, 180, 230, 115,
+150, 172, 116, 34, 231, 173, 53, 133, 226, 249, 55, 232, 28, 117, 223, 110,
+ 71, 241, 26, 113, 29, 41, 197, 137, 111, 183, 98, 14, 170, 24, 190, 27,
+252, 86, 62, 75, 198, 210, 121, 32, 154, 219, 192, 254, 120, 205, 90, 244,
+ 31, 221, 168, 51, 136, 7, 199, 49, 177, 18, 16, 89, 39, 128, 236, 95,
+ 96, 81, 127, 169, 25, 181, 74, 13, 45, 229, 122, 159, 147, 201, 156, 239,
+160, 224, 59, 77, 174, 42, 245, 176, 200, 235, 187, 60, 131, 83, 153, 97,
+ 23, 43, 4, 126, 186, 119, 214, 38, 225, 105, 20, 99, 85, 33, 12, 125
+};
+#endif /* INTERMEDIATE_VALUE_KAT */
+
+union xtab {
+ u32 xt32[256];
+ u8 xt8[256][4];
+};
+
+static const union xtab xT1 = {
+ .xt8 = {
+{0xc6,0x63,0x63,0xa5}, {0xf8,0x7c,0x7c,0x84}, {0xee,0x77,0x77,0x99}, {0xf6,0x7b,0x7b,0x8d},
+{0xff,0xf2,0xf2,0x0d}, {0xd6,0x6b,0x6b,0xbd}, {0xde,0x6f,0x6f,0xb1}, {0x91,0xc5,0xc5,0x54},
+{0x60,0x30,0x30,0x50}, {0x02,0x01,0x01,0x03}, {0xce,0x67,0x67,0xa9}, {0x56,0x2b,0x2b,0x7d},
+{0xe7,0xfe,0xfe,0x19}, {0xb5,0xd7,0xd7,0x62}, {0x4d,0xab,0xab,0xe6}, {0xec,0x76,0x76,0x9a},
+{0x8f,0xca,0xca,0x45}, {0x1f,0x82,0x82,0x9d}, {0x89,0xc9,0xc9,0x40}, {0xfa,0x7d,0x7d,0x87},
+{0xef,0xfa,0xfa,0x15}, {0xb2,0x59,0x59,0xeb}, {0x8e,0x47,0x47,0xc9}, {0xfb,0xf0,0xf0,0x0b},
+{0x41,0xad,0xad,0xec}, {0xb3,0xd4,0xd4,0x67}, {0x5f,0xa2,0xa2,0xfd}, {0x45,0xaf,0xaf,0xea},
+{0x23,0x9c,0x9c,0xbf}, {0x53,0xa4,0xa4,0xf7}, {0xe4,0x72,0x72,0x96}, {0x9b,0xc0,0xc0,0x5b},
+{0x75,0xb7,0xb7,0xc2}, {0xe1,0xfd,0xfd,0x1c}, {0x3d,0x93,0x93,0xae}, {0x4c,0x26,0x26,0x6a},
+{0x6c,0x36,0x36,0x5a}, {0x7e,0x3f,0x3f,0x41}, {0xf5,0xf7,0xf7,0x02}, {0x83,0xcc,0xcc,0x4f},
+{0x68,0x34,0x34,0x5c}, {0x51,0xa5,0xa5,0xf4}, {0xd1,0xe5,0xe5,0x34}, {0xf9,0xf1,0xf1,0x08},
+{0xe2,0x71,0x71,0x93}, {0xab,0xd8,0xd8,0x73}, {0x62,0x31,0x31,0x53}, {0x2a,0x15,0x15,0x3f},
+{0x08,0x04,0x04,0x0c}, {0x95,0xc7,0xc7,0x52}, {0x46,0x23,0x23,0x65}, {0x9d,0xc3,0xc3,0x5e},
+{0x30,0x18,0x18,0x28}, {0x37,0x96,0x96,0xa1}, {0x0a,0x05,0x05,0x0f}, {0x2f,0x9a,0x9a,0xb5},
+{0x0e,0x07,0x07,0x09}, {0x24,0x12,0x12,0x36}, {0x1b,0x80,0x80,0x9b}, {0xdf,0xe2,0xe2,0x3d},
+{0xcd,0xeb,0xeb,0x26}, {0x4e,0x27,0x27,0x69}, {0x7f,0xb2,0xb2,0xcd}, {0xea,0x75,0x75,0x9f},
+{0x12,0x09,0x09,0x1b}, {0x1d,0x83,0x83,0x9e}, {0x58,0x2c,0x2c,0x74}, {0x34,0x1a,0x1a,0x2e},
+{0x36,0x1b,0x1b,0x2d}, {0xdc,0x6e,0x6e,0xb2}, {0xb4,0x5a,0x5a,0xee}, {0x5b,0xa0,0xa0,0xfb},
+{0xa4,0x52,0x52,0xf6}, {0x76,0x3b,0x3b,0x4d}, {0xb7,0xd6,0xd6,0x61}, {0x7d,0xb3,0xb3,0xce},
+{0x52,0x29,0x29,0x7b}, {0xdd,0xe3,0xe3,0x3e}, {0x5e,0x2f,0x2f,0x71}, {0x13,0x84,0x84,0x97},
+{0xa6,0x53,0x53,0xf5}, {0xb9,0xd1,0xd1,0x68}, {0x00,0x00,0x00,0x00}, {0xc1,0xed,0xed,0x2c},
+{0x40,0x20,0x20,0x60}, {0xe3,0xfc,0xfc,0x1f}, {0x79,0xb1,0xb1,0xc8}, {0xb6,0x5b,0x5b,0xed},
+{0xd4,0x6a,0x6a,0xbe}, {0x8d,0xcb,0xcb,0x46}, {0x67,0xbe,0xbe,0xd9}, {0x72,0x39,0x39,0x4b},
+{0x94,0x4a,0x4a,0xde}, {0x98,0x4c,0x4c,0xd4}, {0xb0,0x58,0x58,0xe8}, {0x85,0xcf,0xcf,0x4a},
+{0xbb,0xd0,0xd0,0x6b}, {0xc5,0xef,0xef,0x2a}, {0x4f,0xaa,0xaa,0xe5}, {0xed,0xfb,0xfb,0x16},
+{0x86,0x43,0x43,0xc5}, {0x9a,0x4d,0x4d,0xd7}, {0x66,0x33,0x33,0x55}, {0x11,0x85,0x85,0x94},
+{0x8a,0x45,0x45,0xcf}, {0xe9,0xf9,0xf9,0x10}, {0x04,0x02,0x02,0x06}, {0xfe,0x7f,0x7f,0x81},
+{0xa0,0x50,0x50,0xf0}, {0x78,0x3c,0x3c,0x44}, {0x25,0x9f,0x9f,0xba}, {0x4b,0xa8,0xa8,0xe3},
+{0xa2,0x51,0x51,0xf3}, {0x5d,0xa3,0xa3,0xfe}, {0x80,0x40,0x40,0xc0}, {0x05,0x8f,0x8f,0x8a},
+{0x3f,0x92,0x92,0xad}, {0x21,0x9d,0x9d,0xbc}, {0x70,0x38,0x38,0x48}, {0xf1,0xf5,0xf5,0x04},
+{0x63,0xbc,0xbc,0xdf}, {0x77,0xb6,0xb6,0xc1}, {0xaf,0xda,0xda,0x75}, {0x42,0x21,0x21,0x63},
+{0x20,0x10,0x10,0x30}, {0xe5,0xff,0xff,0x1a}, {0xfd,0xf3,0xf3,0x0e}, {0xbf,0xd2,0xd2,0x6d},
+{0x81,0xcd,0xcd,0x4c}, {0x18,0x0c,0x0c,0x14}, {0x26,0x13,0x13,0x35}, {0xc3,0xec,0xec,0x2f},
+{0xbe,0x5f,0x5f,0xe1}, {0x35,0x97,0x97,0xa2}, {0x88,0x44,0x44,0xcc}, {0x2e,0x17,0x17,0x39},
+{0x93,0xc4,0xc4,0x57}, {0x55,0xa7,0xa7,0xf2}, {0xfc,0x7e,0x7e,0x82}, {0x7a,0x3d,0x3d,0x47},
+{0xc8,0x64,0x64,0xac}, {0xba,0x5d,0x5d,0xe7}, {0x32,0x19,0x19,0x2b}, {0xe6,0x73,0x73,0x95},
+{0xc0,0x60,0x60,0xa0}, {0x19,0x81,0x81,0x98}, {0x9e,0x4f,0x4f,0xd1}, {0xa3,0xdc,0xdc,0x7f},
+{0x44,0x22,0x22,0x66}, {0x54,0x2a,0x2a,0x7e}, {0x3b,0x90,0x90,0xab}, {0x0b,0x88,0x88,0x83},
+{0x8c,0x46,0x46,0xca}, {0xc7,0xee,0xee,0x29}, {0x6b,0xb8,0xb8,0xd3}, {0x28,0x14,0x14,0x3c},
+{0xa7,0xde,0xde,0x79}, {0xbc,0x5e,0x5e,0xe2}, {0x16,0x0b,0x0b,0x1d}, {0xad,0xdb,0xdb,0x76},
+{0xdb,0xe0,0xe0,0x3b}, {0x64,0x32,0x32,0x56}, {0x74,0x3a,0x3a,0x4e}, {0x14,0x0a,0x0a,0x1e},
+{0x92,0x49,0x49,0xdb}, {0x0c,0x06,0x06,0x0a}, {0x48,0x24,0x24,0x6c}, {0xb8,0x5c,0x5c,0xe4},
+{0x9f,0xc2,0xc2,0x5d}, {0xbd,0xd3,0xd3,0x6e}, {0x43,0xac,0xac,0xef}, {0xc4,0x62,0x62,0xa6},
+{0x39,0x91,0x91,0xa8}, {0x31,0x95,0x95,0xa4}, {0xd3,0xe4,0xe4,0x37}, {0xf2,0x79,0x79,0x8b},
+{0xd5,0xe7,0xe7,0x32}, {0x8b,0xc8,0xc8,0x43}, {0x6e,0x37,0x37,0x59}, {0xda,0x6d,0x6d,0xb7},
+{0x01,0x8d,0x8d,0x8c}, {0xb1,0xd5,0xd5,0x64}, {0x9c,0x4e,0x4e,0xd2}, {0x49,0xa9,0xa9,0xe0},
+{0xd8,0x6c,0x6c,0xb4}, {0xac,0x56,0x56,0xfa}, {0xf3,0xf4,0xf4,0x07}, {0xcf,0xea,0xea,0x25},
+{0xca,0x65,0x65,0xaf}, {0xf4,0x7a,0x7a,0x8e}, {0x47,0xae,0xae,0xe9}, {0x10,0x08,0x08,0x18},
+{0x6f,0xba,0xba,0xd5}, {0xf0,0x78,0x78,0x88}, {0x4a,0x25,0x25,0x6f}, {0x5c,0x2e,0x2e,0x72},
+{0x38,0x1c,0x1c,0x24}, {0x57,0xa6,0xa6,0xf1}, {0x73,0xb4,0xb4,0xc7}, {0x97,0xc6,0xc6,0x51},
+{0xcb,0xe8,0xe8,0x23}, {0xa1,0xdd,0xdd,0x7c}, {0xe8,0x74,0x74,0x9c}, {0x3e,0x1f,0x1f,0x21},
+{0x96,0x4b,0x4b,0xdd}, {0x61,0xbd,0xbd,0xdc}, {0x0d,0x8b,0x8b,0x86}, {0x0f,0x8a,0x8a,0x85},
+{0xe0,0x70,0x70,0x90}, {0x7c,0x3e,0x3e,0x42}, {0x71,0xb5,0xb5,0xc4}, {0xcc,0x66,0x66,0xaa},
+{0x90,0x48,0x48,0xd8}, {0x06,0x03,0x03,0x05}, {0xf7,0xf6,0xf6,0x01}, {0x1c,0x0e,0x0e,0x12},
+{0xc2,0x61,0x61,0xa3}, {0x6a,0x35,0x35,0x5f}, {0xae,0x57,0x57,0xf9}, {0x69,0xb9,0xb9,0xd0},
+{0x17,0x86,0x86,0x91}, {0x99,0xc1,0xc1,0x58}, {0x3a,0x1d,0x1d,0x27}, {0x27,0x9e,0x9e,0xb9},
+{0xd9,0xe1,0xe1,0x38}, {0xeb,0xf8,0xf8,0x13}, {0x2b,0x98,0x98,0xb3}, {0x22,0x11,0x11,0x33},
+{0xd2,0x69,0x69,0xbb}, {0xa9,0xd9,0xd9,0x70}, {0x07,0x8e,0x8e,0x89}, {0x33,0x94,0x94,0xa7},
+{0x2d,0x9b,0x9b,0xb6}, {0x3c,0x1e,0x1e,0x22}, {0x15,0x87,0x87,0x92}, {0xc9,0xe9,0xe9,0x20},
+{0x87,0xce,0xce,0x49}, {0xaa,0x55,0x55,0xff}, {0x50,0x28,0x28,0x78}, {0xa5,0xdf,0xdf,0x7a},
+{0x03,0x8c,0x8c,0x8f}, {0x59,0xa1,0xa1,0xf8}, {0x09,0x89,0x89,0x80}, {0x1a,0x0d,0x0d,0x17},
+{0x65,0xbf,0xbf,0xda}, {0xd7,0xe6,0xe6,0x31}, {0x84,0x42,0x42,0xc6}, {0xd0,0x68,0x68,0xb8},
+{0x82,0x41,0x41,0xc3}, {0x29,0x99,0x99,0xb0}, {0x5a,0x2d,0x2d,0x77}, {0x1e,0x0f,0x0f,0x11},
+{0x7b,0xb0,0xb0,0xcb}, {0xa8,0x54,0x54,0xfc}, {0x6d,0xbb,0xbb,0xd6}, {0x2c,0x16,0x16,0x3a}
+ }
+};
+#define T1 xT1.xt8
-Td0[x] = Si[x].[0e, 09, 0d, 0b];
-Td1[x] = Si[x].[0b, 0e, 09, 0d];
-Td2[x] = Si[x].[0d, 0b, 0e, 09];
-Td3[x] = Si[x].[09, 0d, 0b, 0e];
-Td4[x] = Si[x].[01, 01, 01, 01];
-*/
+static const union xtab xT2 = {
+ .xt8 = {
+{0xa5,0xc6,0x63,0x63}, {0x84,0xf8,0x7c,0x7c}, {0x99,0xee,0x77,0x77}, {0x8d,0xf6,0x7b,0x7b},
+{0x0d,0xff,0xf2,0xf2}, {0xbd,0xd6,0x6b,0x6b}, {0xb1,0xde,0x6f,0x6f}, {0x54,0x91,0xc5,0xc5},
+{0x50,0x60,0x30,0x30}, {0x03,0x02,0x01,0x01}, {0xa9,0xce,0x67,0x67}, {0x7d,0x56,0x2b,0x2b},
+{0x19,0xe7,0xfe,0xfe}, {0x62,0xb5,0xd7,0xd7}, {0xe6,0x4d,0xab,0xab}, {0x9a,0xec,0x76,0x76},
+{0x45,0x8f,0xca,0xca}, {0x9d,0x1f,0x82,0x82}, {0x40,0x89,0xc9,0xc9}, {0x87,0xfa,0x7d,0x7d},
+{0x15,0xef,0xfa,0xfa}, {0xeb,0xb2,0x59,0x59}, {0xc9,0x8e,0x47,0x47}, {0x0b,0xfb,0xf0,0xf0},
+{0xec,0x41,0xad,0xad}, {0x67,0xb3,0xd4,0xd4}, {0xfd,0x5f,0xa2,0xa2}, {0xea,0x45,0xaf,0xaf},
+{0xbf,0x23,0x9c,0x9c}, {0xf7,0x53,0xa4,0xa4}, {0x96,0xe4,0x72,0x72}, {0x5b,0x9b,0xc0,0xc0},
+{0xc2,0x75,0xb7,0xb7}, {0x1c,0xe1,0xfd,0xfd}, {0xae,0x3d,0x93,0x93}, {0x6a,0x4c,0x26,0x26},
+{0x5a,0x6c,0x36,0x36}, {0x41,0x7e,0x3f,0x3f}, {0x02,0xf5,0xf7,0xf7}, {0x4f,0x83,0xcc,0xcc},
+{0x5c,0x68,0x34,0x34}, {0xf4,0x51,0xa5,0xa5}, {0x34,0xd1,0xe5,0xe5}, {0x08,0xf9,0xf1,0xf1},
+{0x93,0xe2,0x71,0x71}, {0x73,0xab,0xd8,0xd8}, {0x53,0x62,0x31,0x31}, {0x3f,0x2a,0x15,0x15},
+{0x0c,0x08,0x04,0x04}, {0x52,0x95,0xc7,0xc7}, {0x65,0x46,0x23,0x23}, {0x5e,0x9d,0xc3,0xc3},
+{0x28,0x30,0x18,0x18}, {0xa1,0x37,0x96,0x96}, {0x0f,0x0a,0x05,0x05}, {0xb5,0x2f,0x9a,0x9a},
+{0x09,0x0e,0x07,0x07}, {0x36,0x24,0x12,0x12}, {0x9b,0x1b,0x80,0x80}, {0x3d,0xdf,0xe2,0xe2},
+{0x26,0xcd,0xeb,0xeb}, {0x69,0x4e,0x27,0x27}, {0xcd,0x7f,0xb2,0xb2}, {0x9f,0xea,0x75,0x75},
+{0x1b,0x12,0x09,0x09}, {0x9e,0x1d,0x83,0x83}, {0x74,0x58,0x2c,0x2c}, {0x2e,0x34,0x1a,0x1a},
+{0x2d,0x36,0x1b,0x1b}, {0xb2,0xdc,0x6e,0x6e}, {0xee,0xb4,0x5a,0x5a}, {0xfb,0x5b,0xa0,0xa0},
+{0xf6,0xa4,0x52,0x52}, {0x4d,0x76,0x3b,0x3b}, {0x61,0xb7,0xd6,0xd6}, {0xce,0x7d,0xb3,0xb3},
+{0x7b,0x52,0x29,0x29}, {0x3e,0xdd,0xe3,0xe3}, {0x71,0x5e,0x2f,0x2f}, {0x97,0x13,0x84,0x84},
>>> TRUNCATED FOR MAIL (1000 lines) <<<
More information about the p4-projects
mailing list