dragonfly.git
20 years agoAdd a bunch of Intel USB controllers.
Jeroen Ruigrok/asmodai [Tue, 28 Oct 2003 06:54:49 +0000 (06:54 +0000)]
Add a bunch of Intel USB controllers.

20 years agoAdd the AMD-766, Apple KeyLargo, and SiS 5571.
Jeroen Ruigrok/asmodai [Tue, 28 Oct 2003 06:50:15 +0000 (06:50 +0000)]
Add the AMD-766, Apple KeyLargo, and SiS 5571.

20 years agoReorder to alphabetical order.
Jeroen Ruigrok/asmodai [Tue, 28 Oct 2003 06:47:30 +0000 (06:47 +0000)]
Reorder to alphabetical order.

20 years agoAdd NVIDIA's nForce2.
Jeroen Ruigrok/asmodai [Tue, 28 Oct 2003 06:46:45 +0000 (06:46 +0000)]
Add NVIDIA's nForce2.

20 years agoDeal with multicast packets in a manner similar to Solaris, RFC 3376, and
Matthew Dillon [Tue, 28 Oct 2003 03:51:51 +0000 (03:51 +0000)]
Deal with multicast packets in a manner similar to Solaris, RFC 3376, and
draft-ietf-magma-msf-api-05.txt.   Multicast packets are not sent to
multicast-unaware sockets or to sockets not bound to the interface the
packet came in on.

The sysctl net.inet.udp.strict_mcast_mship enables the new requirements
by default.  Original operation may be recovered by setting the sysctl to 0.

There is a relatively minor scaling issue with the per-PCB membership
array scan, which is linear.  It is not a show stopper though.

Submitted by: "William A. Carrel" <william.a@carrel.org>
Reviewed by: Jeffrey Hsu <hsu@FreeBSD.org>, dillon

20 years agoAdd OHCI support for the NVIDIA nForce 2 chipset.
Jeroen Ruigrok/asmodai [Mon, 27 Oct 2003 21:39:27 +0000 (21:39 +0000)]
Add OHCI support for the NVIDIA nForce 2 chipset.

FreeBSD PR: kern/47311
Submitted by: Mike Hibler <mike@cs.utah.edu>

20 years agoAllow NVIDIA's nForce 2 chipset to use proper ATA DMA modes.
Jeroen Ruigrok/asmodai [Mon, 27 Oct 2003 21:12:29 +0000 (21:12 +0000)]
Allow NVIDIA's nForce 2 chipset to use proper ATA DMA modes.

FreeBSD PR: kern/47311
Submitted by: Mike Hibler <mike@cs.utah.edu>

20 years agoFix a bug introduced when I redid the stray interrupt arary. The
Matthew Dillon [Mon, 27 Oct 2003 16:42:17 +0000 (16:42 +0000)]
Fix a bug introduced when I redid the stray interrupt arary.  The
initial loading of the vectors by isa_defaultirq() wound up being a nop
because I broke the intr_handler[] check in icu_unset().  This caused
stray interrupts doing boot (e.g. a stray irq 7 / printer interrupt being
the most common) to generate trap 30's and drop into DDB on boot.

Mucho Thanks to: David Rhodus <drhodus@catpa.com>

20 years agoBackout last commit, oops! SIGCKPT had already been added and it was redundant.
Matthew Dillon [Mon, 27 Oct 2003 15:31:19 +0000 (15:31 +0000)]
Backout last commit, oops! SIGCKPT had already been added and it was redundant.

20 years agoRemove unneeded XXX, to rename lwkt_create() as it was named
Hiten Pandya [Sun, 26 Oct 2003 13:59:58 +0000 (13:59 +0000)]
Remove unneeded XXX, to rename lwkt_create() as it was named
lwkt_create() since rev 1.6.

20 years agoSimplify the lazy-release code for P_CURPROC, removing the TDF_RUNQ
Matthew Dillon [Sat, 25 Oct 2003 17:39:22 +0000 (17:39 +0000)]
Simplify the lazy-release code for P_CURPROC, removing the TDF_RUNQ
optimization because it wasn't actually getting hit often enough to matter.

20 years agoAdd a DEBUG_INTERRUPTS option for debugging unexpected (trap 30) interrupts.
Matthew Dillon [Sat, 25 Oct 2003 17:36:22 +0000 (17:36 +0000)]
Add a DEBUG_INTERRUPTS option for debugging unexpected (trap 30) interrupts.
This might be useful in the upcoming AMD64 port as well so it's worth
comitting.

