]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/log
FreeBSD/FreeBSD.git
18 years agoMake COUNT_IPIS and COUNT_XINVLTLB_HITS real kernel options and take
jhb [Tue, 22 Nov 2005 22:54:42 +0000 (22:54 +0000)]
Make COUNT_IPIS and COUNT_XINVLTLB_HITS real kernel options and take
them out of machine/smptests.h.

18 years agoGarbage collect unused {VERBOSE_,}CPUSTOP_ON_DDBBREAK macros.
jhb [Tue, 22 Nov 2005 22:37:13 +0000 (22:37 +0000)]
Garbage collect unused {VERBOSE_,}CPUSTOP_ON_DDBBREAK macros.

18 years agoGarbage collect the code to store diagnostics codes in a CMOS register
jhb [Tue, 22 Nov 2005 22:34:14 +0000 (22:34 +0000)]
Garbage collect the code to store diagnostics codes in a CMOS register
during SMP startup.  We haven't had any issues with starting up the APs
on i386 in quite a while now which is all this code is really useful for.
If someone ever does really need it they can always dig it up out of the
attic.

18 years ago- Add a workaround (change the interrupt map mask to compare the full
marius [Tue, 22 Nov 2005 22:32:50 +0000 (22:32 +0000)]
- Add a workaround (change the interrupt map mask to compare the full
  INO) for incorrect interrupt map entries on E250 machines. These
  incorrect entries caused the INO of the on-board HME to be also
  assigned to the second on-board NS16550 and to the on-board printer
  port controller. Further down the road caused hme(4) to fail to attach
  to the on-board HME in FreeBSD 5 and 6 as INTR_FAST and non-INTR_FAST
  handlers can't share the same IRQ there (it's unknown what whould
  happen in -CURRENT now that INTR_FAST and non-INTR_FAST handlers can
  share an IRQ but I'd expect funny problems with uart(4)).
- Make sure there are exactly 4 PCI ranges instead of just checking
  that the bridge has a 'ranges' property in the OFW device tree at all.
  Besides the fact that currently the 64bit memory range isn't used by
  this driver it we can't really work with less than 4 ranges and don't
  have memory for more than 4 bus handles for the ranges in the softc.
- Remove sc_range and sc_nrange from softc; for the bridges supported
  by this driver we no longer need to know the ranges besides the bus
  handles obtained from them once this driver is attached. That way we
  also can free the memory allocated for sc_range during attach again.
- Remove sc_dvmabase from the softc and pass it to psycho_iommu_init()
  via an additional argument as we no longer need to know the DVMA base
  in this driver once the IOMMU is initialized.
- Remove sc_dmatag from the softc, there isn't much sense in keeping
  the nexus dma tag around locally.

PR: 88279 [1]
Info from: OpenSolaris [1]
Tested by: kensmith [1]
MFC after: 1 month

18 years agoUpdate the test for failed zone transfers to reflect BIND 9.3.1 semantics
dougb [Tue, 22 Nov 2005 22:24:27 +0000 (22:24 +0000)]
Update the test for failed zone transfers to reflect BIND 9.3.1 semantics
Simplify the shell scripting a bit, and remove a useless grep | sed

The problem was pointed out by the PR, and I used part of the solution
suggested there, but the semantics changed again for 9.2.x -> 9.3.x.

PR: conf/74228
Submitted by: Jeremy Chadwick <freebsd@jdc.parodius.com>

18 years agoSome clean-up, style changes and changes that will reduce differences
marius [Tue, 22 Nov 2005 21:34:26 +0000 (21:34 +0000)]
Some clean-up, style changes and changes that will reduce differences
between this driver and other Host-PCI bridge drivers based on this one:

- Make the code fit into 80 columns.
- Make the code adhere style(9) (don't use function calls in initializers,
  use uintXX_t instead of u_intXX_t, add missing prototypes, ...).
- Remove unused and superfluous struct declaration, softc member, casts,
  includes, etc.
- Use FBSDID.
- Sprinkle const.
- Try to make comments and messages consistent in style throughout the
  driver.
- Use convenience macros for the number of interrupts and ranges of the
  bridge.
- Use __func__ instead of hardcoded function names in panic strings and
  error messages. Some of the hardcoded function names actually were
  outdated through moving code around. [1]
- Rename softc members related to the PCI side of the bridge to sc_pci_*
  in order to make it clear which side of the bridge they refer to (so
  stuff like sc_bushandle vs. sc_bh is less confusing while reading the
  code).

PR: 76052 [1]

18 years agoUnbreak installworld.
ru [Tue, 22 Nov 2005 20:47:43 +0000 (20:47 +0000)]
Unbreak installworld.

18 years agoRemove not needed redirection of kldstat -q output to /dev/null.
emax [Tue, 22 Nov 2005 19:17:41 +0000 (19:17 +0000)]
Remove not needed redirection of kldstat -q output to /dev/null.

Noticed by: pjd
MFC after: 3 days

18 years agoRevise hcsecd(8) and sdpd(8) rc.d scripts one more time
emax [Tue, 22 Nov 2005 18:51:43 +0000 (18:51 +0000)]
Revise hcsecd(8) and sdpd(8) rc.d scripts one more time

- Use _prestart rc.d method to automatically kldload ng_btsocket(4) if needed;

- Rename "sdpd_user" to "sdpd_username" and "sdpd_group" to "sdpd_groupname"
  to avoid collision with "magic" variables;

Inspired by: yar
MFC after: 3 days

18 years ago- Add ofw_bus_if.h to SRCS on sparc64 as envctrl.c and pcf_ebus.c depend
marius [Tue, 22 Nov 2005 17:32:51 +0000 (17:32 +0000)]
- Add ofw_bus_if.h to SRCS on sparc64 as envctrl.c and pcf_ebus.c depend
  on it.
- Sync with sys/conf/files* and build pcf_isa.c only on i386 for now.
- Try to adhere to style.Makefile(5) (sorting, whitespace).

18 years agoConditionalize the compilation of the envctrl.c front-end of pcf(4)
marius [Tue, 22 Nov 2005 17:25:10 +0000 (17:25 +0000)]
Conditionalize the compilation of the envctrl.c front-end of pcf(4)
additionally on ebus(4) as the 'SUNW,envctrl' devices (as well as
'SUNW,envctrltwo' and 'SUNW,rasctrl', which we might want to also
support in envctrl.c in the future) are only found on EBus.

18 years agoMove zs.c from files to files.powerpc as zs(4) by now is only supported
marius [Tue, 22 Nov 2005 17:12:49 +0000 (17:12 +0000)]
Move zs.c from files to files.powerpc as zs(4) by now is only supported
on powerpc (more or less...). That way people updating from FreeBSD 5 to
FreeBSD 6 and beyond on sparc64 will get an error from config(8) rather
than a mysterious compile error when they have a stale 'device zs' in
their kernel config file.

MFC after: 2 weeks

18 years ago- Convert these bus drivers to make use of the newly introduced set of
marius [Tue, 22 Nov 2005 16:39:44 +0000 (16:39 +0000)]
- Convert these bus drivers to make use of the newly introduced set of
  ofw_bus_gen_get_*() for providing the ofw_bus KOBJ interface in order
  to reduce code duplication.
- While here sync the various sparc64 bus drivers a bit (handle failure
  to attach a child gracefully instead of panicing, move the printing
  of child resources common to bus_print_child() and bus_probe_nomatch()
  implementations of a bus into a <bus>_print_res() function, ...) and
  fix some minor bugs and nits (plug memory leaks present when attaching
  a bus or child device fails, remove unused struct members, ...).

Additional testing by: kris (central(4) and fhc(4))

18 years ago- Add a new method ofw_bus_default_get_devinfo() that allows to retrieve
marius [Tue, 22 Nov 2005 16:37:45 +0000 (16:37 +0000)]
- Add a new method ofw_bus_default_get_devinfo() that allows to retrieve
  a newly introduced struct ofw_bus_devinfo which can hold the OFW info
  of a device recallable via the ofw_bus KOBJ interface. Introduce a set
  of functions ofw_bus_gen_get_*() which use ofw_bus_default_get_devinfo()
  to provide generic subroutines for implementing the rest of the ofw_bus
  KOBJ interface in a bus driver.
  This is inspired by bus_get_resource_list() and bus_generic_rl_*_resource()
  and allows to reduce code duplication in bus drivers as they only have
  to provide an ofw_bus_default_get_devinfo() implementation in order to
  provide the ofw_bus KOBJ interface via ofw_bus_gen_get_*().
- While here add a comment to ofw_bus_if.m describing the intention of
  the ofw_bus KOBJ interface.

Reviewed by: marcel

18 years agoRemove unused function and variables.
marius [Tue, 22 Nov 2005 14:21:03 +0000 (14:21 +0000)]
Remove unused function and variables.

18 years agoCheck IFF_DRV_RUNNING in the re_intr() loop. It can disappear,
glebius [Tue, 22 Nov 2005 12:46:15 +0000 (12:46 +0000)]
Check IFF_DRV_RUNNING in the re_intr() loop. It can disappear,
since re_rxeof() drops the lock for some time.

Reported & tested by: XueFeng Deng <dsnofe yahoo.com.cn>

18 years agoGet rid of SPECIAL_INSTALLCHECKS variable that isn't settable
ru [Tue, 22 Nov 2005 12:02:41 +0000 (12:02 +0000)]
Get rid of SPECIAL_INSTALLCHECKS variable that isn't settable
by a user.  Instead, add individual checks as dependencies to
the main "installcheck" target.  Make sure that installkernel
etc. depend on it (including the UID/GID checks).

18 years agoFold some common stuff into a macro ${KMAKE}.
ru [Tue, 22 Nov 2005 11:31:03 +0000 (11:31 +0000)]
Fold some common stuff into a macro ${KMAKE}.

18 years agoFix interaction with Windows 2000/XP based servers:
bp [Tue, 22 Nov 2005 07:13:00 +0000 (07:13 +0000)]
Fix interaction with Windows 2000/XP based servers:

If the complete reply on the TRANS2_FIND_FIRST2 request fits exactly
into one responce packet, then next call to TRANS2_FIND_NEXT2 will return
zero entries and server will close current transaction.  To avoid
subsequent errors we should not perform FIND_CLOSE2 request.

PR: kern/78953
Submitted by: Jim Carroll

18 years agoCache the result of battery info retrieval from smbat as well
ume [Tue, 22 Nov 2005 03:34:09 +0000 (03:34 +0000)]
Cache the result of battery info retrieval from smbat as well
as cmbat.

Reviewed by: njl
MFC after: 3 days

18 years agoPrevent module unloading if there are active connections.
bp [Tue, 22 Nov 2005 02:15:46 +0000 (02:15 +0000)]
Prevent module unloading if there are active connections.

PR: kern/89085
Submitted by: Rostislav Krasny
MFC after: 1 week

18 years agoFix a bug in the loop in sonewconn that makes room on the incomplete
jdp [Tue, 22 Nov 2005 01:55:29 +0000 (01:55 +0000)]
Fix a bug in the loop in sonewconn that makes room on the incomplete
connection queue for a new connection.  It was removing connections
from the wrong list.

Submitted by: Paul Mikesell
Sponsored by: Isilon Systems
MFC after: 1 week

18 years agoResolve misalignment traps caused by changes to IF_LLADDR().
marcel [Tue, 22 Nov 2005 01:51:57 +0000 (01:51 +0000)]
Resolve misalignment traps caused by changes to IF_LLADDR().
Use de16dec() and le16dec() to fetch the link-level address
from struct ifnet.

Tested on: alpha
Reviewed by: jhb
See also: de(4)

18 years agoBring mount_nullfs up to WARNS=6.
rodrigc [Mon, 21 Nov 2005 22:51:16 +0000 (22:51 +0000)]
Bring mount_nullfs up to WARNS=6.

18 years agoOverhaul nve(4) locking to make it more like other ethernet drivers in
jhb [Mon, 21 Nov 2005 22:14:49 +0000 (22:14 +0000)]
Overhaul nve(4) locking to make it more like other ethernet drivers in
the tree.
- Add locked variants of nve_start(), nve_init(), and nve_ifmedia_upd().
- Use callout_* to manage callouts rather than timeout(9).
- Mark interrupt handler MPSAFE (IFF_NEEDGIANT was already clear).
- Lock the driver lock in driver entry points such as the interrupt
  handler, if_start, and if_init rather than locking the driver mutex
  in the various work functions called by the binary blob.  The spin lock
  used by the binary block can probably be stubbed out now.
- Use IFQ_DRV_IS_EMPTY() macro rather than doing it by hand.
- Fix locking in detach.
- Remove some unused fields from the softc.

Tested by: cognet
MFC after: 2 weeks

18 years agoFor mounting a UFS filesystem, call nmount() directly, instead of having
rodrigc [Mon, 21 Nov 2005 22:07:54 +0000 (22:07 +0000)]
For mounting a UFS filesystem, call nmount() directly, instead of having
special logic which called mount() in a separate mount_ufs() function.

18 years agoFix the code to look up the BIOS IRQ for a given link device by reading
jhb [Mon, 21 Nov 2005 22:01:16 +0000 (22:01 +0000)]
Fix the code to look up the BIOS IRQ for a given link device by reading
the IRQ set by the BIOS in existing devices to actually get the correct
bus number of the child PCI bus.  I was not reading the bus number from
the bridge device correctly.  The __BUS_ACCESSOR() macros (from which
pcib_get_bus() is built) assume that the passed in argument is a child
device.  However, at the time I'm reading the bus there is no child
device yet, so I was passing in the pcib device as the child device.
The parent of the pcib device probably returned an error in the case of
a host bridge, thus resulting in random stack garbage for the bus number.
For PCI-PCI bridges, the bus number being used was actually the subvendor
of the PCI-PCI bridge device itself.

MFC after: 1 week

18 years agoVarious fixes to make de(4) not panic after ru@'s IF_LLADDR() changes:
jhb [Mon, 21 Nov 2005 21:50:07 +0000 (21:50 +0000)]
Various fixes to make de(4) not panic after ru@'s IF_LLADDR() changes:
- Don't call tulip_addr_filter() to reset the RX address filter in
  tulip_reset() since that gets called before ether_ifattach().  Just
  call it in tulip_init_locked().
- Use be16dec() and le16dec() to parse MAC addresses when programming
  the RX filter.
- Let ether_ioctl() handle SIOCSIFMTU since we were doing the exact same
  thing with the added bonus that we leaked the driver lock if the MTU
  was > ETHERMTU in the homerolled version.  This part will be MFC'd.

Clue from: wpaul (1)
Stolen from: marcel (2 via patch for dc(4))
MFC after: 1 week

18 years agoadd witty remark about serious thought.
wilko [Mon, 21 Nov 2005 21:42:43 +0000 (21:42 +0000)]
add witty remark about serious thought.

MFC after: 2 days

18 years agoTurn PUC_FASTINTR back off on by default on sparc64 since it breaks with
jhb [Mon, 21 Nov 2005 21:40:33 +0000 (21:40 +0000)]
Turn PUC_FASTINTR back off on by default on sparc64 since it breaks with
the built-in serial ports on the ultra60 and e4500.

In collusion with: kris

18 years agoTeach schedgraph how to parse KTR_CRITICAL records. critical_enter/exit
scottl [Mon, 21 Nov 2005 21:27:40 +0000 (21:27 +0000)]
Teach schedgraph how to parse KTR_CRITICAL records.  critical_enter/exit
events are now plotted as a counting graph, similar to CPU load, so that
their duration and critnest values can be visualized.

18 years agoDon't enable PUC_FASTINTR by default in the source. Instead, enable it
jhb [Mon, 21 Nov 2005 20:22:35 +0000 (20:22 +0000)]
Don't enable PUC_FASTINTR by default in the source.  Instead, enable it
via the DEFAULTS kernel configs.  This allows folks to turn it that option
off in the kernel configs if desired without having to hack the source.
This is especially useful since PUC_FASTINTR hangs the kernel boot on my
ultra60 which has two uart(4) devices hung off of a puc(4) device.

I did not enable PUC_FASTINTR by default on powerpc since powerpc does not
currently allow sharing of INTR_FAST with non-INTR_FAST like the other
archs.

18 years agoCreate DEFAULTS files for alpha, ia64, powerpc, and sparc64 and move
jhb [Mon, 21 Nov 2005 20:17:46 +0000 (20:17 +0000)]
Create DEFAULTS files for alpha, ia64, powerpc, and sparc64 and move
'device mem' over from GENERIC to DEFAULTS to be consistent with i386 and
amd64.  Additionally, on ia64 enable ACPI by default since ia64 requires
acpi.

18 years agoPull up sys/modules/acpi/acpi/Makefile,v 1.10 change by iedowse@.
ru [Mon, 21 Nov 2005 20:11:39 +0000 (20:11 +0000)]
Pull up sys/modules/acpi/acpi/Makefile,v 1.10 change by iedowse@.
This should fix another parallel make breakage, reported by pjd@.

18 years agoFix for a bug where NFS/TCP would not reconnect (in the case where
ps [Mon, 21 Nov 2005 19:25:24 +0000 (19:25 +0000)]
Fix for a bug where NFS/TCP would not reconnect (in the case where
the server FIN'ed). Seen with Solaris NFS servers.

Reported by: TOMITA Yoshinori <yoshint@flab.fujitsu.co.jp>
Submitted by: Mohan Strinivasan

18 years ago- Always return success from NFS strategy. nfs_doio(), in the
ps [Mon, 21 Nov 2005 19:23:46 +0000 (19:23 +0000)]
- Always return success from NFS strategy. nfs_doio(), in the
  event of an error, does the right thing, in terms of setting
  the error flags in the buf header. That fixes a crash from
  bstrategy().
- Treat ETIMEDOUT as a "recoverable" error, causing the buffer
  to be re-dirtied. ETIMEDOUT can occur on soft mounts, when
  the number of retries are exceeded, and we don't want data loss
  in that case.

Submitted by: Mohan Srinivasan

18 years agoFix for a bug that causes SACK scoreboard corruption when the limit
ps [Mon, 21 Nov 2005 19:22:10 +0000 (19:22 +0000)]
Fix for a bug that causes SACK scoreboard corruption when the limit
on holes per connection is reached.

Reported by: Patrik Roos
Submitted by: Mohan Srinivasan
Reviewed by: Raja Mukerji, Noritoshi Demizu

18 years agoForce pmap to write-back the pte cacheline after each pte modification,
cognet [Mon, 21 Nov 2005 19:10:44 +0000 (19:10 +0000)]
Force pmap to write-back the pte cacheline after each pte modification,
even if the pte is supposed to be cached in write through mode (might be a
skyeye bug, I'll have to check).

18 years agoAdd an alternate ID for the arm920t (the real solution is to have
cognet [Mon, 21 Nov 2005 19:06:25 +0000 (19:06 +0000)]
Add an alternate ID for the arm920t (the real solution is to have
per-cpu class masks, but oh well).

18 years agofix a problem with XID re-use when a server returns NFSERR_JUKEBOX.
rees [Mon, 21 Nov 2005 18:39:18 +0000 (18:39 +0000)]
fix a problem with XID re-use when a server returns NFSERR_JUKEBOX.

Submitted by: cel@citi.umich.edu
Fixed by: rick@snowhite.cis.uoguelph.ca
Approved by: alfred
MFC after: 3 weeks

18 years agoExpand the hack to mask the atpics if 'device atpic' is not in the kernel
jhb [Mon, 21 Nov 2005 18:39:17 +0000 (18:39 +0000)]
Expand the hack to mask the atpics if 'device atpic' is not in the kernel
during boot up.  Now we do a full reset of the 8259As and setup a simple
interrupt handler (we actually borrow the apic one that just does an
immediate iret) to handle any spurious interrupts triggered by either chip.
This should fix some folks that were getting a Trap 30 during bootup of
certain SMP AMD systems.  This might get pushed into the 6.0 branch as an
errata.  For now a suitable workaround is to add 'device atpic' to your
kernel config.

Tested by: scottl
Helpful info from: dillon
MFC after: 1 week

18 years agoTidy up markup and fix two bugs.
ru [Mon, 21 Nov 2005 17:18:34 +0000 (17:18 +0000)]
Tidy up markup and fix two bugs.

18 years ago- Merge FreeBSD Configuration subsection etc. with SYNOPSIS.
ru [Mon, 21 Nov 2005 16:44:16 +0000 (16:44 +0000)]
- Merge FreeBSD Configuration subsection etc. with SYNOPSIS.
- Remove the description of how to build a module.
- Remove the description of how to patch the sources.
- Refer to the polling(4) manpage on how to enable the polling mode.
- Tidy up markup.

18 years agoFix mysterious build failures (with parallel make) early in
ru [Mon, 21 Nov 2005 14:41:10 +0000 (14:41 +0000)]
Fix mysterious build failures (with parallel make) early in
buildkernel: provide a real but dummy name to ${DEPENDFILE}
so that the relevant exists() check in bsd.prog.mk fails and
ensures that ${GENHDRS} are built before any other objects.

MFC after: 3 days

18 years agoMess up the "kernel" float trig function .c files with ifdefs so that
bde [Mon, 21 Nov 2005 04:57:12 +0000 (04:57 +0000)]
Mess up the "kernel" float trig function .c files with ifdefs so that
they can be #included in other .c files to give inline functions, and
use them to inline the functions in most callers (not in e_lgammaf_r.c).
__kernel_tanf() is too large and complicated for gcc to inline very well.

An athlons, this gives a speed increase under favourable pipeline
conditions of about 10% overall (larger for AXP, smaller for A64).
E.g., on AXP, sinf() on uniformly distributed args in [-2Pi, 2Pi]
now takes 30-56 cycles; it used to take 45-61 cycles; hardware fsin
takes 65-129.

18 years agoCreate a device node in /dev when a USB keyboard is plugged in.
arun [Mon, 21 Nov 2005 04:47:46 +0000 (04:47 +0000)]
Create a device node in /dev when a USB keyboard is plugged in.

Reviewed by: grehan

18 years agobusdma cleanup for em(4).
yongari [Mon, 21 Nov 2005 04:17:43 +0000 (04:17 +0000)]
busdma cleanup for em(4).
 - don't force busdma to pre-allocate bounce pages for parent tag.
 - use system supplied roundup2 macro instead of rolling its own version.
 - TX/RX decriptor length should be multiple of 128. There is no
   no need to expand the size with the multiple of 4096.
 - don't create/destroy DMA maps in TX/RX handlers. Use pre-allocated
   DMA maps. Since creating DMA maps on sparc64 is time consuming
   operations(resource mananger overhead), this change should boost
   performance on sparc64. I could get > 2x speedup on Ultra60.
 - TX/RX descriptors could be aligned on 128 boundary. Aligning them
   on PAGE_SIZE is waste of resource.
 - don't blindly create TX DMA tag with size of MCLBYTES * 8. The size
   is only valid under jumbo frame environments. Instead of using the
   hardcoded value, re-compute necessary size on the fly.
 - RX side bus_dmamap_load_mbuf_sg(9) support.
 - remove unused macro EM_ROUNDUP and constant EM_MMBA.

Reviewed by: scottl
Tested by: glebius

18 years agoAdd a hack to ignore PCR bit for 6300ESB, 82801[D-G]B chips. It seems
yongari [Mon, 21 Nov 2005 03:37:43 +0000 (03:37 +0000)]
Add a hack to ignore PCR bit for 6300ESB, 82801[D-G]B chips. It seems
that enabling busmastering would result in PCR bit ON after codec
reset.
While I'm here add DELAY(1) to codec access routine to give reasonable
time to codec operation. Without the delay, it would cause problems on
super-fast machines(> 2GHz). Also enable legacy audio for all 6300ESB,
82801[D-G]B chips. Previously, it enabled legacy audio for 82801DB(ICH4)
chip only.

Reported by:    Maxim Maximov mcsi AT mcsi DOT pp DOT ru
Andrew Bliznak andriko.b AT gmail DOT com
Tested by: brueffer, Maxim Maximov, Andrew Bliznak

18 years agoUse double precision to simplify and optimize a long division.
bde [Mon, 21 Nov 2005 00:38:21 +0000 (00:38 +0000)]
Use double precision to simplify and optimize a long division.

On athlons, this gives a speedup of 10-20% for tanf() on uniformly
distributed args in [-2Pi, 2Pi].  (It only directly applies for 43%
of the args and gives a 16-20% speedup for these (more for AXP than
A64) and this gives an overall speedup of 10-12% which is all that it
should; however, it gives an overall speedup of 17-20% with gcc-3.3
on AXP-A64 by mysteriously effected cases where it isn't executed.)

I originally intended to use double precision for all internals of
float trig functions and will probably still do this, but benchmarking
showed that converting to double precision and back is a pessimization
in cases where a simple float precision calculation works, so it may
be optimal to switch precisions only when using extra precision is
much simpler.

18 years agoRestored a cleanup in rev.1.9 tthat was lost in rev.1.10.
bde [Sun, 20 Nov 2005 20:17:04 +0000 (20:17 +0000)]
Restored a cleanup in rev.1.9 tthat was lost in rev.1.10.

18 years agoIf export mount flag is not passed in, set default parameters
rodrigc [Sun, 20 Nov 2005 17:04:50 +0000 (17:04 +0000)]
If export mount flag is not passed in, set default parameters
for export structure and pass that to vfs_export().
Currently in userland mount(8), an export structure is unconditionally
passed in, only for UFS.  This is an attempt to move that UFS-specific
behavior out of mount(8) and into the UFS filesystem code.

18 years agoInclude ip_options.h for IPX-IP encapsulation.
andre [Sun, 20 Nov 2005 16:17:12 +0000 (16:17 +0000)]
Include ip_options.h for IPX-IP encapsulation.

Noticed by: Tinderbox
Sponsored by:   TCP/IP Optimization Fundraise 2005

18 years agoUse memcpy/memset consistently accross ipw and iwi instead of bcopy/bzero.
damien [Sun, 20 Nov 2005 16:13:00 +0000 (16:13 +0000)]
Use memcpy/memset consistently accross ipw and iwi instead of bcopy/bzero.

18 years agoDon't use /etc/firmware. /etc is for configuration files only.
damien [Sun, 20 Nov 2005 16:02:04 +0000 (16:02 +0000)]
Don't use /etc/firmware.  /etc is for configuration files only.
Use /boot to store firmware files instead.

Requested by: Daniel O'Connor, Scott Long

18 years agoUse the appropriate error function for displaying the error,
dds [Sun, 20 Nov 2005 13:48:15 +0000 (13:48 +0000)]
Use the appropriate error function for displaying the error,
instead of printing it to stdout.

MFC after: 1 week

18 years agoWhitespace.
le [Sun, 20 Nov 2005 12:14:18 +0000 (12:14 +0000)]
Whitespace.

18 years agoAlways declare variables at the start of the function.
le [Sun, 20 Nov 2005 12:12:31 +0000 (12:12 +0000)]
Always declare variables at the start of the function.
Don't allocate potentially large variables on the stack.
Check strsep() return values when the string comes from userland.
Shorten variable names for lucidity's sake.

most of the stuff:
Pointed out by:    njl@

18 years agoFix whitespace issue.
le [Sun, 20 Nov 2005 10:40:06 +0000 (10:40 +0000)]
Fix whitespace issue.

Pointed out by:   joel@

18 years agoFix whitespace issues.
le [Sun, 20 Nov 2005 10:35:46 +0000 (10:35 +0000)]
Fix whitespace issues.

Pointed out by:    joel@

18 years agoEliminate pmap_init2(). It's no longer used.
alc [Sun, 20 Nov 2005 06:09:49 +0000 (06:09 +0000)]
Eliminate pmap_init2().  It's no longer used.

18 years agoFix compile on 64-bit platforms.
scottl [Sun, 20 Nov 2005 04:27:24 +0000 (04:27 +0000)]
Fix compile on 64-bit platforms.

18 years agoImprove inittodr(). Assume the real-time clock is reliable and only
marcel [Sun, 20 Nov 2005 01:31:29 +0000 (01:31 +0000)]
Improve inittodr(). Assume the real-time clock is reliable and only
use the base time in case the real-time clock is bogus or behind the
base time. Most importantly, don't sanity-check the base time up front
because it may be zero. This is not a preposterous condition. It just
means that none of the file systems have their mount time updated.

MFC after: 1 week

18 years agoCorrect the API for Windows interupt handling a little. The prototype
wpaul [Sun, 20 Nov 2005 01:29:29 +0000 (01:29 +0000)]
Correct the API for Windows interupt handling a little. The prototype
for a Windows ISR is 'BOOLEAN isrfunc(KINTERRUPT *, void *)' meaning
the ISR get a pointer to the interrupt object and a context pointer,
and returns TRUE if the ISR determines the interrupt was really generated
by the associated device, or FALSE if not.

I had mistakenly used 'void isrfunc(void *)' instead. It happens the
only thing this affects is the internal ndis_intr() ISR in subr_ndis.c,
but it should be fixed just in case we ever need to register a real
Windows ISR vi IoConnectInterrupt().

For NDIS miniports that provide a MiniportISR() method, the 'is_our_intr'
value returned by the method serves as the return value from ndis_isr(),
and 'call_isr' is used to decide whether or not to schedule the interrupt
handler via DPC. For drivers that only supply MiniportEnableInterrupt()
and MiniportDisableInterrupt() methods, call_isr is always TRUE and
is_our_intr is always FALSE.

In the end, there should be no functional changes, except that now
ntoskrnl_intr() can terminate early once it finds the ISR that wants
to service the interrupt.

18 years agoAn empty file does not have a positive number of lines.
cperciva [Sun, 20 Nov 2005 00:50:30 +0000 (00:50 +0000)]
An empty file does not have a positive number of lines.

Make sure that the number of lines read is non-zero before in order to
avoid dumping core.

Reported by: Wojciech A. Koszek
Pointy hat to: cperciva

18 years agoAdd more options to ffs_opts, so that vfs_filteropts() will not
rodrigc [Sat, 19 Nov 2005 23:28:19 +0000 (23:28 +0000)]
Add more options to ffs_opts, so that vfs_filteropts() will not
complain when we pass these options to a UFS filesystem as strings
via nmount():  noexec, nosuid, nosymfollow, sync, suiddir

18 years agoReturn 0 if we are a network card and do match. Previously, we'd bogusly
imp [Sat, 19 Nov 2005 23:26:57 +0000 (23:26 +0000)]
Return 0 if we are a network card and do match.  Previously, we'd bogusly
fail and the card wouldn't be detected.

Submitted by: Bryan Blackburn

18 years agoFix bug introduced in revision 1.186:
marcel [Sat, 19 Nov 2005 21:51:45 +0000 (21:51 +0000)]
Fix bug introduced in revision 1.186:
  When all file systems have a time stamp of zero, which is the case
for example when the root file system is on a read-only medium, we
ended up not calling inittodr() at all.  A potential uncleanliness
existed as well. If multiple file systems had a non-zero time stamp,
we would call inittodr() multiple times. While this should not be
harmful, it's definitely not ideal.
Fix both issues by iterating over the mounted file systems to find
the largest time stamp and call inittodr() exactly once with that
time stamp. This could of course be a zero time stamp if none of the
mounted file systems have a non-zero time stamp. In that case the
annoying errors mentioned in the commit log for revision 1.186 still
haven't been avoided. The bottom line is that inittodr() should not
complain when it gets a time base of zero. At the time of this
commit only alpha seems to have that problem.

Reported by: Dario Freni (saturnero at freesbie dot org)
MFC after: 1 week

18 years agoParse more mount options in vfs_donmount(), before vfs_domount()
rodrigc [Sat, 19 Nov 2005 21:22:21 +0000 (21:22 +0000)]
Parse more mount options in vfs_donmount(), before vfs_domount()
is called.  It looks like there are lots of different mount flags checked
in vfs_domount(), so we need to do the parsing for these particular
mount flags earlier on.  The new flags parsed are:
async, force, multilabel, noasync, noatime, noclusterr, noclusterw,
noexec, nosuid, nosymfollow, snapshot, suiddir, sync, union.

Existing code which uses mount() to mount UFS filesystems is not
affected, but new code which uses nmount() to mount UFS filesystems
should behave better.

18 years agoFinally bring in what was produced during Google SoC 2005:
le [Sat, 19 Nov 2005 20:26:52 +0000 (20:26 +0000)]
Finally bring in what was produced during Google SoC 2005:

Add functions to rename objects and to move a subdisk from one drive
to another.

Add manual page (finally).

Bring up-to-date the online help.

Obtained from:  Chris Jones <chris.jones@ualberta.ca>
Sponsored by:   Google Summer of Code 2005
MFC in:         1 week

18 years agoFinally bring in what was produced during Google SoC 2005:
le [Sat, 19 Nov 2005 20:25:18 +0000 (20:25 +0000)]
Finally bring in what was produced during Google SoC 2005:

Add functions to rename objects and to move a subdisk from one drive
to another.

Obtained from:  Chris Jones <chris.jones@ualberta.ca>
Sponsored by:   Google Summer of Code 2005
MFC in:         1 week

18 years agoRemove references to iwicontrol.
damien [Sat, 19 Nov 2005 17:26:54 +0000 (17:26 +0000)]
Remove references to iwicontrol.
Firmware is now loaded by the driver itself.

Remove references to wicontrol.
wicontrol should not be used with iwi.

18 years agoRemove 'ipprintfs' which were protected under DIAGNOSTIC. It doesn't
andre [Sat, 19 Nov 2005 17:04:52 +0000 (17:04 +0000)]
Remove 'ipprintfs' which were protected under DIAGNOSTIC.  It doesn't
have any know to enable it from userland and could only be enabled by
either setting it to 1 at compile time or through the kernel debugger.

In the future it may be brought back as KTR tracing points.

Discussed with: rwatson
Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoLoad firmware images directly from the filesystem (looks into /etc/firmware
damien [Sat, 19 Nov 2005 16:54:55 +0000 (16:54 +0000)]
Load firmware images directly from the filesystem (looks into /etc/firmware
directory by default) without requiring the user to load them by hand using
e.g iwicontrol.  Get rid of the old ioctl crud.
Updated iwi-firmware port coming soon.

Obtained from: OpenBSD

18 years agoProperly parse the nowin95 mount option.
rodrigc [Sat, 19 Nov 2005 16:38:39 +0000 (16:38 +0000)]
Properly parse the nowin95 mount option.

Tested by: Rainer Hurling <rhurlin at gwdg dot de>

18 years agoMinor tweaks.
damien [Sat, 19 Nov 2005 15:08:05 +0000 (15:08 +0000)]
Minor tweaks.

18 years agoMove MAX_IPOPTLEN and struct ipoption back into ip_var.h as
andre [Sat, 19 Nov 2005 14:01:32 +0000 (14:01 +0000)]
Move MAX_IPOPTLEN and struct ipoption back into ip_var.h as
userland programs depend on it.

Pointed out by: le
Sponsored by: TCP/IP Optimization Fundraise 2005

18 years ago- Move the documentation for the ENABLE_WPA_SUPPLICANT_EAPOL knob to into
jkoshy [Sat, 19 Nov 2005 12:21:11 +0000 (12:21 +0000)]
- Move the documentation for the ENABLE_WPA_SUPPLICANT_EAPOL knob to into
  the list for 'world' builds.
- Increase the width of a bullet list.
- Use .Ss to name sub-sections of this file.

18 years agoDo not explicitly state how many bytes an argument list can be in the
simon [Sat, 19 Nov 2005 11:30:55 +0000 (11:30 +0000)]
Do not explicitly state how many bytes an argument list can be in the
description of E2BIG, since it's now larger on some platforms.

MFC after: 3 days

18 years agoRevert last revision by phk@, it's redundant since bsd.incs.mk
ru [Sat, 19 Nov 2005 07:04:17 +0000 (07:04 +0000)]
Revert last revision by phk@, it's redundant since bsd.incs.mk
already handles this, FWIW.

18 years agoAdd the NO_INCS knob to bsd.prog.mk and bsd.lib.mk to not include
ru [Sat, 19 Nov 2005 06:45:44 +0000 (06:45 +0000)]
Add the NO_INCS knob to bsd.prog.mk and bsd.lib.mk to not include
bsd.incs.mk, and use it when installing 32-bit compat libraries
on amd64.  This causes it to *not* overwrite native headers with
i386 versions, which was the case with <fenv.h> and <vgl.h>.

PR: amd64/83806
Prodded by: bde
MFC after: 1 week

18 years agoo Include <sys/time.h>
marcel [Sat, 19 Nov 2005 04:47:06 +0000 (04:47 +0000)]
o  Include <sys/time.h>
o  Make this ILP32/LP64 clean: cast pointers to long
o  Code conditional upon DEBUG must also be conditional
   upon _LIBC_R_

18 years agoo Include <string.h>
marcel [Sat, 19 Nov 2005 04:45:15 +0000 (04:45 +0000)]
o  Include <string.h>
o  Make this ILP32/LP64 clean: cast pointers to long.

18 years agoFix typo: s/_LIBC_R/_LIBC_R_/
marcel [Sat, 19 Nov 2005 04:43:29 +0000 (04:43 +0000)]
Fix typo: s/_LIBC_R/_LIBC_R_/

18 years agoMoved all the optimizations for |x| <= 9pi/2 from
bde [Sat, 19 Nov 2005 02:38:27 +0000 (02:38 +0000)]
Moved all the optimizations for |x| <= 9pi/2 from
__ieee754_rem_pio2f() to its 3 callers and manually inline them.

On Athlons, with favourable compiler flags and optimizations and
favourable pipeline conditions, this gives a speedup of 30-40 cycles
for cosf(), sinf() and tanf() on the range pi/4 < |x| <= 9pi/4, so
thes functions are now signifcantly faster than the hardware trig
functions in many cases.  E.g., in a benchmark with uniformly distributed
x in [-2pi, 2pi], A64 hardware fcos took 72-129 cycles and cosf() took
37-55 cycles.  Out-of-order execution is needed to get both of these
times.  The optimizations in this commit apparently work more by
removing 1 serialization point than by reducing latency.

18 years agoAdd "shortnames" and "longnames" mount options which are
rodrigc [Fri, 18 Nov 2005 22:34:31 +0000 (22:34 +0000)]
Add "shortnames" and "longnames" mount options which are
synonyms for "shortname" and "longname" mount options.  The old
(before nmount()) mount_msdosfs program accepted "shortnames" and "longnames",
but the kernel nmount() checked for "shortname" and "longname".
So, make the kernel accept "shortnames", "longnames", "shortname", "longname"
for forwards and backwarsd compatibility.

Discovered by: Rainer Hurling <rhurlin at gwdg dot de>

18 years agoural now supports automatic rate adaptation in BSS mode.
damien [Fri, 18 Nov 2005 21:46:28 +0000 (21:46 +0000)]
ural now supports automatic rate adaptation in BSS mode.

18 years agoSecond part of the AMRR commit.
damien [Fri, 18 Nov 2005 21:37:02 +0000 (21:37 +0000)]
Second part of the AMRR commit.
Enable automatic rate adaptation in BSS operating mode.
Works great here.  Will need a lot of testing though.

18 years agoConsolidate all IP Options handling functions into ip_options.[ch] and
andre [Fri, 18 Nov 2005 20:12:40 +0000 (20:12 +0000)]
Consolidate all IP Options handling functions into ip_options.[ch] and
include ip_options.h into all files making use of IP Options functions.

From ip_input.c rev 1.306:
  ip_dooptions(struct mbuf *m, int pass)
  save_rte(m, option, dst)
  ip_srcroute(m0)
  ip_stripoptions(m, mopt)

From ip_output.c rev 1.249:
  ip_insertoptions(m, opt, phlen)
  ip_optcopy(ip, jp)
  ip_pcbopts(struct inpcb *inp, int optname, struct mbuf *m)

No functional changes in this commit.

Discussed with: rwatson
Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoAdd sanity checking for QUEUE(3) lists under INVARIANTS. Races may lead
emaste [Fri, 18 Nov 2005 19:41:55 +0000 (19:41 +0000)]
Add sanity checking for QUEUE(3) lists under INVARIANTS.  Races may lead
to list corruption, which can be difficult to unravel in a post-mortem
analysis.  These checks verify that prev and next pointers are consistent
when inserting or removing elements, thus catching any corruption earlier.

Also use TRASHIT to break LIST and SLIST link pointers on element removal,
from mlaier via -hackers.

Reviewed by: mlaier
Approved by: rwatson (mentor)

18 years agoUnifdef for FreeBSD.
ru [Fri, 18 Nov 2005 19:38:45 +0000 (19:38 +0000)]
Unifdef for FreeBSD.

18 years ago- Always print the trap number so that we have something to start with for
jhb [Fri, 18 Nov 2005 19:26:46 +0000 (19:26 +0000)]
- Always print the trap number so that we have something to start with for
  mystery traps.  If we don't have a message for a given trap, just use
  UNKNOWN for the message.
- Add trap messages for T_XMMFLT and T_RESERVED.

MFC after: 1 week

18 years agoDocument CLOCK_UPTIME which returns the current uptime in SI seconds.
andre [Fri, 18 Nov 2005 17:13:22 +0000 (17:13 +0000)]
Document CLOCK_UPTIME which returns the current uptime in SI seconds.
At the moment it is just an alias for CLOCK_MONOTONIC which reports
the same number.

Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoRemove references to MEXT_ADD_REF, MEXT_REM_REF and MEXT_IS_REF
andre [Fri, 18 Nov 2005 17:04:49 +0000 (17:04 +0000)]
Remove references to MEXT_ADD_REF, MEXT_REM_REF and MEXT_IS_REF
which were removed with rev. 1.179 of mbuf.h.

Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoAdd CLOCK_UPTIME to clock_gettime(2) reporting the current
andre [Fri, 18 Nov 2005 16:51:13 +0000 (16:51 +0000)]
Add CLOCK_UPTIME to clock_gettime(2) reporting the current
uptime measured in SI seconds.

Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoAdd support for a new/unreleased Pentium-M.
ps [Fri, 18 Nov 2005 16:47:24 +0000 (16:47 +0000)]
Add support for a new/unreleased Pentium-M.

Reviewed by: jkoshy

18 years agoPurge layer specific mbuf flags on layer crossings to avoid confusing
andre [Fri, 18 Nov 2005 16:23:26 +0000 (16:23 +0000)]
Purge layer specific mbuf flags on layer crossings to avoid confusing
upper or lower layers.

Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoRework icmp_error() to deal with truncated IP packets from
andre [Fri, 18 Nov 2005 14:48:42 +0000 (14:48 +0000)]
Rework icmp_error() to deal with truncated IP packets from
ip_forward() when doing extended quoting in error messages.

Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoIn ip_forward() copy as much into the temporary error mbuf as we
andre [Fri, 18 Nov 2005 14:44:48 +0000 (14:44 +0000)]
In ip_forward() copy as much into the temporary error mbuf as we
have free space in it.  Allocate correct mbuf from the beginning.
This allows icmp_error() to quote the entire TCP header in error
messages.

Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoAdd KASSERTs to M_ALIGN() and MH_ALIGN() to prevent usage on wrong
andre [Fri, 18 Nov 2005 14:40:43 +0000 (14:40 +0000)]
Add KASSERTs to M_ALIGN() and MH_ALIGN() to prevent usage on wrong
mbuf types.

Sponsored by: TCP/IP Optimization Fundraise 2005

18 years agoFix markup, grammar and spelling.
ru [Fri, 18 Nov 2005 14:21:28 +0000 (14:21 +0000)]
Fix markup, grammar and spelling.