[dahdi-commits] sruffell: tag linux/2.6.0-rc1 r10313 - /linux/tags/2.6.0-rc1/

SVN commits to the DAHDI project dahdi-commits at lists.digium.com
Wed Nov 2 16:59:06 CDT 2011


Author: sruffell
Date: Wed Nov  2 16:59:02 2011
New Revision: 10313

URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=10313
Log:
Importing files for 2.6.0-rc1 release.

Added:
    linux/tags/2.6.0-rc1/.version   (with props)
    linux/tags/2.6.0-rc1/ChangeLog   (with props)

Added: linux/tags/2.6.0-rc1/.version
URL: http://svnview.digium.com/svn/dahdi/linux/tags/2.6.0-rc1/.version?view=auto&rev=10313
==============================================================================
--- linux/tags/2.6.0-rc1/.version (added)
+++ linux/tags/2.6.0-rc1/.version Wed Nov  2 16:59:02 2011
@@ -1,0 +1,1 @@
+2.6.0-rc1

Propchange: linux/tags/2.6.0-rc1/.version
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: linux/tags/2.6.0-rc1/.version
------------------------------------------------------------------------------
    svn:keywords = none

Propchange: linux/tags/2.6.0-rc1/.version
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Added: linux/tags/2.6.0-rc1/ChangeLog
URL: http://svnview.digium.com/svn/dahdi/linux/tags/2.6.0-rc1/ChangeLog?view=auto&rev=10313
==============================================================================
--- linux/tags/2.6.0-rc1/ChangeLog (added)
+++ linux/tags/2.6.0-rc1/ChangeLog Wed Nov  2 16:59:02 2011
@@ -1,0 +1,5794 @@
+2011-11-02 Shaun Ruffell <sruffell at digium.com>
+
+	* dahdi-linux 2.6.0-rc1 released.
+
+2011-11-02 21:46 +0000 [r10310]  Russ Meyerriecks <rmeyerreicks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: minor: Removed unnecessary
+	  instrumentation Removed a couple prints of instrumentation that
+	  was cluttering up the log output. Signed-off-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com> Acked-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+2011-11-02 19:46 +0000 [r10303-10304]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/dahdi-base.c: dahdi: First span registered becomes
+	  master by default. r10205 "dahdi: Check for master in
+	  DAHDI_STARTUP / resolves MeetMe regression." did not handle the
+	  case for the wcb4xxp driver since it would set DAHDI_FLAG_RUNNING
+	  as part of the probe. Therefore, the DAHDI_STARTUP ioctl was
+	  never processed for it, creating a situation where audio is
+	  missing on channels that are conferenced with channels on the BRI
+	  spans. Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+	* include/dahdi/kernel.h: dahdi: Define POLLRDHUP on kernels <
+	  2.6.17 Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+2011-11-02 17:05 +0000 [r10299-10302]  Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/xpp/xpp_dahdi.c, drivers/dahdi/xpp/card_pri.c,
+	  drivers/dahdi/xpp/card_bri.c, drivers/dahdi/xpp/xpp_dahdi.h: xpp:
+	  bugfix: clear NOTOPEN span alarm on assign The NOTOPEN span alarm
+	  flag is set at span unassignment time. * It needs to be cleared
+	  when the span is reassigned. * That is: only if the span is
+	  actually connected. Signed-off-by: Tzafrir Cohen
+	  <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/xpp/xpp_dahdi.c: xpp: bugfix -- manage xpd refcount
+	  for EC module Signed-off-by: Tzafrir Cohen
+	  <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/xpp/xpp_usb.c, drivers/dahdi/xpp/card_global.c,
+	  drivers/dahdi/xpp/xbus-core.h, drivers/dahdi/xpp/init_card_1_30:
+	  xpp: Adaptations for E-Main-3 * An xbus transport now have a
+	  "model_string" member * The xpp_usb driver fills this with
+	  "usb:<idVendor>/<idProduct>/<bcdDevice>" * It is passed via
+	  environment to the "init_card_<type>_<protocol>" scripts * The
+	  FXS script uses this to condition two registers according to the
+	  power supply model. Signed-off-by: Tzafrir Cohen
+	  <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/xpp/card_fxo.h, drivers/dahdi/xpp/card_fxs.h: xpp:
+	  remove leftovers of old XPD_STATE method Signed-off-by: Tzafrir
+	  Cohen <tzafrir.cohen at xorcom.com>
+
+2011-11-01 20:35 +0000 [r10290-10296]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/voicebus/GpakCust.c: wctdm24xxp, wcte12xp: Allow
+	  VPMADT032 commands more time to complete. Since "wctdm24xxp:
+	  Probe for and configure modules in parallel." the check for the
+	  VPMADT032 module was moved closer to after when the interface was
+	  initialized. The 200ms timeout did not provide enough time for
+	  the system to settle out after initial start. The result was that
+	  sometimes after a cold boot the driver would fail to detect any
+	  VPMADT032 modules. This fixes a race condition that is not in any
+	  released branches. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* drivers/dahdi/firmware/Makefile: wctdm24xxp, wcte12xp: Update
+	  VPMOCT032 firmware to 1.12.0. - Cleaned up the OCT6114 interface
+	  . - Relaxed the timeout waiting for OCT6114 bus cycle completion
+	  to 100 mS and added a 2 mS delay time from OCT6114 reset to
+	  initialization. This change only addresses issues that were
+	  created in the lab and not in the field. Signed-off-by: Doug
+	  Bailey <dbailey at digium.com> Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Expose serial number in
+	  dahdi_device and kernel log. This will allow the serial number to
+	  be exposed in sysfs and also allow span assignment rules to use
+	  the serial number. Signed-off-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com> Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* drivers/dahdi/firmware/Makefile, drivers/dahdi/wct4xxp/base.c:
+	  wct4xxp: Add field upgradable firmware support for TE820. This
+	  commit adds field upgradeable support for the TE820 firmware.
+	  Firmware can now be silently upgraded as part of updating drivers
+	  like most of the existing DAHDI firmware. Previous versions of
+	  dual and quad span cards did not support upgrading firmware in
+	  the field. Signed-off-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com> Fixed up some checkpatch issues:
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wct4xxp/wct4xxp.h, drivers/dahdi/firmware/Makefile,
+	  drivers/dahdi/wct4xxp/vpm450m.c, drivers/dahdi/wct4xxp/Kbuild,
+	  drivers/dahdi/wct4xxp/base.c,
+	  drivers/dahdi/oct612x/include/oct6100api/oct6100_defines.h,
+	  README: wct4xxp: Add support for TE820 and VPMOCT256. TE820 is an
+	  8-span PCI-express digital interface card. VPMOCT256 is a
+	  hardware echo canceler that is able to provide echo cancelation
+	  on all 8-spans. From: Matthew Fredrickson <creslin at digium.com>
+	  Signed-off-by: Russ Meyerriecks <rmeyerriecks at digium.com>
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+2011-10-27 19:59 +0000 [r10270-10289]  Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+	* README: README: Minor additions regarding pinned-spans
+	  Signed-off-by: Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+	* README: README: initial update for span assignments
+	  Signed-off-by: Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/xpp/xpp_dahdi.c, drivers/dahdi/xpp/xbus-core.c:
+	  xpp: cleanup some printk()'s * Also demote them to DBG()
+	  Signed-off-by: Oron Peled <oron.peled at xorcom.com>
+
+	* drivers/dahdi/dahdi-sysfs.c: added 'basechan' and 'channels'
+	  attributes to spans * So we can: - Generate 'pinned-spans.conf'
+	  from existing state - Run dahdi_cfg from udev (on specific span +
+	  its channels) Signed-off-by: Oron Peled <oron.peled at xorcom.com>
+
+	* drivers/dahdi/dahdi-base.c: dahdi: Give userspace a chance to
+	  respond to surprise removal. * We try very hard to help asterisk
+	  understand that we unassign spans. * Implement disable_span(): -
+	  Set span + channels to DAHDI_ALARM_NOTOPEN - qevent
+	  DAHDI_EVENT_REMOVED * Use disable_span(): - in
+	  dahdi_unassign_span() and dahdi_unregister_device() - with long
+	  msleep() so asterisk has a chance to get the message - Out of the
+	  registration_mutex so we actually context switch. * Also return
+	  more POLLERR variants (POLLRDHUP is not portable, should be
+	  tested). * Also improve printk(), fix rate_limit increment (was
+	  missing) Signed-off-by: Oron Peled <oron.peled at xorcom.com>
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/xpp/xpp_dahdi.c, drivers/dahdi/xpp/xpp_dahdi.h,
+	  drivers/dahdi/xpp/xbus-core.c: xpp: Remove dahdi_autoreg
+	  parameter: * With pinned-spans all spans are registered to dahdi
+	  with the device (and assigned later) * So this parameter cannot
+	  function anymore * Also remove the (now) empty xpd_post_init()
+	  function. Signed-off-by: Oron Peled <oron.peled at xorcom.com>
+
+	* drivers/dahdi/xpp/xpp_dahdi.c: xpp: more informative span
+	  description: * Contains the hardware_id and the local span number
+	  Signed-off-by: Oron Peled <oron.peled at xorcom.com>
+
+	* drivers/dahdi/xpp/xbus-core.c: xpp: make unregistration safer
+	  (idempotent) * Otherwise, a failed unit initialization (e.g: when
+	  init_card_?_?? fails) causes a panic Signed-off-by: Oron Peled
+	  <oron.peled at xorcom.com>
+
+	* drivers/dahdi/xpp/xbus-sysfs.c: xpp: adapt to 'location'
+	  attribute removal: * Reparent astribanks below their USB
+	  transport * This way their location can be derived from their
+	  hardware hierarchy. * The tradeoff is that once USB hardware is
+	  disconnected, there is no sysfs visibility of the astribank
+	  object even if it cannot be release yet due to open channels by
+	  asterisk * Thus, we'll need to migrate to "surprise removal" of
+	  dahdi devices... Signed-off-by: Oron Peled
+	  <oron.peled at xorcom.com>
+
+	* drivers/dahdi/xpp/xpp_dahdi.c, drivers/dahdi/xpp/card_pri.c,
+	  drivers/dahdi/xpp/xpp_dahdi.h: xpp: PRI: use DAHDI new
+	  set_spantype() method * Implement pri_set_spantype() method *
+	  Refactor code from PRI_card_dahdi_preregistration() into a new
+	  apply_pri_protocol(). - It is now called from both
+	  PRI_card_dahdi_preregistration() and set_pri_proto() - It now
+	  also sets span name + description * Remove old
+	  pri_protocol_store() method (pri_protocol is now RO) * Added
+	  pri_protocol_bystr() method (maybe promote it to DAHDI?)
+	  Signed-off-by: Oron Peled <oron.peled at xorcom.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Allow linemode (T1/E1/J1)
+	  to be changed via sysfs attribute. Allowing the linemode to be
+	  configured with sysfs before the spans are assigned opens the
+	  eventualy capability for line mode to be configured with the
+	  other physical layer settings per card. Currently linemode is set
+	  with either physical jumpers or with a module parameter to the
+	  wct4xxp driver that is global for all cards. Default behavior is
+	  not changed with this commit. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* drivers/dahdi/wcte12xp/base.c: wcte12xp: Allow linemode (T1/E1)
+	  to be changed via sysfs attribute. Allowing the linemode to be
+	  configured with sysfs before the spans are assigned opens the
+	  eventualy capability for line mode to be configured with the
+	  other physical layer settings per card. Currently linemode is set
+	  with either physical jumpers or with a module parameter to the
+	  wcte12xp driver that is global for all cards. Default behavior is
+	  not changed with this commit. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* include/dahdi/kernel.h, drivers/dahdi/dahdi-sysfs.c: dahdi: Allow
+	  'spantype' to be changed before span assignement via sysfs. For
+	  some boards, the linemode (E1/T1/J1) is software selectable but
+	  needs to be configured before the spans were historically
+	  registered since the line mode determines the channel count
+	  available on the span. This change exports a "spantype" attribute
+	  from the dahdi_device that can be used to set E1/T1/J1 before the
+	  spans are assigned. When userspace writes to this attribute (in a
+	  <span offset>:<span type string> format), and if the board driver
+	  has implemented a set_spantype function in it's dahdi_span_ops,
+	  then the board driver can optionally change it's mode before
+	  registration. Also part of this change is breaking out the raw
+	  data structure initialization of the spans / channels via the
+	  dahdi_init_device_spans function since the board drivers may need
+	  to reallocate channels / spans as part of this callback. For
+	  example, changing from T1 to E1 mode will require allocating 7
+	  new channels. Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wcfxo.c, drivers/dahdi/wcte12xp/base.c,
+	  drivers/dahdi/wcb4xxp/base.c, include/dahdi/kernel.h,
+	  drivers/dahdi/wct4xxp/base.c, drivers/dahdi/wcte11xp.c,
+	  drivers/dahdi/dahdi-sysfs.c, drivers/dahdi/wct1xxp.c,
+	  drivers/dahdi/wctdm.c, drivers/dahdi/wctdm24xxp/base.c,
+	  drivers/dahdi/dahdi-base.c: dahdi: Remove dahdi_span.irq and move
+	  dahdi_span.irqmisses into dahdi_device. 'irqmisses' is more a
+	  function of the device and there are better ways to get to IRQ
+	  for a device than storing it in any DAHDI structures.
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wcte12xp/base.c, include/dahdi/kernel.h,
+	  drivers/dahdi/dahdi-sysfs.c, drivers/dahdi/dahdi.h,
+	  drivers/dahdi/xpp/xbus-core.c, drivers/dahdi/dahdi-base.c: dahdi:
+	  Expose dahdi devices in sysfs. This exposes dahdi devices in
+	  sysfs and also exposes attributes that will allow user space to
+	  control the registration order in spans. This facilitates loading
+	  drivers out of order yet keeping consistent span/channel
+	  numbering, which in turn will eventually allow the blacklist for
+	  DAHDI drivers to be removed. The default behavior, controlled
+	  with the auto_register module parameter on dahdi is to number the
+	  spans / channels in order like is currently done. So this change
+	  does not introduce any new behavior by default. * Writing
+	  (anything) to this attribute returns the span to its unassigned
+	  state * Fix dahdi_chan_unreg() echocan refcount * Add safeguard
+	  against duplicate unassignment to _dahdi_unregister_span() *
+	  Remove the span from device_node list, only in
+	  dahdi_unregister_device() and not in dahdi_unregister_span() *
+	  Free allocated span->span_device in span_sysfs_remove() [is it
+	  safe?, didn't cause problem so far...] Signed-off-by: Shaun
+	  Ruffell <sruffell at digium.com> Signed-off-by: Oron Peled
+	  <oron.peled at xorcom.com> Signed-off-by: Tzafrir Cohen
+	  <tzafrir.cohen at xorcom.com> dahdi: Add "hardware_id" dahdi_device
+	  attribute. - The "hardware_id" does not change with device
+	  location (e.g: when a PCI card is moved from one slot to
+	  another). - Not all devices have this attribute. It is legal for
+	  it to be NULL (that is the default for all low-level drivers that
+	  do not set it explicitly). - When "hardware_id" is NULL, the
+	  sysfs attribute value is "\n" Signed-off-by: Oron Peled
+	  <oron.peled at xorcom.com> Acked-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* include/dahdi/kernel.h, drivers/dahdi/dahdi-sysfs.c,
+	  drivers/dahdi/dahdi-base.c: dahdi: Expose spans in sysfs. This
+	  change will facilitate creating rules that will allow spans and
+	  channels to be accessed by named device files instead of by
+	  numbers. Signed-off-by: Oron Peled <oron.peled at xorcom.com>
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/tor2.c, drivers/dahdi/wcfxo.c,
+	  drivers/dahdi/wcte12xp/base.c, include/dahdi/kernel.h,
+	  drivers/dahdi/pciradio.c, drivers/dahdi/wct4xxp/base.c,
+	  drivers/dahdi/xpp/xbus-sysfs.c,
+	  drivers/dahdi/voicebus/voicebus.c,
+	  drivers/dahdi/wctdm24xxp/base.c,
+	  drivers/dahdi/wcte12xp/wcte12xp.h,
+	  drivers/dahdi/wcb4xxp/wcb4xxp.h, drivers/dahdi/xpp/xpp_dahdi.c,
+	  drivers/dahdi/wcb4xxp/base.c, drivers/dahdi/xpp/xpp_dahdi.h,
+	  drivers/dahdi/wcte11xp.c, drivers/dahdi/wctdm24xxp/wctdm24xxp.h,
+	  drivers/dahdi/dahdi_dynamic.c, drivers/dahdi/wctdm.c,
+	  drivers/dahdi/wct1xxp.c, drivers/dahdi/xpp/xbus-core.c,
+	  drivers/dahdi/dahdi-base.c, drivers/dahdi/xpp/xbus-core.h: dahdi:
+	  Register devices instead of individual spans. Increasingly, spans
+	  are implemented by devices that support more than a single span.
+	  Introduce a 'struct dahdi_device' object which explicitly
+	  contains multiple spans. This will allow a cleaner representation
+	  of spans and devices in sysfs since order of arrival will not
+	  determine the layout of the devices. This also gives the core of
+	  dahdi a way to know the relationship between spans. This
+	  generalizes similar concepts that were previously xpp specific.
+	  The conversion of the xpp code was almost entirely done by Oron
+	  and Tzafrir. Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+	  Signed-off-by: Oron Peled <oron.peled at xorcom.com> Signed-off-by:
+	  Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/dahdi-base.c: dahdi: dahdi_is_analog_span() ->
+	  dahdi_is_digital_span() * dahdi-base.c had a reverse
+	  is_analog_span() static function -- fixed. Signed-off-by: Oron
+	  Peled <oron.peled at xorcom.com> Acked-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* drivers/dahdi/dahdi-base.c: dahdi: Add error messages in
+	  dahdi_ioctl_chanconfig. Provide more context to trouble shoot
+	  failures. Signed-off-by: Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+	  Acked-by: Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/xpp/xpp_dahdi.c, drivers/dahdi/dahdi-base.c: dahdi:
+	  start handling "surprise device removal". This patch contains
+	  interim results while trying to make device removal work
+	  correctly: * XPP has protections to prevent dahdi unregistration
+	  while channels are open -- they are now removed, so we can
+	  unregister immediately. * Handle processes in poll_wait(): - Wake
+	  them during dahdi_chan_unreg() after the channel is gone
+	  (chan->channo = -1 or chan->file->private_data == NULL) - Test in
+	  every wait_event_interruptible() that the channel was not gone
+	  (chan->file->private_data) - Return correct values (POLLERR |
+	  POLLHUP) instead of some errno (would be important in the future
+	  if we modify asterisk to respond correctly to this condition. *
+	  Other issues: - If unregistered channel is being polled, than
+	  call msleep() before returning, to give other processes a chance
+	  (normally, asterisk has RT priority) - Call close_channel() from
+	  dahdi_chan_unreg() so it releases related tonezone * There is
+	  still a horrible race hidden by msleep(20) in dahdi_chan_unreg()
+	  force close channels from dahdi_chan_unreg(): * Mark them via
+	  DAHDI_FLAGBIT_OPEN * Call low-level driver close() method if
+	  available * What about other closing activities? Signed-off-by:
+	  Oron Peled <oron.peled at xorcom.com> Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+2011-10-24 22:19 +0000 [r10269]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Deprecate 't1e1override'
+	  module parameter in favor of 'default_linemode'. 't1e1override'
+	  isn't immediately apparent what it is supposed to do by the name.
+	  Instead 'default_linemode' module parameter can be set to "auto",
+	  "t1", or "e1" to make it clear. This change was introduced
+	  earlier in the wcte12xp driver. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+2011-10-21 19:32 +0000 [r10226-10252]  Shaun Ruffell <sruffell at digium.com>
+
+	* include/dahdi/kernel.h, drivers/dahdi/wctc4xxp/base.c: dahdi:
+	  Move WARN_ON_ONCE from wctc4xxp driver to include/dahdi/kernel.h
+	  I only generally test on RHEL 4 when testing against kernels
+	  older than 2.6.18. Apparently OpenSUSE 10.1 runs with 2.6.16 and
+	  doesn't have WARN_ON_ONCE backported. I took the patch Richard
+	  Miller originally attached to the issue and moved it to
+	  include/dahdi/kernel.h so it would be available for all the board
+	  drivers in the future. Internal-Issue-ID: DAHLIN-260 Reported-by:
+	  Richard Miller Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wcb4xxp/base.c: wcb4xxp: Do not show LASVEGAS2 as
+	  echocan name if vpmsupport is set to 0 This fixes an issue where
+	  "EC: LASVEGAS2" was displayed in /proc/dahdi/x for a B410P span
+	  even though vpmsupport was disabled with the module parameter.
+	  Internal-Issue-ID: DAHLIN-247 Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Refactor t4_serial_setup()
+	  to remove t4.globalconfig. Allows the globalconfig member to be
+	  removed from the struct t4 and not carried around for the life of
+	  the card. Also holds the reglock a little longer for all the
+	  framer writes but I realize the startup of the wct4xxp based
+	  cards does not need to be optimized. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Trivial. Use ARRAY_SIZE in
+	  free_wc() and __handle_leds(). Reduces the amount of code to read
+	  in the two functions and fixes checkpatch.pl warnings.
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com> Acked-by:
+	  Michael Spiceland <mspiceland at digium.com> Acked-by: Russ
+	  Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Atomically perform some
+	  read/modify/write operations There are read/modify/write
+	  operations on the framer that were not protected by any locks.
+	  While I didn't notice any code paths that would result in
+	  simultaneous accesses to these registers, this change will
+	  hopefully save someone else some time in the future verifying
+	  that the accesses are safe. A side effect is that the reglock is
+	  acquired only once for each read/modify/write cycle as opposed to
+	  twice previously. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Fix spelling Contains a
+	  minor spelling correction. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Change t4_span.spantype to
+	  linemode. Since 'linemode' more accurately describes what
+	  spantype is specifying. We can also use an enumeration for the
+	  linemode to make it explicit that linemode is only set to one of
+	  three possible values. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Trivial refactoring in
+	  t4_init_one(). Use some convenience pointers to make the function
+	  easier to read as opposed to indexing into the arrays.
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com> Acked-by:
+	  Michael Spiceland <mspiceland at digium.com> Acked-by: Russ
+	  Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Add has_e1_span() helper.
+	  All those checks for wc->t1e1 span appear to basically be there
+	  to determine if there are *any* E1 spans exported by the card. We
+	  can make that explicit by wrapping those tests with a
+	  has_e1_span() inline function to help with readability.
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com> Acked-by:
+	  Michael Spiceland <mspiceland at digium.com> Acked-by: Russ
+	  Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wcte12xp/base.c: wcte12xp: Deprecate 't1e1override'
+	  module parameter in favor of 'default_linemode'. 't1e1override'
+	  isn't immediately apparent what it is supposed to do by the name.
+	  Instead 'default_linemode' module parameter can be set to "auto",
+	  "t1", or "e1" to make it clear. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove redundant 'vpm'
+	  from struct t4. Since removal of the VPM400 support the 'vpm'
+	  member of struct t4 is now redundant with the 'vpm450m' member.
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com> Acked-by:
+	  Michael Spiceland <mspiceland at digium.com> Acked-by: Russ
+	  Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove vpm400 support. The
+	  VPM400 module is no longer supported by the wct4xxp driver. The
+	  VPMOCT064 and VPMOCT128 are. Signed-off-by: Russ Meyerreicks
+	  <rmeyerriecks at digium.com> Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove unused debugging
+	  code Signed-off-by: Shaun Ruffell <sruffell at digium.com> Acked-by:
+	  Michael Spiceland <mspiceland at digium.com> Acked-by: Russ
+	  Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Turn off the fancy alarm
+	  LEDS. Saves about a 1us on average from the interrupt handler on
+	  one test system. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Hold a pointer to the
+	  devtype directly Eliminates the need to store a copy of the flags
+	  and variety from the global devtype. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove unused fields from
+	  'struct t4' and 'struct t4_span' 'memaddr' and 'memlen' is
+	  already cached as part of the underlying pci device so the
+	  wct4xxp driver does not need to cache it again. 'canary',
+	  'passno', 'master', and 'oct_rw_count' are unused. In t4_span
+	  'irqmisses' was incremented, but never used anywhere, and there
+	  is already the irqmisses on the span itself. Signed-off-by: Shaun
+	  Ruffell <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove prefetching
+	  support. I was unable to measure a performance change with
+	  prefetching. Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+	  Acked-by: Michael Spiceland <mspiceland at digium.com> Acked-by:
+	  Russ Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Use in-hardirq version of
+	  dahdi_receive/transmit. We are already in hardirq context and can
+	  therefore save the cli/sti call. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: __t4_framer_in and
+	  __t4_framer_out speedups. Speeds up these calls primarily by
+	  eliminating unnecessary flushes of writes to the PCI bus. Before:
+	  7.095 us | __t4_framer_in(); 5.835 us | __t4_framer_out(); 7.122
+	  us | __t4_framer_in(); 7.071 us | __t4_framer_in(); 7.059 us |
+	  __t4_framer_in(); 5.859 us | __t4_framer_out(); 7.076 us |
+	  __t4_framer_in(); 5.852 us | __t4_framer_out(); 7.124 us |
+	  __t4_framer_in(); 7.080 us | __t4_framer_in(); After: 1.694 us |
+	  __t4_framer_out(); 1.686 us | __t4_framer_out(); 1.695 us |
+	  __t4_framer_out(); 3.182 us | __t4_framer_in(); 3.283 us |
+	  __t4_framer_in(); 2.889 us | __t4_framer_in(); 2.942 us |
+	  __t4_framer_in(); 2.951 us | __t4_framer_in(); 2.906 us |
+	  __t4_framer_in(); Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove 'pedanticpci'
+	  module parameter. The 'pedanticpci' module parameter, which is
+	  always on by default, inserts extra reads from the card in order
+	  to ensure that all writes are properly flushed through any PCI
+	  bridges which may post the writes. The side effect is that this
+	  takes more CPU time for registers reads and writes, especially to
+	  the framer registers. It is never recommended to run with
+	  pedanticpci set to 0, so I'm removing it as a module parameter so
+	  that the default case does not take a performance hit checking
+	  for whether the parameter is set or not. Signed-off-by: Shaun
+	  Ruffell <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove some debug
+	  information from the kernel logs. Also has the nice side effect
+	  of eliminating a comparison from the interrupt handler.
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com> Acked-by:
+	  Michael Spiceland <mspiceland at digium.com> Acked-by: Russ
+	  Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Slow down the rate we poll
+	  the framers in alarm. The overhead of reading the framer
+	  registers is significant and can result in latency bumps / data
+	  drops on heavily loaded systems. Instead of checking all spans
+	  every millisecond when they are in alarm we will instead only
+	  check every 100 ms. On one test system, dropped the % CPU time
+	  spent in hard interrupt context from 10% per TDM4XX when all four
+	  spans are in alarm to closer to 2%. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Move "hardware DTMF
+	  disabled" message from dev_notice -> dev_info This is the
+	  "normal" condition and can be lumped with the other informational
+	  messages. Otherwise, just this one message might go to the
+	  console depending on the system configuration which can be
+	  confusing. Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+	  Acked-by: Michael Spiceland <mspiceland at digium.com> Acked-by:
+	  Russ Meyerriecks <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wctdm24xxp/wctdm24xxp.h: wctdm24xxp: Remove
+	  DEBOUNCING_RINGING_OFF from ring_detector_state enum. This value
+	  is not used and is now gone. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* drivers/dahdi/wctdm24xxp/base.c: wctdm24xxp: Setup all VPMADT032
+	  channels on hybrid cards. r10160 "wctdm24xxp: Probe for and
+	  configure modules in parallel." did not properly setup the
+	  VPMADT032 for all ports on hybrid cards. The most immediate
+	  sympton being that spans 3 and up on a hybrid card would not come
+	  up in Asterisk even though they were out of alarm. This was
+	  because the echo canceler was blocking messages on the dchannels.
+	  This does not affect any previously released versions of
+	  DAHDI-Linux or users of the VPMOCT032. Signed-off-by: Shaun
+	  Ruffell <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* include/dahdi/kernel.h, drivers/dahdi/wctdm24xxp/base.c: dahdi:
+	  Add functions for determining spantype (E1/T1) to
+	  include/dahdi/kernel.h Uses the linecompat member to determine
+	  what type of span it is. This will allow removing T1/E1 flags
+	  from other places where the span type is stored. This function
+	  also changes the return value from bool to int for the inlines
+	  defined in include/dahdi/kernel.h. This is because not all kernel
+	  versions include stdbool.h in the headers and it will conflict
+	  with boolean values that are exported via module parameters on
+	  some older kernels if dahdi included it globally. Signed-off-by:
+	  Shaun Ruffell <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+	* include/dahdi/kernel.h: dahdi: Define pr_xxx macros if not
+	  already defined. The pr_ macros are the recommended way for
+	  subsystems to print messages but not all kernel versions DAHDI
+	  support has them defined. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Michael Spiceland
+	  <mspiceland at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+2011-10-12 16:12 +0000 [r10220]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Fix condition where
+	  hardware echo canceler erroneously mutes DTMF. Commit r9750
+	  "wct4xxp: Reduce the memory footprint of the hardware
+	  echocanceler.", as part of reducing the non-pageable memory
+	  required to support the VPMOCT064 and VPMOCT128, disabled caching
+	  of some hardware echocan registers. This resulted in more
+	  physical reads to the echo canceler. These new read transactions
+	  exposed an existing issue where sometimes reads could be turned
+	  into writes which put a channel into an unintended state
+	  preventing Asterisk from detecting any DTMF. This issue is
+	  resolved by ensuring that the write signal to the Octasic part is
+	  explicitly cleared between when the address is presented on the
+	  bus and when the read and chip select signals are asserted. The
+	  cost is an increase in the average time to enable / disable echo
+	  cancellation by about 5 us on one Intel Xeon X3220 test machine
+	  (~250ns increase per read from the Octasic part and 20 reads to
+	  enable / disable a channel). This commit resolves a behavioral
+	  regression first introduced in 2.5.0 and 2.4.1 which could take
+	  many calls before revealing itself. This change only affects
+	  cards with a VPMOCT128 or VPMOCT064 installed. Signed-off-by:
+	  Shaun Ruffell <sruffell at digium.com> Acked-by: Doug Bailey
+	  <dbailey at digium.com>
+
+2011-09-30 19:12 +0000 [r10218]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wctc4xxp/base.c: wctc4xxp: Allow G723 SID frames to
+	  pass to the hardware decoder. The driver has, until now, dropped
+	  G723 SID frames even though the firmware on the TC400/TCE400 can
+	  handle them. Now let them on through. Reported-and-Tested-by:
+	  Angel Carhuas <acarhuas at colinanet.com> Signed-off-by: Shaun
+	  Ruffell <sruffell at digium.com>
+
+2011-09-29 16:11 +0000 [r10212]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wcte12xp/base.c: wcte12xp: Set uncollected
+	  performance counters to -1. The intent here is to flag to users
+	  that the maintenance counters are not collected for spans
+	  exported by the wcte12xp driver. dahdi_maint before this change:
+	  # dahdi_maint -s 1 Span 1: >Framing Errors : 0: >CRC Errors : 0:
+	  >Code Violations : 0: >E-bit Count : 0: >General Errored Seconds
+	  : 0: And after: # dahdi_maint -s 1 Span 1: >Framing Errors : -1:
+	  >CRC Errors : -1: >Code Violations : -1: >E-bit Count : -1:
+	  >General Errored Seconds : -1: This can be combined with a change
+	  to dahdi_maint to recognize that the errors are -1 and print an
+	  even more explicit warning. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com> Acked-by: Russ Meyerriecks
+	  <rmeyerriecks at digium.com>
+
+2011-09-27 22:08 +0000 [r10210]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/wctdm24xxp/base.c: wctdm24xxp: Set
+	  dahdi_span.devicetype string in one place. Currently, the
+	  devicetype string was set both when the device was first
+	  allocated and updated when an echocanceler was detected. For
+	  simplicity, combine both these steps into a single function. This
+	  change also replaces an improper use of strncat with strlcat.
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com>
+
+2011-09-27 17:10 +0000 [r10209]  Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/xpp/card_fxs.c: xpp: fix FXS D DTMF detection (not
+	  zero) * 'D' DTMF digits were accidentally discarded with the
+	  notice message: "Bad DTMF value 0. Ignored". * No need for an odd
+	  1-based translation table anymore - it's 0-based. Signed-off-by:
+	  Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+2011-09-23 20:18 +0000 [r10203-10205]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/dahdi-base.c: dahdi: Check for master in
+	  DAHDI_STARTUP / resolves MeetMe regression. There were a couple
+	  of reports that MeetMe conferences were not working in 2.5.0.1
+	  and that downgrading to 2.4.1.2 resolved the issue. This could
+	  occur if there were no analog spans in a system, and all the
+	  digital spans were out of alarm before DAHDI_STARTUP ioctl was
+	  called by dahdi_cfg. If the spans were *not* out of alarm, they
+	  would be marked master when the span changes it's alarm state.
+	  This would result in a condition where no spans were marked as
+	  the "master" and so the core timer was handling conferencing. The
+	  core timer runs by default at 4ms and most board drivers run at
+	  1ms intervals, but a channel currently only buffers up 2ms of
+	  data when conferenced. Therefore, 2ms of audio from a board was
+	  continuously dropped from the conference every 4ms by default.
+	  This fixes a regression first introduced in 2.5.0 which was
+	  specifically added in revision r9611 "dahdi: Do not locate new
+	  master in interrupt context." Internal-reference-ID: DAHDI-894
+	  Signed-off-by: Shaun Ruffell <sruffell at digium.com> Tested-by:
+	  Dennis Martinez <dmartinez at digium.com>
+
+	* drivers/dahdi/wct4xxp/base.c: wct4xxp: Remove unused
+	  t4_span.psync and t4_span.redalarms. These members are not used
+	  anywhere and are now gone. Signed-off-by: Shaun Ruffell
+	  <sruffell at digium.com>
+
+	* drivers/dahdi/wcte12xp/base.c, drivers/dahdi/wctdm24xxp/base.c:
+	  wctdm24xxp, wcte12xp: Advertise VPMOCT032 presence in
+	  dahdi_span.devicetype. A "(VPMADT032)" string is appended to the
+	  devicetype (as shown by dahdi_scan) for the span if one is
+	  installed. Now append '(VPMOCT032)' if one is installed as well.
+	  Also, for the wcte12xp driver append the VPM name to the device
+	  type after initially probing as opposed to only after the span is
+	  configured. (Related to issue DAHDI-890) Signed-off-by: Shaun
+	  Ruffell <sruffell at digium.com>
+
+2011-09-22 18:55 +0000 [r10202]  Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+	* drivers/dahdi/xpp/card_fxs.c: xpp: fxs: bugfix for 2fxs+6fxo
+	  cards * Bug sympthoms: wrong FSK VMWI sent few seconds after
+	  offhook. That was caused because the driver kept polling the
+	  (physically unconnected) digital inputs. [note: a workaround for
+	  drivers without this patch is to zero the
+	  'xpd_fxs.poll_digital_inputs' parameter.] * Also, the
+	  digital_inputs/digital_output masks were calculate using a
+	  different condition. * Now we determine number of channels,
+	  digital inputs and digital outputs in a single place and use this
+	  info later to calculate the correct masks. * We poll only if
+	  there are digital_inputs * We added a sanity check in
+	  process_digital_inputs, so we get a notice if it's called on an
+	  xpd without digital inputs (e.g: hypothetic firmware bug).
+	  Signed-off-by: Tzafrir Cohen <tzafrir.cohen at xorcom.com> Acked-by:
+	  Tzafrir Cohen <tzafrir.cohen at xorcom.com>
+
+2011-09-13 18:28 +0000 [r10200]  Shaun Ruffell <sruffell at digium.com>
+
+	* drivers/dahdi/dahdi-base.c: dahdi: Decrease the initial coretimer
+	  delay to 4ms from 1 second. DAHDI currently waits a second before
+	  checking if a board driver is calling dahdi_receive and switching
+	  to internal timing. Some versions of Asterisk (I was looking at
+	  1.4.42 when writing this) only wait 300ms for a timer to expire
+	  when first starting and verifying that DAHDI is properly
+	  configured. This can result in a "ERROR[27673] asterisk.c:

[... 5100 lines stripped ...]



More information about the dahdi-commits mailing list