20 years agoFix two bugs in split in split revealed after my optimization in
Hiten Pandya [Sat, 25 Oct 2003 14:14:52 +0000 (14:14 +0000)]
Fix two bugs in split in split revealed after my optimization in
last revision of this file.

Check for new file at the beginning and not at the end to avoid
the internal buffer getting confused.

Submitted by: Simon 'corecode' Schubert <corecode@fs.ei.tum.de>

20 years agoInterrupt threads could block in free waiting for kernel_map(). Add a
Matthew Dillon [Sat, 25 Oct 2003 00:48:03 +0000 (00:48 +0000)]
Interrupt threads could block in free waiting for kernel_map().  Add a
check for TDF_INTTHREAD to avoid this scenario.  This makes free() compatible
with assumptions made by softupdates().

20 years agoFix type-o's, minor documentation update.
Matthew Dillon [Fri, 24 Oct 2003 17:47:51 +0000 (17:47 +0000)]
Fix type-o's, minor documentation update.

Submitted-by: Eirik Nygaard <eirikn@kerneled.com>
20 years agoHonor MODULES_OVERRIDE if defined.
Matthew Dillon [Fri, 24 Oct 2003 17:22:15 +0000 (17:22 +0000)]
Honor MODULES_OVERRIDE if defined.

Submitted-by: Skip Ford <skip.ford@verizon.net>
20 years agoThis is FreeBSD 5.x's code to dump the kernel's identifier through
Matthew Dillon [Fri, 24 Oct 2003 17:19:16 +0000 (17:19 +0000)]
This is FreeBSD 5.x's code to dump the kernel's identifier through
either the 'kern.ident' oid or with uname -i.

Submitted-by: Skip Ford <skip.ford@verizon.net>
20 years agoAdd SIGCKPT support to tcsh's built-in kill.
Matthew Dillon [Fri, 24 Oct 2003 17:14:14 +0000 (17:14 +0000)]
Add SIGCKPT support to tcsh's built-in kill.

Submitted-by: Emiel Kollof <coolvibe@hackerheaven.org>
20 years agoRemove the FreeBSD 3.x signal code. This includes osendsig(),
David P. Reese, Jr. [Fri, 24 Oct 2003 14:10:46 +0000 (14:10 +0000)]
Remove the FreeBSD 3.x signal code.  This includes osendsig(),
osigreturn() and a couple of structures that these syscalls depended
on.

Split the sigaction(), sigprocmask(), sigpending(), sigsuspend(),
sigaltstack() and kill() syscalls.

Move the 4.3BSD signal syscalls osigvec(), osigblock(), osigsetmask(),
osigstack() and okillpg() to the 43bsd subtree.  I'm not too sure
if these will even work with the FreeBSD-4 signal trampoline code,
but they do compile and link.

Implement linux_signal(), linux_rt_sigaction(), linux_sigprocmask(),
linux_rt_sigprocmask(), linux_sigpending(), linux_kill(),
linux_sigaction(), linux_sigsuspend(), linux_rt_sigsuspend(),
linux_pause(), and linux_sigaltstack() with the new in-kernel syscalls.
This patch kills 7 stackgap allocations in the Linuxolator.

20 years agoHook i386/vesa up to the module build
Matthew Dillon [Thu, 23 Oct 2003 17:32:54 +0000 (17:32 +0000)]
Hook i386/vesa up to the module build

20 years agomakesyscalls.sh wants comments to be on their own line. Move the Checkpoint
David P. Reese, Jr. [Thu, 23 Oct 2003 00:04:58 +0000 (00:04 +0000)]
makesyscalls.sh wants comments to be on their own line.  Move the Checkpoint
comment to its own line.

20 years ago* Un-break buildworld
David Rhodus [Wed, 22 Oct 2003 17:00:53 +0000 (17:00 +0000)]
* Un-break buildworld

20 years agoMSGF_DONE needs to be cleared when a message is to be handled asynchronously.
Matthew Dillon [Wed, 22 Oct 2003 01:01:16 +0000 (01:01 +0000)]
MSGF_DONE needs to be cleared when a message is to be handled asynchronously.
Nobody uses lwkt_waitmsg() yet so the bug didn't effect anything.

Noticed-by: Galen Sampson <galen_sampson@yahoo.com>
20 years agoAdd support for SIGCKPT to csh/tcsh's internal 'kill' command.
Matthew Dillon [Wed, 22 Oct 2003 01:00:16 +0000 (01:00 +0000)]
Add support for SIGCKPT to csh/tcsh's internal 'kill' command.

