]> CyberLeo.Net >> Repos - FreeBSD/stable/8.git/log
FreeBSD/stable/8.git
13 years agoMFC r213306:
yongari [Fri, 8 Oct 2010 18:19:05 +0000 (18:19 +0000)]
MFC r213306:
  Rename rl_setmulti() to rl_rxfilter() as rl_rxfilter() will handle
  IFF_ALLMULTI/IFF_PROMISC as well as multicast filter configuration.
  Rewrite RX filter logic to reduce number of register accesses and
  make it handle promiscuous/allmulti toggling without controller
  reinitialization.

  Previously rl(4) counted on controller reinitialization to reprogram
  promiscuous configuration but r211767 resulted in avoiding
  controller reinitialization whenever promiscuous mode is toggled.
  To address this, keep track of driver's view of interface state and
  handle IFF_ALLMULTI/IFF_PROMISC changes without reinitializing
  controller. This should fix a regression introduced in r211267.

  While I'm here remove unnecessary variable reassignment in ioctl
  handler.

  PR: kern/151079

git-svn-id: svn://svn.freebsd.org/base/stable/8@213590 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212926:
mdf [Fri, 8 Oct 2010 18:06:15 +0000 (18:06 +0000)]
MFC r212926:

Use destroy_dev_sched(9) instead of destroy_dev(9) in passcleanup() as
it is indirectly a d_close method.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213588 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213013:
emaste [Fri, 8 Oct 2010 14:59:14 +0000 (14:59 +0000)]
MFC r213013:

  Move test for zero bufp or size before rseq and wseq calculation.  This
  avoids spinning in an infinite loop for some (possibly corrupt?) core
  files at work.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213577 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212570:
emaste [Fri, 8 Oct 2010 14:56:39 +0000 (14:56 +0000)]
MFC r212570:

  Allow a kernel config to specify a set but empty value via
  'makeoptions OPTION=' for consistency with the make commandline.

  Previously 'makeoptions WERROR=' would result in a syntax error; now
  it produces the same effect as 'makeoptions WERROR'.  Both forms now
  result in 'WERROR=' in the generated Makefile.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213576 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213322: sysctls in kern_shutdown: add twin tunables
avg [Fri, 8 Oct 2010 08:13:22 +0000 (08:13 +0000)]
MFC r213322: sysctls in kern_shutdown: add twin tunables

git-svn-id: svn://svn.freebsd.org/base/stable/8@213560 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213305: there must be only one SYSINIT with
avg [Fri, 8 Oct 2010 08:01:36 +0000 (08:01 +0000)]
MFC r213305: there must be only one SYSINIT with
SI_SUB_RUN_SCHEDULER+SI_ORDER_ANY order

git-svn-id: svn://svn.freebsd.org/base/stable/8@213558 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213304: debug.kdb.stop_cpus sysctl: hint that this is also a
avg [Fri, 8 Oct 2010 07:57:19 +0000 (07:57 +0000)]
MFC r213304: debug.kdb.stop_cpus sysctl: hint that this is also a
tunable

git-svn-id: svn://svn.freebsd.org/base/stable/8@213556 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213303: kmem_size* sysctls: hint that these are also tunables
avg [Fri, 8 Oct 2010 07:52:00 +0000 (07:52 +0000)]
MFC r213303: kmem_size* sysctls: hint that these are also tunables

git-svn-id: svn://svn.freebsd.org/base/stable/8@213554 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212994: kdb_backtrace: use stack_print_ddb instead of stack_print
avg [Fri, 8 Oct 2010 07:49:05 +0000 (07:49 +0000)]
MFC r212994: kdb_backtrace: use stack_print_ddb instead of stack_print

git-svn-id: svn://svn.freebsd.org/base/stable/8@213553 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212964: kdb_backtrace: stack(9)-based code to print backtrace
avg [Fri, 8 Oct 2010 07:38:44 +0000 (07:38 +0000)]
MFC r212964: kdb_backtrace: stack(9)-based code to print backtrace
without any backend

git-svn-id: svn://svn.freebsd.org/base/stable/8@213552 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212781: zfs arc_reclaim_needed: remove redundant checks for
avg [Fri, 8 Oct 2010 07:36:30 +0000 (07:36 +0000)]
MFC r212781: zfs arc_reclaim_needed: remove redundant checks for
arc_c_max and arc_c_max

git-svn-id: svn://svn.freebsd.org/base/stable/8@213551 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212783: zfs arc_reclaim_needed: fix typo in mismerge in r212780
avg [Fri, 8 Oct 2010 07:34:32 +0000 (07:34 +0000)]
MFC r212783: zfs arc_reclaim_needed: fix typo in mismerge in r212780

git-svn-id: svn://svn.freebsd.org/base/stable/8@213550 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212780: zfs arc_reclaim_needed: more reasonable threshold for
avg [Fri, 8 Oct 2010 07:33:22 +0000 (07:33 +0000)]
MFC r212780: zfs arc_reclaim_needed: more reasonable threshold for
available pages

git-svn-id: svn://svn.freebsd.org/base/stable/8@213549 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212657: zfs vn_has_cached_data: take into account v_object->cache != NULL
avg [Fri, 8 Oct 2010 07:31:32 +0000 (07:31 +0000)]
MFC r212657: zfs vn_has_cached_data: take into account v_object->cache != NULL

git-svn-id: svn://svn.freebsd.org/base/stable/8@213548 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212951: zfs_map_page/zfs_unmap_page: do not use sched_pin() and
avg [Fri, 8 Oct 2010 07:29:26 +0000 (07:29 +0000)]
MFC r212951: zfs_map_page/zfs_unmap_page: do not use sched_pin() and
SFB_CPUPRIVATE

git-svn-id: svn://svn.freebsd.org/base/stable/8@213547 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212950: zfs_vnops: use zfs_map_page/zfs_unmap_page helper functions
avg [Fri, 8 Oct 2010 07:26:56 +0000 (07:26 +0000)]
MFC r212950: zfs_vnops: use zfs_map_page/zfs_unmap_page helper functions
in another place