Submitetd-by: Kenneth Culver <culverk@sweetdreamsracing.biz>
20 years agoUse sys_nsig instead of NSIG so libc-suspplied arrays match up.
Matthew Dillon [Wed, 22 Oct 2003 00:51:15 +0000 (00:51 +0000)]
Use sys_nsig instead of NSIG so libc-suspplied arrays match up.

20 years agoFix bug in last commit, flags were not being passed to fo_write() which
Matthew Dillon [Tue, 21 Oct 2003 20:06:47 +0000 (20:06 +0000)]
Fix bug in last commit, flags were not being passed to fo_write() which
broke pwrite().  This caused samba to stop working (amoung other things).

Samba problem reported by: David Rhodus <drhodus@catpa.com>

20 years agoA hackish fix to a bug uio_yield().
Matthew Dillon [Tue, 21 Oct 2003 04:14:58 +0000 (04:14 +0000)]
A hackish fix to a bug uio_yield().

20 years agoCreate the kern_fstat() and kern_ftruncate() in-kernel syscalls.
David P. Reese, Jr. [Tue, 21 Oct 2003 01:05:09 +0000 (01:05 +0000)]
Create the kern_fstat() and kern_ftruncate() in-kernel syscalls.

Implement fstat(), nfstat() and ftruncate() using the in-kernel syscalls.

Move ofstat() and oftruncate() to the 43bsd emulation tree and implement
with in-kernel syscalls.

Create the linux_ftruncate() syscall in the linux emulation layer.  This
replaces a direct use of oftruncate() in the linux syscall map.  Rewrite
linux_newfstat() and linux_fstat64() with the in-kernel syscalls.

20 years agoYah yah. Always good to commit the header file needed for the last fix.
Matthew Dillon [Mon, 20 Oct 2003 16:50:39 +0000 (16:50 +0000)]
Yah yah.  Always good to commit the header file needed for the last fix.

20 years agoFix a bug introduced by recent INVARIANTS debugging additions, sometimes
Matthew Dillon [Mon, 20 Oct 2003 16:09:00 +0000 (16:09 +0000)]
Fix a bug introduced by recent INVARIANTS debugging additions, sometimes
the first word of M_ZERO'd memory isn't zero'd.

20 years agoFix an error message.
Matthew Dillon [Mon, 20 Oct 2003 07:01:05 +0000 (07:01 +0000)]
Fix an error message.

20 years agoDo a bit of cleanup and add a bit of debugging to the checkpoint module.
Matthew Dillon [Mon, 20 Oct 2003 06:50:51 +0000 (06:50 +0000)]
Do a bit of cleanup and add a bit of debugging to the checkpoint module.

Fix a bug in the offset calculations in the ELF checkpoint file descriptor
writeout code... one loop was skipping descriptors 0,1,2, another loop
was not.  This bug had prevented 'primes' from being properly checkpointed.

20 years agoAdd the checkpt module to the system tree. Currently this may only be
Matthew Dillon [Mon, 20 Oct 2003 04:48:42 +0000 (04:48 +0000)]
Add the checkpt module to the system tree.  Currently this may only be
loaded as a module, not configured into the kernel directly.

20 years agoAdditional checkpoint suppor for vmspace info. In particular, the data size
Matthew Dillon [Mon, 20 Oct 2003 04:47:35 +0000 (04:47 +0000)]
Additional checkpoint suppor for vmspace info.  In particular, the data size
is used by sbrk and must be restored for programs to work properly.

20 years agoAdd the 'checkpt' utility to support the process checkpoint module. This
Matthew Dillon [Mon, 20 Oct 2003 04:46:14 +0000 (04:46 +0000)]
Add the 'checkpt' utility to support the process checkpoint module.  This
originated from Kip Macy with cleanups and modifications by Matt Dillon.

Note: currently i386-specific.  The system calls have not been integrated
into libc yet.

Submitted-by: Kip Macy <kmacy@fsmware.com>
20 years agoAdd the 'checkpt' utility to support the process checkpoint module. This
Matthew Dillon [Mon, 20 Oct 2003 04:45:54 +0000 (04:45 +0000)]
Add the 'checkpt' utility to support the process checkpoint module.  This
originated from Kip Macy with cleanups and modifications by Matt Dillon.

Submitted-by: Kip Macy <kmacy@fsmware.com>
20 years agoAdd a fp_vpopen() function to kern_fp.c, and add reserved fields to
Matthew Dillon [Sun, 19 Oct 2003 23:23:29 +0000 (23:23 +0000)]
Add a fp_vpopen() function to kern_fp.c, and add reserved fields to
various checkpoint structures.

20 years agoUn-initialise (i.e free) the HPFS inode hash; previously, unloading
Hiten Pandya [Sun, 19 Oct 2003 21:24:55 +0000 (21:24 +0000)]
Un-initialise (i.e free) the HPFS inode hash; previously, unloading
the HPFS module led to stray number of bytes still being allocated.
32K almost.

Related to:

   malloc_uninit: 32768 bytes of 'HPFS hphash' still allocated on cpu0

20 years agoEnhance the fp_*() API. Reorganize the ELF dump code using the fp_*()
Matthew Dillon [Sun, 19 Oct 2003 19:24:20 +0000 (19:24 +0000)]
Enhance the fp_*() API.  Reorganize the ELF dump code using the fp_*()
API and adding hooks to make checkpointing easier.

Submitted-by: Kip Macy <kmacy@fsmware.com>
20 years agoFix the INVARIANTS memuse test, the memuse for each cpu must be aggregated
Matthew Dillon [Sun, 19 Oct 2003 18:18:50 +0000 (18:18 +0000)]
Fix the INVARIANTS memuse test, the memuse for each cpu must be aggregated
and the final total used.  Array entries cannot be used individually.

20 years agoFix a ``missing free''.
Hiten Pandya [Sun, 19 Oct 2003 18:11:37 +0000 (18:11 +0000)]
Fix a ``missing free''.

The NTFS Inode hashing code did not free the inode hash, which caused
the following warning at unload time.  This is only noticed when NTFS
is loaded as a KLD module:

   malloc_uninit: 32768 bytes of 'NTFS nthash' still allocated on cpu0

Use vfs_uninit() entry point to solve this issue, by calling (new)
ntfs_nthash_uninit() function to release the NT inode hash.

20 years agoUnravel a nested conditional.
Jeffrey Hsu [Sun, 19 Oct 2003 05:19:21 +0000 (05:19 +0000)]
Unravel a nested conditional.
Same as FreeBSD rev 1.185.

20 years agoEntirely remove the old kernel malloc and kmem_map code. The slab allocator
Matthew Dillon [Sun, 19 Oct 2003 00:23:30 +0000 (00:23 +0000)]
Entirely remove the old kernel malloc and kmem_map code.  The slab allocator
is now mandatory.  Also remove the related conf options, USE_KMEM_MAP and
NO_SLAB_ALLOCATOR.

20 years agoHack up param.h even more so sys/socket.h can include portions of it without
Matthew Dillon [Sun, 19 Oct 2003 00:13:18 +0000 (00:13 +0000)]
Hack up param.h even more so sys/socket.h can include portions of it without
polluting the namespace (like it did before), but without preventing another
header or source file from including it directly, as well.

20 years agoDon't try to call an ipiq function with a UP build when the cpuid doesn't
Matthew Dillon [Sat, 18 Oct 2003 23:59:58 +0000 (23:59 +0000)]
Don't try to call an ipiq function with a UP build when the cpuid doesn't
match, panic instead.

20 years agoAdd the pim(4) and multicast(4) manual pages, following
Hiten Pandya [Sat, 18 Oct 2003 21:40:41 +0000 (21:40 +0000)]
Add the pim(4) and multicast(4) manual pages, following
Jeffrey Hsu's recent addition of the Protocol Independent Multicasting
code.

Both manual pages by: Pavlin Radoslavov <pavlin@icir.org>

20 years agoRemove a diagnostic message that detected PHOLD() vs exit()/process-reaping
Matthew Dillon [Sat, 18 Oct 2003 20:41:08 +0000 (20:41 +0000)]
Remove a diagnostic message that detected PHOLD() vs exit()/process-reaping
races.  The races are handled just fine, the message was just to see if they
could even occur (and they can).

20 years agoFix races in ihashget that were introduced when I introduced the
Matthew Dillon [Sat, 18 Oct 2003 20:15:10 +0000 (20:15 +0000)]
Fix races in ihashget that were introduced when I introduced the
lwkt_gettoken() API to interlock the vnode and hash table ops.

Report-by: David Rhodus.
20 years agoUpdate sysinstall's NFS module:
Hiten Pandya [Sat, 18 Oct 2003 20:12:26 +0000 (20:12 +0000)]
Update sysinstall's NFS module:

* Add ability to select NFSv3 version (default)

* Add ability to use TCP as protocol.  TCP is
  not made default to retain automatic compatiblity
  with a wider range of NFS servers.

* Fix argument processing in mediaInitNFS(), variable_get()
  cannot be used in a conditional statement because it returns
  a "char *" string; instead, use variable_cmp().