git-svn-id: svn://svn.freebsd.org/base/stable/8@213546 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213258:
davidxu [Thu, 7 Oct 2010 12:20:50 +0000 (12:20 +0000)]
MFC r213258:
- kern_sched_rr_get_interval should return interval for thread 1 in
    target process.
- eliminate a goto.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213511 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211059:
delphij [Thu, 7 Oct 2010 00:36:58 +0000 (00:36 +0000)]
MFC r211059:

Address an edge condition that we found at work, where the carp(4)
interface goes to issue LINK_UP, then LINK_DOWN, then LINK_UP at
cold boot.  This behavior is not observed when carp(4) interface
is created slightly later, when the underlying interface is fully
up.

Before this change what happen at boot is roughly:

 - ifconfig creates em0 interface;
 - ifconfig clones a carp device using em0;
   (em0's link state is DOWN at this point)
 - carp state: INIT -> BACKUP [*]
 - carp state: BACKUP -> MASTER
 - [Some negotiate between em0 and switch]
 - em0 kicks up link state change event
   (em0's link state is now up DOWN at this point)
 - do_link_state_change() -> carp_carpdev_state()
 - carp state: MASTER -> INIT (via carp_set_state(sc, INIT)) [+]
 - carp state: INIT -> BACKUP
 - carp state: BACKUP -> MASTER

At the [*] stage, em0 did not received any broadcast message from other
node, and assume our node is the master, thus carp(4) sets the link
state to "UP" after becoming a master.  At [+], the master status
is forcely set to "INIT", then an election is casted, after which our
node would actually become a master.

We believe that at the [*] stage, the master status should remain as
"INIT" since the underlying parent interface's link state is not up.

Obtained from:  iXsystems, Inc.
Reported by:    jpaetzel

git-svn-id: svn://svn.freebsd.org/base/stable/8@213505 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213044:
delphij [Thu, 7 Oct 2010 00:29:07 +0000 (00:29 +0000)]
MFC r213044:

In the past gunzip(1) write()'s after each inflate return.  This is
not optimal from a performance standpoint since the write buffer is
not necessarily be filled up when the inflate rountine reached the
end of input buffer and it's not the end of file.

This problem gets uncovered by trying to pipe gunzip -c output to
a GEOM device directly, which enforces the writes be multiple of
sector size.

Sponsored by: iXsystems, Inc.
Reported by:  jpaetzel

git-svn-id: svn://svn.freebsd.org/base/stable/8@213503 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212998:
kib [Wed, 6 Oct 2010 10:00:37 +0000 (10:00 +0000)]
MFC r212998:
For sparc64 relocations that directly put bits of the symbol value into
the location, apply elf_relocaddr to the symbol value to have right
values for the symbols from dpcpu segment.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213478 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r203958: %U was macroized in mdoc(7), escape.
ru [Wed, 6 Oct 2010 08:05:53 +0000 (08:05 +0000)]
MFC r203958: %U was macroized in mdoc(7), escape.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213473 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r202454,202457,202458,202586,207842,207844,208099:
delphij [Wed, 6 Oct 2010 00:13:55 +0000 (00:13 +0000)]
MFC r202454,202457,202458,202586,207842,207844,208099:

Expose stripesize and stripeoffset via kernel sysctl as well as userland
library and the geom(8) utility.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213467 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r213105, r213147
marius [Mon, 4 Oct 2010 20:13:19 +0000 (20:13 +0000)]
MFC: r213105, r213147

Improve r56796; the reply handler actually may remove the request from
the chain in which case it shouldn't be removed twice.
Reported by: Staale Kristoffersen

git-svn-id: svn://svn.freebsd.org/base/stable/8@213421 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r213102
marius [Mon, 4 Oct 2010 20:02:48 +0000 (20:02 +0000)]
MFC: r213102

Remove the duplicate logging of failed read requests, whose error message
also was inappropriate as it triggered for every EACCESS and ENOTFOUND, not
just the case the -n option is intended to deal with and thus really spammed
us with ~20 messages in the default configuration when booting a diskless
FreeBSD client, introduced with r207608 (commited to stable/8 in 213038)
again.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213419 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r213099
marius [Mon, 4 Oct 2010 19:59:08 +0000 (19:59 +0000)]
MFC: r213099

Make WARNS=6 clean.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213417 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: 213075
marius [Mon, 4 Oct 2010 19:51:15 +0000 (19:51 +0000)]
MFC: 213075

Try to adhere to style.Makefile(5).

git-svn-id: svn://svn.freebsd.org/base/stable/8@213415 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r213053
marius [Mon, 4 Oct 2010 19:39:51 +0000 (19:39 +0000)]
MFC: r213053

Remove an explicit assignment of the CFLAGS variable intended for
debugging purposes only.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213413 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213325:
bz [Mon, 4 Oct 2010 07:00:47 +0000 (07:00 +0000)]
MFC r213325:

  Proper bracketing.

  Submitted by: SunMinghao (sunminghao hotmail.com)
PR: kern/151100

git-svn-id: svn://svn.freebsd.org/base/stable/8@213400 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoRevision 209601 should have merged this part of r203711 to make fmt(1)
delphij [Mon, 4 Oct 2010 06:49:12 +0000 (06:49 +0000)]
Revision 209601 should have merged this part of r203711 to make fmt(1)
build unconditional.

PR: misc/151180

git-svn-id: svn://svn.freebsd.org/base/stable/8@213399 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r201053: sh: Various warning fixes (from WARNS=6 NO_WERROR=1):
jilles [Sun, 3 Oct 2010 21:56:20 +0000 (21:56 +0000)]
MFC r201053: sh: Various warning fixes (from WARNS=6 NO_WERROR=1):
- const
- initializations to silence -Wuninitialized (it was safe anyway)
- remove nested extern declarations
- rename "index" locals to "idx"

git-svn-id: svn://svn.freebsd.org/base/stable/8@213390 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212506:
kib [Sun, 3 Oct 2010 08:57:02 +0000 (08:57 +0000)]
MFC r212506:
Do not fork nfsiod directly from the vop methods.
Schedule the task that performs fork to be executed in
the taskqueue context.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213380 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213174:
ae [Sat, 2 Oct 2010 22:21:01 +0000 (22:21 +0000)]
MFC r213174:
  Some schemes can allocate memory for internal purposes but when
  GEOM does withering this memory doesn't freed. Add G_PART_DESTROY
  call to g_part_wither. Also add missed g_free() call to G_PART_READ
  method for MBR and PC98 schemes.

  Submitted by: jh (previous version)
  Reviewed by: pjd

Approved by: kib (mentor)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213376 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212706 (by pjd):
ae [Sat, 2 Oct 2010 22:18:36 +0000 (22:18 +0000)]
MFC r212706 (by pjd):
  Change message when setting or unsetting attribute to be less confusing.
  Before:

   ada0 has <attrib> set

  After:

   <attrib> set on ada0

Approved by: kib (mentor)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213375 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212703 (by pjd):
ae [Sat, 2 Oct 2010 22:15:57 +0000 (22:15 +0000)]
MFC r212703 (by pjd):
  Make the message that informs about bootcode being written to disk less
  confusing.

  Note there is still no information about 'partcode' being written to disk
  (gpart bootcode -p <partcode> <disk>).

  Maybe in the future all the messages printed by gpart(8) on success could
  be hidden under -v?

  PR: bin/150239
  Reported by: Roddi <roddi@me.com>
  Submitted by: arundel

Approved by: kib (mentor)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213374 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212609 (by pjd):
ae [Sat, 2 Oct 2010 22:14:01 +0000 (22:14 +0000)]
MFC r212609 (by pjd):
  Simplify the code a bit.

Approved by: kib (mentor)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213373 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r209536 (by rpaulo):
ae [Sat, 2 Oct 2010 22:12:04 +0000 (22:12 +0000)]
MFC r209536 (by rpaulo):
  Add NTFS partition type to GEOM_MBR.

Approved by: kib (mentor)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213371 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r203261 (by marcel):
ae [Sat, 2 Oct 2010 22:08:17 +0000 (22:08 +0000)]
MFC r203261 (by marcel):
  Export the UUID of the partition in the XML. The partition UUID is used
  by EFI's device path to identify a partition. In order for FreeBSD to
  add EFI boot options, proper device paths need to be constructed.

Approved by: kib (mentor)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213370 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r202977 (by trasz):
ae [Sat, 2 Oct 2010 22:06:07 +0000 (22:06 +0000)]
MFC r202977 (by trasz):
  Remove unneeded variables.

Approved by: kib (mentor)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213369 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r200967: sh: Add some __dead2 to indicate functions that do not return.
jilles [Sat, 2 Oct 2010 20:55:11 +0000 (20:55 +0000)]
MFC r200967: sh: Add some __dead2 to indicate functions that do not return.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213367 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r200956: sh: Constify various strings.
jilles [Sat, 2 Oct 2010 20:39:45 +0000 (20:39 +0000)]
MFC r200956: sh: Constify various strings.

Most of this is adding const keywords, but setvar() in var.c had to be
changed somewhat more.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213366 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212824:
kib [Sat, 2 Oct 2010 17:41:47 +0000 (17:41 +0000)]
MFC r212824:
Adopt the deferring of object deallocation for the deleted map entries
on map unlock to the lock downgrade and later read unlock operation.

MFC r212868 (by alc) [1]:
Make refinements to r212824. Redo the implementation of
vm_map_unlock_and_wait().

Approved by: alc [1]

git-svn-id: svn://svn.freebsd.org/base/stable/8@213362 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r210782,210837: Update the "desiredvnodes" calculation.
avg [Sat, 2 Oct 2010 08:11:38 +0000 (08:11 +0000)]
MFC r210782,210837: Update the "desiredvnodes" calculation.

On behalf of: alc

git-svn-id: svn://svn.freebsd.org/base/stable/8@213353 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoCreate the var/run/wpa_supplicant directory where the wpa_supplicant
bschmidt [Fri, 1 Oct 2010 17:20:13 +0000 (17:20 +0000)]
Create the var/run/wpa_supplicant directory where the wpa_supplicant
RC script wants to save a pidfile for each interface.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213330 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC of 213312, tzdata2010m
edwin [Thu, 30 Sep 2010 22:03:43 +0000 (22:03 +0000)]
MFC of 213312, tzdata2010m

- Fix historical data for Hongkong
- Fix location description for Antarctica/Vostok

git-svn-id: svn://svn.freebsd.org/base/stable/8@213315 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r213005:
dougb [Thu, 30 Sep 2010 21:54:25 +0000 (21:54 +0000)]
MFC r213005:

Remove confusing-though-technically-correct --disable-ipv6
from CONFIGARGS.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213309 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212732:
mav [Thu, 30 Sep 2010 04:23:03 +0000 (04:23 +0000)]
MFC r212732:
Fix panic, when due to some kind of congestion on FIS-based switching
port multiplier some command triggers false positive timeout, but then
completes normally.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213293 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212165:
nwhitehorn [Thu, 30 Sep 2010 04:06:16 +0000 (04:06 +0000)]
MFC r212165:

In the case of non-sequential mappings, ofw_mapmem() could ask Open
Firmware to map a memory region with negative length, causing crashes
and Undefined Behavior. Add the appropriate check to make the behavior
defined.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213292 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212359:
nwhitehorn [Thu, 30 Sep 2010 04:03:14 +0000 (04:03 +0000)]
MFC r212359:

Fix a problem where device detection would work unreliably on Serverworks
K2 SATA controllers. The chip's status register must be read first, and
as a long, for other registers to be correctly updated after a command, and
this includes the command sequence in device detection as well as the
previously handled case after interrupts. While here, clean up some
previous hacks related to this controller.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213291 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC Revision: 213042
emax [Wed, 29 Sep 2010 18:41:47 +0000 (18:41 +0000)]
MFC Revision: 213042

Add the following Linux BlueZ compatibility macros: htobs(), htobl(),
btohs() and btohl()

PR: kern/136386
Submitted by: Monty Hall < kungfu_disciple at sbcglobal dot net >

git-svn-id: svn://svn.freebsd.org/base/stable/8@213276 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r209168:
jh [Wed, 29 Sep 2010 14:36:25 +0000 (14:36 +0000)]
MFC r209168:

Update vfs_busy(9) and vfs_unbusy(9) manual pages to better match the
current behaviour of the functions.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213273 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212980 & r213160(man4/axe.4 only)
sanpei [Wed, 29 Sep 2010 12:53:02 +0000 (12:53 +0000)]
MFC r212980 & r213160(man4/axe.4 only)

Add Planex UE-200TX-G2 to list of supported devices.
Add new device ids.
 Buffalo (Melco Inc.) LUA3-U2-AGT
 Logitec LAN-GTJ/U2A

git-svn-id: svn://svn.freebsd.org/base/stable/8@213269 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212993: acpi_attach: do not explicitly install default handlers for
avg [Wed, 29 Sep 2010 09:20:18 +0000 (09:20 +0000)]
MFC r212993: acpi_attach: do not explicitly install default handlers for
default address spaces

git-svn-id: svn://svn.freebsd.org/base/stable/8@213264 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212655: zfs mappedread, update_pages: use int for offset and length
avg [Wed, 29 Sep 2010 09:18:34 +0000 (09:18 +0000)]
MFC r212655: zfs mappedread, update_pages: use int for offset and length
within a page

git-svn-id: svn://svn.freebsd.org/base/stable/8@213263 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212654: zfs mappedread: use uiomove_fromphys where possible
avg [Wed, 29 Sep 2010 09:16:45 +0000 (09:16 +0000)]
MFC r212654: zfs mappedread: use uiomove_fromphys where possible

git-svn-id: svn://svn.freebsd.org/base/stable/8@213262 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212652: zfs: catch up with vm_page_sleep_if_busy changes
avg [Wed, 29 Sep 2010 09:15:02 +0000 (09:15 +0000)]
MFC r212652: zfs: catch up with vm_page_sleep_if_busy changes

git-svn-id: svn://svn.freebsd.org/base/stable/8@213261 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212650: tmpfs, zfs + sendfile: mark page bits as valid after
avg [Wed, 29 Sep 2010 09:11:34 +0000 (09:11 +0000)]
MFC r212650: tmpfs, zfs + sendfile: mark page bits as valid after
populating it with data

git-svn-id: svn://svn.freebsd.org/base/stable/8@213260 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212932,212949: tools/umastat: fix build on amd64 and more
avg [Tue, 28 Sep 2010 05:53:35 +0000 (05:53 +0000)]
MFC r212932,212949: tools/umastat: fix build on amd64 and more

PR: misc/146119

git-svn-id: svn://svn.freebsd.org/base/stable/8@213242 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211913:
yongari [Mon, 27 Sep 2010 17:54:04 +0000 (17:54 +0000)]
MFC r211913:
  Do not allocate multicast array memory in multicast filter
  configuration function. For failed memory allocations, em(4)/lem(4)
  called panic(9) which is not acceptable on production box.
  igb(4)/ixgb(4)/ix(4) allocated the required memory in stack which
  consumed 768 bytes of stack memory which looks too big.

  To address these issues, allocate multicast array memory in device
  attach time and make multicast configuration success under any
  conditions. This change also removes the excessive use of memory in
  stack.

  Reviewed by: jfv

git-svn-id: svn://svn.freebsd.org/base/stable/8@213218 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211909:
yongari [Mon, 27 Sep 2010 17:50:56 +0000 (17:50 +0000)]
MFC r211909:
  If em(4) failed to allocate RX buffers, do not call panic(9).
  Just showing some buffer allocation error is more appropriate
  action for drivers. This should fix occasional panic reported on
  em(4) when driver encountered resource shortage.

  Reviewed by: jfv

git-svn-id: svn://svn.freebsd.org/base/stable/8@213217 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211907:
yongari [Mon, 27 Sep 2010 17:49:05 +0000 (17:49 +0000)]
MFC r211907:
  Do not call voluntary panic(9) in case of if_alloc() failure.

  Reviewed by: jfv

git-svn-id: svn://svn.freebsd.org/base/stable/8@213216 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211906:
yongari [Mon, 27 Sep 2010 17:46:11 +0000 (17:46 +0000)]
MFC r211906:
  Make sure not to access unallocated stats memory.

  Reviewed by: jfv

git-svn-id: svn://svn.freebsd.org/base/stable/8@213214 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211400:
yongari [Mon, 27 Sep 2010 17:37:25 +0000 (17:37 +0000)]
MFC r211400:
  Remove unnecessary clean target in em(4), igb(4) and ixgbe(4).
  While here also remove man target in igb(4).

  Reviewed by: jfv

git-svn-id: svn://svn.freebsd.org/base/stable/8@213211 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212755:
yongari [Mon, 27 Sep 2010 17:10:22 +0000 (17:10 +0000)]
MFC r212755:
  Fix incorrect RX BD producer updates. The producer index was
  already updated after allocating mbuf so driver had to use the last
  index instead of using next producer index. This should fix driver
  hang which may happen under high network load.

  Reported by: Igor Sysoev <is <> rambler-co dot ru>, Vlad Galu <dudu <> dudu dot ro>
  Tested by: Igor Sysoev <is <> rambler-co dot ru>, Vlad Galu <dudu <> dudu dot ro>

git-svn-id: svn://svn.freebsd.org/base/stable/8@213208 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC 212902:
jhb [Mon, 27 Sep 2010 16:29:25 +0000 (16:29 +0000)]
MFC 212902:
Tweak the stats exported by the e1000 drivers:
- Add a single sysctl procedure to all three drivers to read an arbitrary
  register (the register is passed as arg2).  Use it to replace existing
  routines in igb(4) that used a separate routine for each register, and
  to add support for missing stats in em(4) and lem(4).
- Move the 'rx_overruns' and 'watchdog_timeouts' stats out of the MAC stats
  section as they are driver stats, not MAC counters.
- Simplify the code that creates per-queue stats in igb(4) to use a single
  loop and remove duplicated code.
- Properly read all 64 bits of the 'good octets received/transmitted' in
  em(4) and lem(4).
- Actually read the interrupt count registers in em(4), and drop the
  'host to card' sysctl stats from em(4) as they are not implemented in
  any of the hardware this driver supports.
- Restore several stats to em(4) that were lost in the earlier stats
  conversion including per-queue stats.
- Export several MAC stats in em(4) that were exported in igb(4) but not
  in em(4).
- Export stats in lem(4) using individual sysctls as in em(4) and igb(4).

git-svn-id: svn://svn.freebsd.org/base/stable/8@213205 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212544: bus_add_child: add specialized default implementation that
avg [Mon, 27 Sep 2010 06:02:12 +0000 (06:02 +0000)]
MFC r212544: bus_add_child: add specialized default implementation that
calls panic

git-svn-id: svn://svn.freebsd.org/base/stable/8@213195 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212821: kern.sched.topology_spec sysctl: use step of 1 for group
avg [Mon, 27 Sep 2010 05:46:20 +0000 (05:46 +0000)]
MFC r212821: kern.sched.topology_spec sysctl: use step of 1 for group
levels numeration

git-svn-id: svn://svn.freebsd.org/base/stable/8@213194 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r212834
rmacklem [Mon, 27 Sep 2010 02:57:44 +0000 (02:57 +0000)]
MFC: r212834
Fix nfsrv_freeallnfslocks() in the experimental NFSv4 server so that
it frees local locks correctly upon close. In order for
nfsrv_localunlock() to work correctly, the lock can no longer be in
the lockowner's stateid list. As such, nfsrv_freenfslock() has to
be called before nfsrv_localunlock(), to get rid of the lock structure
on the lockowner's stateid list. This only affected operation when
local locks (vfs.newnfs.enable_locallocks=1) are enabled, which is
not the default at this time.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213193 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r212833
rmacklem [Mon, 27 Sep 2010 02:44:30 +0000 (02:44 +0000)]
MFC: r212833
Fix the experimental NFSv4 server so that it performs local VOP_ADVLOCK()
unlock operations correctly. It was passing in F_SETLK instead of
F_UNLCK as the operation for the unlock case. This only affected
operation when local locking (vfs.newnfs.enable_locallocks=1) was enabled.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213192 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r212443
rmacklem [Mon, 27 Sep 2010 02:30:56 +0000 (02:30 +0000)]
MFC: r212443
This patch applies one of the two fixes suggested by
zack.kirsch at isilon.com for a race between nfsrv_freeopen()
and nfsrv_getlockfile() in the experimental NFS server that
he found during testing. Although nfsrv_freeopen() holds a
sleep lock on the lock file structure when called with
cansleep != 0, nfsrv_getlockfile() could still search the
list, once it acquired the NFSLOCKSTATE() mutex. I believe
that acquiring the mutex in nfsrv_freeopen() fixes the race.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213191 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r212439
rmacklem [Mon, 27 Sep 2010 02:09:25 +0000 (02:09 +0000)]
MFC: r212439
Fix the NFSVNO_CMPFH() macro in the experimental NFS server so
that it works correctly for ZFS file handles. It is possible to
have two ZFS file handles that differ only in the bytes in the
fid_reserved field of the generic "struct fid" and comparing the
bytes in fid_data didn't catch this case. This patch changes the
macro to compare all bytes of "struct fid".

git-svn-id: svn://svn.freebsd.org/base/stable/8@213190 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC: r212362
rmacklem [Mon, 27 Sep 2010 01:41:39 +0000 (01:41 +0000)]
MFC: r212362
Fix the experimental NFS client so that it doesn't panic when
NFSv2,3 byte range locking is attempted. A fix that allows the
nlm_advlock() to work with both clients is in progress, but
may take a while. As such, I am doing this commit so that
the kernel doesn't panic in the meantime.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213189 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211873:
jh [Sun, 26 Sep 2010 16:52:05 +0000 (16:52 +0000)]
MFC r211873:

Don't attempt to write label with GEOM_BSD based method if the class is
not available. This improves error reporting when bsdlabel(8) is unable
to open a device for writing. If GEOM_BSD was unavailable, only a rather
obscure error message "Class not found" was printed.

PR: bin/58390

git-svn-id: svn://svn.freebsd.org/base/stable/8@213186 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoRevert r213002.
rpaulo [Sun, 26 Sep 2010 12:52:23 +0000 (12:52 +0000)]
Revert r213002.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213184 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211393 (des):
delphij [Fri, 24 Sep 2010 23:47:42 +0000 (23:47 +0000)]
MFC r211393 (des):

In setusercontext(), do not apply user settings unless running as the
user in question (usually but not necessarily because we were called
with LOGIN_SETUSER).  This plugs a hole where users could raise their
resource limits and expand their CPU mask.

Approved by: des

git-svn-id: svn://svn.freebsd.org/base/stable/8@213144 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211768:
yongari [Fri, 24 Sep 2010 19:30:34 +0000 (19:30 +0000)]
MFC r211768:
  Remove unnecessary controller reinitialization.

  PR: kern/87506

git-svn-id: svn://svn.freebsd.org/base/stable/8@213132 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211767:
yongari [Fri, 24 Sep 2010 19:27:47 +0000 (19:27 +0000)]
MFC r211767:
  Remove unnecessary controller reinitialization.

  PR: kern/87506

git-svn-id: svn://svn.freebsd.org/base/stable/8@213130 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211766:
yongari [Fri, 24 Sep 2010 19:24:45 +0000 (19:24 +0000)]
MFC r211766:
  vr_init_locked() will stop and reset the controller. Remove
  unnecessary vr_stop()/vr_reset() calls.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213128 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211765:
yongari [Fri, 24 Sep 2010 19:19:53 +0000 (19:19 +0000)]
MFC r211765:
  Remove unnecessary controller reinitialization.
  CAM filter handling was rewritten long time ago so it should not
  require controller reinitialization.

  PR: kern/87506

git-svn-id: svn://svn.freebsd.org/base/stable/8@213126 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211764:
yongari [Fri, 24 Sep 2010 19:16:42 +0000 (19:16 +0000)]
MFC r211764:
  Add PNP id for Compex RL2000.
  I'm not sure whether adding this logical id is correct or not
  because Compex RL2000 is in the list of supported hardware list.
  I guess the Compex RL2000 could be PCI variant while the controller
  in question is ISA controller. It seems PNP compat id didn't match
  or it had multiple compat ids so isa_pnp_probe() seemed to return
  ENOENT.

  PR: kern/80853

git-svn-id: svn://svn.freebsd.org/base/stable/8@213124 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211721:
yongari [Fri, 24 Sep 2010 19:13:43 +0000 (19:13 +0000)]
MFC r211721:
  Fix a possible unaligned access to savebyte array.

  PR: kern/122195

git-svn-id: svn://svn.freebsd.org/base/stable/8@213122 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211717:
yongari [Fri, 24 Sep 2010 19:09:23 +0000 (19:09 +0000)]
MFC r211717:
  Implement basic WOL support. Note, not all xl(4) controllers
  support WOL. Some controllers require additional 3-wire auxiliary
  remote wakeup connector to draw power. More recent xl(4)
  controllers may not need the wakeup connector though.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213120 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211716:
yongari [Fri, 24 Sep 2010 19:04:17 +0000 (19:04 +0000)]
MFC r211716:
  Move xl_reset() to xl_init_locked(). This will make driver
  initialize controller from a known good state. Previously driver
  used to issue controller reset while TX/RX DMA are in progress.
  I guess resetting controller in active TX/RX DMA cycle is to ensure
  stopping I/Os in xl_shutdown(). I remember some buggy controllers
  didn't respond with stop command if controller is under high
  network load at the time of shutdown so resetting controller was
  the only safe way to stop the I/Os. However, from my experiments,
  controller always responded with stop command under high network
  load so I think it's okay to remove the xl_reset() in
  device_shutdown handler.
  Resetting controller also will clear configured RX filter which
  in turn will make WOL support hard because driver have to reprogram
  RX filter in WOL handler as well as setting station address.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213117 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211671:
yongari [Fri, 24 Sep 2010 18:58:04 +0000 (18:58 +0000)]
MFC r211671:
  Remove unnecessary controller reinitialization by checking
  IFF_DRV_RUNNING flag.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213115 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211670:
yongari [Fri, 24 Sep 2010 18:33:15 +0000 (18:33 +0000)]
MFC r211670:
  Clean up SIOCSIFCAP handler and allow RX checksum offloading could
  be controlled by user.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213113 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211597:
yongari [Fri, 24 Sep 2010 18:12:19 +0000 (18:12 +0000)]
MFC r211597:
  Document newly introduced tunable dev.bge.%d.forced_udpcsum.
  While I'm here also mention tunable dev.bge.%d.forced_collapse.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213111 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211596:
yongari [Fri, 24 Sep 2010 17:59:58 +0000 (17:59 +0000)]
MFC r211596:
  It seems all Broadcom controllers have a bug that can generate UDP
  datagrams with checksum value 0 when TX UDP checksum offloading is
  enabled.  Generating UDP checksum value 0 is RFC 768 violation.
  Even though the probability of generating such UDP datagrams is
  low, I don't want to see FreeBSD boxes to inject such datagrams
  into network so disable UDP checksum offloading by default.  Users
  still override this behavior by setting a sysctl variable or loader
  tunable, dev.bge.%d.forced_udpcsum.

  I have no idea why this issue was not reported so far given that
  bge(4) is one of the most commonly used controller on high-end
  server class systems. Thanks to andre@ who passed the PR to me.

  PR: kern/104826

git-svn-id: svn://svn.freebsd.org/base/stable/8@213109 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r211594:
yongari [Fri, 24 Sep 2010 17:53:32 +0000 (17:53 +0000)]
MFC r211594:
  Load tunable from loader.conf(5) instead of device.hints(5).

git-svn-id: svn://svn.freebsd.org/base/stable/8@213107 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r197850:
delphij [Fri, 24 Sep 2010 17:26:57 +0000 (17:26 +0000)]
MFC r197850:

Add a special workaround to handle UIO_NOCOPY case.  This fixes data
corruption observed when sendfile() is being used.

Requested by: avg
PR: kern/127213
Submitted by: gk

git-svn-id: svn://svn.freebsd.org/base/stable/8@213106 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212789: nextboot: warn about limitations of /boot/nextboot.conf on ZFS
avg [Fri, 24 Sep 2010 07:27:53 +0000 (07:27 +0000)]
MFC r212789: nextboot: warn about limitations of /boot/nextboot.conf on ZFS

git-svn-id: svn://svn.freebsd.org/base/stable/8@213094 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212782: zfs+sendfile: advance uio_offset upon reading as well
avg [Fri, 24 Sep 2010 07:23:48 +0000 (07:23 +0000)]
MFC r212782: zfs+sendfile: advance uio_offset upon reading as well

git-svn-id: svn://svn.freebsd.org/base/stable/8@213093 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212305 : Avoid "Entry can disappear before we lock fdvp" panic.
ivoras [Thu, 23 Sep 2010 23:05:31 +0000 (23:05 +0000)]
MFC r212305 : Avoid "Entry can disappear before we lock fdvp" panic.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213088 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212339: sh: Fix 'read' if all chars before the first IFS char are
jilles [Thu, 23 Sep 2010 21:36:10 +0000 (21:36 +0000)]
MFC r212339: sh: Fix 'read' if all chars before the first IFS char are
backslash-escaped.

Backslash-escaped characters did not set the flag for a non-IFS character.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213087 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212330: sh: Add simple tests for backslashes in the read builtin.
jilles [Thu, 23 Sep 2010 20:49:33 +0000 (20:49 +0000)]
MFC r212330: sh: Add simple tests for backslashes in the read builtin.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213086 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212187: sh: Add a test that 'read' leaves the file pointer at the
jilles [Thu, 23 Sep 2010 20:37:29 +0000 (20:37 +0000)]
MFC r212187: sh: Add a test that 'read' leaves the file pointer at the
correct place.

Naive buffering would break the common while read x... construct, which did
not appear to be tested yet.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213085 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r212390: expr(1): Add sh(1) versions of examples, remove an incorrect
jilles [Thu, 23 Sep 2010 17:37:57 +0000 (17:37 +0000)]
MFC r212390: expr(1): Add sh(1) versions of examples, remove an incorrect
example.

The three examples are better done using sh(1) itself these days.

The example
  expr -- "$a" : ".*"
is incorrect in the general case, as "$a" may be an operator.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213079 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMerge r211153 from head:
gavin [Thu, 23 Sep 2010 10:20:28 +0000 (10:20 +0000)]
Merge r211153 from head:

  Now that the uplcom(4) driver can autodetect the chipset type, sync
  the list of devices supported by uplcom(4) with the following sources:

  NetBSD  src/sys/dev/usb/uplcom.c 1.70
  OpenBSD src/sys/dev/usb/uplcom.c 1.52
  Linux   drivers/usb/serial/pl2303.h from kernel 2.6.35
  BeOS    usb_serial/driver.c 1.32

  Give several devices better descriptions, and rename
  PROLIFIC2 -> NETINDEX while here to match everybody else.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213054 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMerge r211111 from head:
gavin [Thu, 23 Sep 2010 09:56:02 +0000 (09:56 +0000)]
Merge r211111 from head:

  Attempt to autodetect the cype of chipset, rather than storing this
  within the device table.  This code uses the same algorithm as used in
  the  Linux, NetBSD and DragonflyBSD driver.

  While investigating this, it became apparent that the Linux driver
  always initialises the device, and not just in the PL2303HX case.
  Change uplcom(4) to do the same.

  This change allows us to synchronize our device ID list with Linux and
  NetBSD, without requiring knowledge of the chipset in use.

Merge r209967, 209968 from head (by takawata):

  One more Prolific serial device ID.

git-svn-id: svn://svn.freebsd.org/base/stable/8@213052 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMerge r211083 from head:
gavin [Thu, 23 Sep 2010 09:52:27 +0000 (09:52 +0000)]
Merge r211083 from head:

  The PL2302X can support any baud rate <= 6Mbps, allow any rate to be set.

PR: usb/128324
Submitted by: Mike Durian <durian shadetreesoftware.com> (original patch)

git-svn-id: svn://svn.freebsd.org/base/stable/8@213051 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r208028,r210628,r210909,r210912,r211397:
pjd [Thu, 23 Sep 2010 09:05:40 +0000 (09:05 +0000)]
MFC r208028,r210628,r210909,r210912,r211397:

r208028:

mdoc: move remaining sections into consistent order

This pertains mostly to FILES, HISTORY, EXIT STATUS and AUTHORS sections.

Found by: mdocml lint run
Reviewed by: ru

r210628:

Fix typo.

PR: docs/149033
Submitted by: Kolar <hsn@sendmail.cz>

r210909:

Update the arguments to yy_config_parse() to match r210883.

Choose the more conservative option ('yes' to exit on error) to match
the equivalent code in hastd.

r210912:

Force commit to remind me about MFCing r210909.

r211397:

Fix typos, spelling, formatting and mdoc mistakes found by Nobuyuki while
translating these manual pages.  Minor corrections by me.

Submitted by: Nobuyuki Koganemaru <n-kogane@syd.odn.ne.jp>

git-svn-id: svn://svn.freebsd.org/base/stable/8@213050 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f

13 years agoMFC r208028,r210368,r210702,r210869,r210870,r210872,r210873,r210875,r210876,
pjd [Thu, 23 Sep 2010 09:02:10 +0000 (09:02 +0000)]
MFC r208028,r210368,r210702,r210869,r210870,r210872,r210873,r210875,r210876,
  r210879,r210880,r210881,r210882,r210883,r210886,r210892,r211397,r211407,
  r211452,r211875,r211876,r211877,r211878,r211879,r211880,r211881,r211882,
  r211883,r211884,r211885,r211886,r211887,r211895,r211896,r211897,r211898,
  r211899,r211975,r211976,r211977,r211978,r211979,r211981,r211982,r211983,
  r211984,r212033,r212034,r212036,r212037,r212038,r212046,r212049,r212051,
  r212052,r212899,r213003,r213004,r213006,r213007,r213008,r213009:

r208028:

mdoc: move remaining sections into consistent order

This pertains mostly to FILES, HISTORY, EXIT STATUS and AUTHORS sections.

Found by: mdocml lint run
Reviewed by: ru

r210368:

Actually, only the fullsync mode is implemented, not memsync mode.
Correct manual page.

r210702:

Spelling fixes.

r210869:

Add an argument to the proto_register() function which allows protocol to
declare it is the default and be placed at the end of the queue so it is
checked last.

r210870:

Now that TCP will be checked last we don't need any knowledge about other
protocols.

r210872:

Mark two more places that we won't reach.

r210873:

Keep $FreeBSD$ in __FBSDID() only for C files.

r210875:

Problem with assertion is that it logs on stderr. Add two macros:
PJDLOG_ASSERT() and PJDLOG_VERIFY() that will check the given condition
and log the problem where appropriate. The difference between those
two is that PJDLOG_VERIFY() always work and PJDLOG_ASSERT() can be
turned off by defining NDEBUG.

r210876:

Assert that various buffers we are large enough.

r210879:

- Use pjdlog_exitx() to log errors and exit instead of errx().
- Use 'unable to' (instead of 'cannot') consistently.

r210880:

Reset signal handlers after fork().

r210881:

Allow to use 'none' keywork as remote address in case second cluster node
is not setup yet.

r210882:

Make control_set_role() more public. We will need it soon.

r210883:

Prepare configuration parsing code to be called multiple times:
- Don't exit on errors if not requested.
- Don't keep configuration in global variable, but allocate memory for
  configuration.
- Call yyrestart() before yyparse() so that on error in configuration file
  we will start from the begining next time and not from the place we left of.

r210886:

Implement configuration reload on SIGHUP. This includes:
- Load added resources.
- Stop and forget removed resources.
- Update modified resources in least intrusive way, ie. don't touch
  /dev/hast/<name> unless path to local component or provider name were
  modified.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r210892:

Document 'none' value for remote.

Reviewed by: dougb

r211397:

Fix typos, spelling, formatting and mdoc mistakes found by Nobuyuki while
translating these manual pages.  Minor corrections by me.

Submitted by: Nobuyuki Koganemaru <n-kogane@syd.odn.ne.jp>

r211407:

The 'size' variable is there to limit how many bytes we want to copy from
'addr'. It is very likely that size of 'addr' is larger than 'size', so checking
strlcpy() return value is bogus.

r211452:

For some setups sending data in 128kB chunks makes communication very slow. No
idea why. 32kB on the other hand seems to work properly everywhere.

Reported by: Thomas Steen Rasmussen <thomas@gibfest.dk>

r211875:

Make comment more readable.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211876:

Add mtx_owned() implementation.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211877:

Add QUEUE_INSERT() and QUEUE_TAKE() macros that simplify the code a bit.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211878:

We have sync_start() function to start synchronization, introduce sync_stop()
function to stop it.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211879:

Log that synchronization was interrupted in a proper place.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211880:

Don't increase number synchronized bytes in case of an error.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211881:

- Remove redundant and incorrect 'old' word from debug message.
- Log disconnects as warnings.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211882:

Implement keepalive mechanism inside HAST protocol so we can detect secondary
node failures quickly for HAST resources that are rarely modified.

Remove XXX from a comment now that the guard thread never sleeps infinitely.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211883:

Reduce indent where possible.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211884:

When logging to stdout/stderr don't close those descriptors after fork().

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211885:

- Run hooks in background - don't block waiting for them to finish.
- Keep all hooks we're running in a global list, so we can report when
  they finish and also report when they are running for too long.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211886:

Allow to execute specified program on various HAST events.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211887:

Document new 'exec' parameter.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211895:

Add hooks execution.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211896:

Check if no signals were delivered just before going to sleep.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211897:

Correct when we log interrupted synchronization.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211898:

When logging to stdout/stderr, flush after each log.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211899:

When SIGTERM or SIGINT is received, terminate worker processes.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211975:

Implement mtx_destroy() and rw_destroy().

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211976:

- Add hook_fini() which should be called after fork() from the main hastd
  process, once it start to use hooks.
- Add hook_check_one() in case the caller expects different child processes
  and once it can recognize it, it will pass pid and status to hook_check_one().

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211977:

Allow to run hooks from the main hastd process.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211978:

- Call hook on role change.
- Document new event.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211979:

Disconnect after logging errors.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211981:

- Move functionality responsible for checking one connection to separate
  function to make code more readable.
- Be sure not to reconnect too often in case of signal delivery, etc.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211982:

Use sigtimedwait(2) for signals handling in primary process.
This fixes various races and eliminates use of pthread* API in signal handler.

Pointed out by: kib
With help from: jilles
Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211983:

Execute hook when split-brain is detected.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r211984:

Execute hook when connection between the nodes is established or lost.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212033:

Constify arguments we can constify.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212034:

Use pjdlog_exit() before fork().

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212036:

When someone gives NULL as data, assume this is because he want to declare
connection side only.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212037:

We only want to know if descriptors are ready for reading.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212038:

Because it is very hard to make fork(2) from threaded process safe (we are
limited to async-signal safe functions in the child process), move all hooks
execution to the main (non-threaded) process.

Do it by maintaining connection (socketpair) between child and parent
and sending events from the child to parent, so it can execute the hook.

This is step in right direction for others reasons too. For example there is
one less problem to drop privs in worker processes.

Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212046:

Mask only those signals that we want to handle.

Suggested by: jilles
Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212049:

Forgot to add event.c and event.h in r212038.

Pointed out by: pluknet <pluknet@gmail.com>
Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com

r212051:

Correct error message.

Submitted by: Mikolaj Golub <to.my.trociny@gmail.com>

r212052:

Include process PID in log messages.

Submitted by: Mikolaj Golub <to.my.trociny@gmail.com>

r212899:

Add __dead2 to functions that we know they are going to exit.

r213003:

Sort includes.

r213004:

If we are unable to receive control message is most likely because the main
process died. Instead of entering infinite loop, terminate.

r213006:

Fix descriptor leaks: when child exits, we have to close control and event
socket pairs. We did that only in one case out of three.

r213007:

Fix possible deadlock where worker process sends an event to the main process
while the main process sends control message to the worker process, but worker
process hasn't started control thread yet, because it waits for reply from the
main process.

The fix is to start the control thread before sending any events.

Reported and fix suggested by: Mikolaj Golub <to.my.trociny@gmail.com>

r213008:

Assert that descriptor numbers are sane.

r213009:

Switch to sigprocmask(2) API also in the main process and secondary process.
This way the primary process inherits signal mask from the main process,
which fixes a race where signal is delivered to the primary process before
configuring signal mask.

Reported by: Mikolaj Golub <to.my.trociny@gmail.com>

git-svn-id: svn://svn.freebsd.org/base/stable/8@213049 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f