* Update I/O block sizes in the case when NFS_SLOW is not
  set to "YES".  Previously, the NFS_SLOW case had a bigger
  block size than the fast case which defaulted to 512b,
  whereas the former was 1024.  The new block size used is
  4096, which is reasonable for the lowest of connection
  mediums.

Reviewed by: dillon, drhodus

20 years agomachine/param.h has to be included outside of _KERNEL for MAXCPU.
Matthew Dillon [Sat, 18 Oct 2003 20:07:32 +0000 (20:07 +0000)]
machine/param.h has to be included outside of _KERNEL for MAXCPU.

20 years agoMake vmstat -m understand the new per-cpu aggregation for
Matthew Dillon [Sat, 18 Oct 2003 19:59:45 +0000 (19:59 +0000)]
Make vmstat -m understand the new per-cpu aggregation for
malloc_type statistics.

20 years agoUse vnconfig(8) instead of mdconfig(8) to enable ${swapfile},
Hiten Pandya [Sat, 18 Oct 2003 14:17:30 +0000 (14:17 +0000)]
Use vnconfig(8) instead of mdconfig(8) to enable ${swapfile},
as the latter is not available.

Submitted by: Skip Ford <skip.ford@verizon.net>

20 years agoAdd SysV IPC regression suite.
Hiten Pandya [Sat, 18 Oct 2003 12:13:01 +0000 (12:13 +0000)]
Add SysV IPC regression suite.

Obtained from: NetBSD

20 years agoFix build by not attempting to compile libc's malloc directly.
Hiten Pandya [Sat, 18 Oct 2003 11:53:43 +0000 (11:53 +0000)]
Fix build by not attempting to compile libc's malloc directly.

Submitted by: Skip Ford <skip.ford@verizon.net>

20 years agoFix memory leaks in the namecache code commited so far to stabilize its
Matthew Dillon [Sat, 18 Oct 2003 05:53:57 +0000 (05:53 +0000)]
Fix memory leaks in the namecache code commited so far to stabilize its
memory use.  These are temporary fixes.

20 years agoMake malloc_type statistics per-cpu, which fixes statistics update races
Matthew Dillon [Sat, 18 Oct 2003 05:48:44 +0000 (05:48 +0000)]
Make malloc_type statistics per-cpu, which fixes statistics update races
in the slab allocator that would result in malloc statistics being way off.

20 years agoFix a uni-processor bug with the last commit... we weren't rescheduling on
Matthew Dillon [Fri, 17 Oct 2003 07:44:18 +0000 (07:44 +0000)]
Fix a uni-processor bug with the last commit... we weren't rescheduling on
priority changes.

20 years agoCleanup P_CURPROC and P_CP_RELEASED handling. P_CP_RELEASED prevents the
Matthew Dillon [Fri, 17 Oct 2003 07:30:43 +0000 (07:30 +0000)]
Cleanup P_CURPROC and P_CP_RELEASED handling.  P_CP_RELEASED prevents the
userland scheduler from messing with a process and must be set (in a lazy
fashion) when a thread that came in from userland is about to block in
the kernel.  P_CURPROC is used to manage which threads belonging to
processes controlled by the userland scheduler are scheduled by LWKT.
The userland scheduler has also been streamlined considerably.

p_priority now has a rollup priority that can be compared directly,
regardless of the realtime/idle/whatever queue a process is on.
p_priority has been changed from an unsigned char to a signed short.

schedclock is now distributed, so 'top' shows the correct values.

A huge amount of cpu affinity code has been added to the scheduler.  It is
not working 100% yet, but the framework is there (see kern/kern_switch.c).
globaldata now has gd_upri to support remote reschedule requests issued
by the affinity code.  There are two goals to the new scheduling code for
MP boxes: (1) so niced/idleprio cpu bound programs do not interfere
*at* *all* with other things (like, say, a buildworld).  (2) to reduce
the flip-flopping of processes between cpus.

lwkt_gettoken() now increments the generation number unconditionally so
kernel code can detect when other processes have used a token.

lwkt_send_ipiq_mask() removes stopped cpus from the mask automatically.

20 years agoCreate kern_readv() and kern_writev() and use them to split read(), pread(),
David P. Reese, Jr. [Fri, 17 Oct 2003 05:25:45 +0000 (05:25 +0000)]
Create kern_readv() and kern_writev() and use them to split read(), pread(),
readv(), write(), pwrite(), and writev().

Also, rewrite linux_pread() and linux_pwrite() using the in-kernel syscalls.

20 years agoRemove PUSER entirely. Since p_priority has nothing to do with kernel
Matthew Dillon [Thu, 16 Oct 2003 23:59:15 +0000 (23:59 +0000)]
Remove PUSER entirely.  Since p_priority has nothing to do with kernel
thread priorities, the userland scheduler can now use the entire range 0-127.

Document the estcpu and other macros related to the p_priority calculation.

Adjust the default values such that a cpu bound nice -20 process will not
completely starve a nice +0 process (though it gets close!).  Note that a
nice +2 process will not run at all in the face of a cpu bound nice -20
process.

20 years agoFix the userland scheduler. When the scheduler releases the P_CURPROC
Matthew Dillon [Thu, 16 Oct 2003 22:26:42 +0000 (22:26 +0000)]
Fix the userland scheduler.  When the scheduler releases the P_CURPROC
designation it unconditionally handed it off to the highest priority
process on the userland process queue, ignoring the fact that the 'current'
process might have had a higher priority.  There was also a missing call to
lwkt_maybe_switch() in the resched_wanted() case that could cause interrupt
threads to stall for a long period of time when they could not preempt.

In SMP there are still some issues.  Niced processes work better, but at
the moment the P_CURPROC handoff does not take into account the fact that
the new higher priority process might better be handed off to another cpu
that is running a lower priority process then the current cpu.

20 years agocorrect the .PATH for access to scvesactl.c
Matthew Dillon [Thu, 16 Oct 2003 01:18:00 +0000 (01:18 +0000)]
correct the .PATH for access to scvesactl.c

Report-by: David Rhodus <drhodus@catpa.com>
20 years agoHave lwkt_reltoken() return the generation number to facilitate checks
Matthew Dillon [Wed, 15 Oct 2003 23:27:06 +0000 (23:27 +0000)]
Have lwkt_reltoken() return the generation number to facilitate checks
for stolen tokens.  Cleanup, optimize, and better document lwkt_gentoken().

20 years agoFix an inherited bug in ptrace's PT_IO. The wrong thread was being assigned
Matthew Dillon [Wed, 15 Oct 2003 21:52:38 +0000 (21:52 +0000)]
Fix an inherited bug in ptrace's PT_IO.  The wrong thread was being assigned
to the UIO.

20 years agoSecond contigmalloc() cleanup:
Hiten Pandya [Wed, 15 Oct 2003 16:48:04 +0000 (16:48 +0000)]
Second contigmalloc() cleanup:

* Move the contigmalloc/vm_contig_pg API into its own
  file, vm_contig.c.

* Give contigmalloc1() a more sensible to reflect its
  purpose, contigmalloc_map().

20 years agoMajor contigmalloc() API cleanup:
Hiten Pandya [Wed, 15 Oct 2003 16:03:04 +0000 (16:03 +0000)]
Major contigmalloc() API cleanup:

    * split the contigmalloc() function into two distinct
      functions:

        - vm_contig_pg_alloc(): this function does the alloc
          of contiguous pages.

        - vm_contig_pg_kmap(): this function maps the allocated
          range of pages into a VM map (i.e. kernel map).

    * remove the duplicated page queue flush management handling
      and put it into a separate function, vm_contig_pg_clean().

The split is important for some special case drivers, which
like to allocated >2G contig memory, and then mmpa(2) it to
userland for various purposes.

By splitting, the contigmalloc/vm_contig_pg API does not
enforce the client to map the contiguous pages into the
KVA, which would have otherwise failed the allocation.

These functions will probably be moved to their own file
some time soon.

Reviewed/Approved/Tested by: Matt Dillon

20 years agoRemove zalloci/zfreei from the Makefile too.
Hiten Pandya [Wed, 15 Oct 2003 15:37:58 +0000 (15:37 +0000)]
Remove zalloci/zfreei from the Makefile too.

20 years agoNuke the zalloci() and zfree() stuff sky-high. We no longer have
Hiten Pandya [Wed, 15 Oct 2003 15:36:44 +0000 (15:36 +0000)]
Nuke the zalloci() and zfree() stuff sky-high.  We no longer have
those functions as zalloc/zfree are interrupt and MP safe.

20 years agoI wasn't properly checking for rollover in iovec_copyin(). Remove code
David P. Reese, Jr. [Wed, 15 Oct 2003 08:43:37 +0000 (08:43 +0000)]
I wasn't properly checking for rollover in iovec_copyin().  Remove code
that ineffectively checks for rollover by checking if a size_t was ever
less than zero (duh).

Add the proper error checking to kern_sendmsg() and kern_recvmsg() which
recieve a uio structure that was populated with the aid of iovec_copyin().

20 years agoRename do_dup() to kern_dup() and pull in some changes from FreeBSD-CURRENT.
David P. Reese, Jr. [Wed, 15 Oct 2003 06:38:46 +0000 (06:38 +0000)]
Rename do_dup() to kern_dup() and pull in some changes from FreeBSD-CURRENT.
Implement dup(), dup2() and fcntl(F_DUPFD) with kern_dup().

Split fcntl() into fcntl() and kern_fcntl().

Implement linux_fcntl() using kern_fcntl() and replace a call to fcntl()
in linux_accept() with a call to kern_fcntl().

20 years agoUpdate the sys_sig* manual page to include portability suggestions.
Matthew Dillon [Tue, 14 Oct 2003 23:13:05 +0000 (23:13 +0000)]
Update the sys_sig* manual page to include portability suggestions.

20 years agoNSIG is now 64. Extend the siglist arrays to match.
Matthew Dillon [Tue, 14 Oct 2003 23:04:10 +0000 (23:04 +0000)]
NSIG is now 64.  Extend the siglist arrays to match.

20 years ago/bin/sh needs to use sys_nsig, not NSIG, when accessing static arrays
Matthew Dillon [Tue, 14 Oct 2003 23:03:08 +0000 (23:03 +0000)]
/bin/sh needs to use sys_nsig, not NSIG, when accessing static arrays
defined in libc.  /bin/sh also needs to check for NULL entries.

20 years agoMake sure PORTSDIR is not in the environment when bootstrapping a
Matthew Dillon [Mon, 13 Oct 2003 23:57:41 +0000 (23:57 +0000)]
Make sure PORTSDIR is not in the environment when bootstrapping a
DragonFly port from a FreeBSD port.

20 years agoAdd checkpoint tty signaling support to stty and tcsh. The signal
Matthew Dillon [Mon, 13 Oct 2003 21:24:29 +0000 (21:24 +0000)]
Add checkpoint tty signaling support to stty and tcsh.  The signal
defaults to '^E'.

20 years agoOops, I gave Kip bad advise. The checkpoint execution code is supposed
Matthew Dillon [Mon, 13 Oct 2003 21:16:42 +0000 (21:16 +0000)]
Oops, I gave Kip bad advise.  The checkpoint execution code is supposed
to be in issignal(), not psignal()!

20 years agoStart separating the ucred from NDINIT.
Matthew Dillon [Mon, 13 Oct 2003 21:16:10 +0000 (21:16 +0000)]
Start separating the ucred from NDINIT.

20 years agoFix miscellanious kern_fp.c bugs.
Matthew Dillon [Mon, 13 Oct 2003 21:15:48 +0000 (21:15 +0000)]
Fix miscellanious kern_fp.c bugs.

20 years agoUse the one remaining free termios control character slot for a tty
Matthew Dillon [Mon, 13 Oct 2003 21:08:50 +0000 (21:08 +0000)]
Use the one remaining free termios control character slot for a tty
checkpoint capability, which defaults to ^E and sends the SIGCKPT signal.

20 years agoExtend NSIG to 64 and introduce a registration function for the checkpointing
Matthew Dillon [Mon, 13 Oct 2003 18:12:07 +0000 (18:12 +0000)]
Extend NSIG to 64 and introduce a registration function for the checkpointing
signal to support the checkpoint module.  This is somewhat of a hack at the
moment but will be cleaned up later.

Submitted-by: Kip Macy <kmacy@fsmware.com>
20 years agoAugment falloc() to support thread-only file pointers (with no integer file
Matthew Dillon [Mon, 13 Oct 2003 18:01:28 +0000 (18:01 +0000)]
Augment falloc() to support thread-only file pointers (with no integer file
descriptor or process).

Add new generic 'easy to use' fp_*() kernel functions which operate on file
pointers.  This will greatly ease in-kernel functions which must open,
perform I/O, and close files.

Adopted from: other kernel sources and Kip Macy's checkpoint code.

20 years agoAdd bsd.dfport.pre.mk and bsd.dfport.post.mk to the Makefile
Matthew Dillon [Mon, 13 Oct 2003 15:06:58 +0000 (15:06 +0000)]
Add bsd.dfport.pre.mk and bsd.dfport.post.mk to the Makefile

20 years agoadd /usr/share/examples/splash to the mtree, for installworld.
Matthew Dillon [Mon, 13 Oct 2003 08:43:56 +0000 (08:43 +0000)]
add /usr/share/examples/splash to the mtree, for installworld.

20 years agoFix an ordering issue, call vm_map_entry_reserve() prior to locking
Hiten Pandya [Mon, 13 Oct 2003 07:03:40 +0000 (07:03 +0000)]
Fix an ordering issue, call vm_map_entry_reserve() prior to locking
the map.

Noticed by: Matt

20 years agoAMI MegaRAID Crash-Dumps support.
Hiten Pandya [Mon, 13 Oct 2003 06:56:13 +0000 (06:56 +0000)]
AMI MegaRAID Crash-Dumps support.

Special thanks to Paul Saab (ps@FreeBSD.ORG) for providing the patch.

20 years agoImplement socket() and shutdown() using the in-kernel syscalls. This
David P. Reese, Jr. [Mon, 13 Oct 2003 04:58:13 +0000 (04:58 +0000)]
Implement socket() and shutdown() using the in-kernel syscalls.  This
commit completely removes COMPAT_43 and stackgap allocations from
linux_socket.c.

20 years agoFix kldload(2) error return when a module is rejected becaue it is
Hiten Pandya [Mon, 13 Oct 2003 04:16:51 +0000 (04:16 +0000)]
Fix kldload(2) error return when a module is rejected becaue it is
statically linked into the kernel.  This is due to a problem in the
linker code.  The EEXIST code which was returned was not reported
and instead an ENOEXEC was returned incorrectly, thus making stuff
like sysinstall act weirdly.

Obtained from: FreeBSD 5.x

20 years agoAdd a splash example / DragonFly BMP
Matthew Dillon [Mon, 13 Oct 2003 03:15:26 +0000 (03:15 +0000)]
Add a splash example / DragonFly BMP

Supplied-by: Emiel Kollof <coolvibe@hackerheaven.org>
20 years agoFix compile when GUPROF is defined.
Hiten Pandya [Sun, 12 Oct 2003 23:38:53 +0000 (23:38 +0000)]
Fix compile when GUPROF is defined.

I.e. add cpu_ prefix to disable_intr() and enable_intr().

20 years ago* Pull is some security checks from sendmail 8.12.10.
David Rhodus [Sun, 12 Oct 2003 16:56:26 +0000 (16:56 +0000)]
* Pull is some security checks from sendmail 8.12.10.

Discussed with: Greg Shapiro and Matt Dillon

20 years agoMore hacks to support DragonFly port overrides. Deal with ports which
Matthew Dillon [Sun, 12 Oct 2003 01:43:59 +0000 (01:43 +0000)]
More hacks to support DragonFly port overrides.  Deal with ports which
use bsd.port.pre.mk and bsd.port.post.mk.

20 years agoFix bugs introduced from the last commit. The loadav routine somehow got
Matthew Dillon [Sun, 12 Oct 2003 00:52:48 +0000 (00:52 +0000)]
Fix bugs introduced from the last commit.  The loadav routine somehow got
deleted, and other minor things.

20 years agodocument the new fdisk option.
Matthew Dillon [Sun, 12 Oct 2003 00:45:24 +0000 (00:45 +0000)]
document the new fdisk option.

20 years agoAdd a -p option to fdisk that allows it to operate on normal files which
Matthew Dillon [Sun, 12 Oct 2003 00:43:17 +0000 (00:43 +0000)]
Add a -p option to fdisk that allows it to operate on normal files which
represent disk images.

20 years agoUpgrade isc-dhcp, e.g. dhclient.
Matthew Dillon [Sat, 11 Oct 2003 21:14:25 +0000 (21:14 +0000)]
Upgrade isc-dhcp, e.g. dhclient.

Taken-from: FreeBSD-current

20 years agoadd bsd.dfport.pre.mk and bsd.dfport.post.mk, part of the DragonFly ports
Matthew Dillon [Sat, 11 Oct 2003 21:08:33 +0000 (21:08 +0000)]
add bsd.dfport.pre.mk and bsd.dfport.post.mk, part of the DragonFly ports
override mechanism.

20 years ago* Add missing function declaration that was some how
David Rhodus [Sat, 11 Oct 2003 19:30:42 +0000 (19:30 +0000)]
* Add missing function declaration that was some how
missed during inital ACPI import.

20 years ago* Move variable 'p' into a more proper place.
David Rhodus [Sat, 11 Oct 2003 19:04:58 +0000 (19:04 +0000)]
* Move variable 'p' into a more proper place.

20 years ago* Add this nice filesystem testing tool that I've recently
David Rhodus [Sat, 11 Oct 2003 13:37:14 +0000 (13:37 +0000)]
* Add this nice filesystem testing tool that I've recently
missed having close by.

20 years agoCorrect unsafe use of realloc().
Hiten Pandya [Sat, 11 Oct 2003 11:38:44 +0000 (11:38 +0000)]
Correct unsafe use of realloc().

Obtained from: FreeBSD (KAME commit by Hajimu UMEMOTO)