Author: marius
Date: Wed Jan 27 22:31:08 2016
New Revision: 294958
URL: https://svnweb.freebsd.org/changeset/base/294958

Log:
  Sync the e1000 drivers with what's in head as of r294327, modulo parts
  that don't apply to stable/10 (driver API, if_inc_counter(), RSS changes
  etc.) and modulo r287465 (which reportedly breaks igb(4)), i. e. assorted
  fixes and improvements only:
  
  o MFC r267385 (partial):
    - Don't compare bus_dma map pointers for static DMA allocations against
      NULL to determine if bus_dmamap_unload() or bus_dmamem_free() should be
      called. Instead, check the associated bus and virtual addresses.
    - Don't clear static DMA maps to NULL.
  o MFC r284933:
    Delete the refernce to VLAN handling being disabled by default. This is
    no longer the case. [1]
  o MFC r285639:
    Add an adapter CORE lock in the DDB hook em_dump_queue to avoid WITNESS
    panic in em_init_locked() while debugging.
  o MFC r285879:
    - Remove unused txd_saved.
    - Intialize txd_upper, txd_lower and txd_used at declaration.
  o MFC r286162:
    Free mbufs when busdma loading fails.
  o MFC r286829:
    Add capability to disable CRC stripping as it breaks IPMI/BMC capabilities
    on certain adatpers. [2]
  o MFC r286831: [3]
    - Increase EM_MAX_SCATTER to 64 such that the size of em_xmit()::
      segs[EM_MAX_SCATTER] doesn't get overrun by things like NFS that can
      and do shove more than 32 segs when being used with em(4) and TSO4.
    - Update tso handling code in em_xmit() with update from jhb@
    - Set if_hw_tsomax, if_hw_tsomaxsegcount and if_hw_tsomaxsegsize to
      appropriate values.
    - Define a TSO workaround "magic" number of 4 that is used to avoid an
      alignment issue in hardware.
    - Change a couple of integer values that were used as booleans to actual
      bool types.
    - Ensure that em_enable_intr() enables the appropriate mask of interrupts
      and not just a hardcoded define of values.
  o MFC r286832:
    e1000/if_lem.c bump to 1.1.0
  o MFC r286833:
    Bump all copywrite dates to 2015.
  o MFC r287112:
    Style/whitespace cleanup in shared/common code.
  o MFC r293331:
    - Switch em(4) to the extended RX descriptor format.
    - Split rxbuffer and txbuffer apart to support the new RX descriptor
      format structures. Move rxbuffer manipulation to em_setup_rxdesc() to
      unify the new behavior changes.
    - Add a RSSKEYLEN macro for help in generating the RSSKEY data structures
      in the card.
    - Change em_receive_checksum() to process the new rxdescriptor format
      status bit.
  o MFC r293332:
    Disable the reuse of checksum offload context descriptors in the case
    of multiple queues in em(4). Document errata in the code.
  o MFC r293854:
    Given that em(4), lem(4) and igb(4) hardware doesn't require the
    alignment guarantees provided by m_defrag(9), use m_collapse(9)
    instead for performance reasons.
    While at it, sanitize the statistics softc members, i. e. retire
    unused ones and add SYSCTL nodes missing for actually used ones.
  
  PR:   118693 [1], 161277 [2], 195078 [3], 199174 [3], 200221 [3]

Modified:
  stable/10/share/man/man4/em.4
  stable/10/sys/dev/e1000/e1000_80003es2lan.c
  stable/10/sys/dev/e1000/e1000_80003es2lan.h
  stable/10/sys/dev/e1000/e1000_82540.c
  stable/10/sys/dev/e1000/e1000_82541.c
  stable/10/sys/dev/e1000/e1000_82541.h
  stable/10/sys/dev/e1000/e1000_82542.c
  stable/10/sys/dev/e1000/e1000_82543.c
  stable/10/sys/dev/e1000/e1000_82543.h
  stable/10/sys/dev/e1000/e1000_82571.c
  stable/10/sys/dev/e1000/e1000_82571.h
  stable/10/sys/dev/e1000/e1000_82575.c
  stable/10/sys/dev/e1000/e1000_82575.h
  stable/10/sys/dev/e1000/e1000_api.c
  stable/10/sys/dev/e1000/e1000_api.h
  stable/10/sys/dev/e1000/e1000_defines.h
  stable/10/sys/dev/e1000/e1000_hw.h
  stable/10/sys/dev/e1000/e1000_i210.c
  stable/10/sys/dev/e1000/e1000_i210.h
  stable/10/sys/dev/e1000/e1000_ich8lan.c
  stable/10/sys/dev/e1000/e1000_ich8lan.h
  stable/10/sys/dev/e1000/e1000_mac.c
  stable/10/sys/dev/e1000/e1000_mac.h
  stable/10/sys/dev/e1000/e1000_manage.c
  stable/10/sys/dev/e1000/e1000_manage.h
  stable/10/sys/dev/e1000/e1000_mbx.c
  stable/10/sys/dev/e1000/e1000_mbx.h
  stable/10/sys/dev/e1000/e1000_nvm.c
  stable/10/sys/dev/e1000/e1000_nvm.h
  stable/10/sys/dev/e1000/e1000_osdep.c
  stable/10/sys/dev/e1000/e1000_osdep.h
  stable/10/sys/dev/e1000/e1000_phy.c
  stable/10/sys/dev/e1000/e1000_phy.h
  stable/10/sys/dev/e1000/e1000_regs.h
  stable/10/sys/dev/e1000/e1000_vf.c
  stable/10/sys/dev/e1000/e1000_vf.h
  stable/10/sys/dev/e1000/if_em.c
  stable/10/sys/dev/e1000/if_em.h
  stable/10/sys/dev/e1000/if_igb.c
  stable/10/sys/dev/e1000/if_igb.h
  stable/10/sys/dev/e1000/if_lem.c
  stable/10/sys/dev/e1000/if_lem.h
  stable/10/sys/dev/ixgb/if_ixgb.c
  stable/10/sys/dev/netmap/if_em_netmap.h
Directory Properties:
  stable/10/   (props changed)

Modified: stable/10/share/man/man4/em.4
==============================================================================
--- stable/10/share/man/man4/em.4       Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/share/man/man4/em.4       Wed Jan 27 22:31:08 2016        
(r294958)
@@ -31,7 +31,7 @@
 .\"
 .\" $FreeBSD$
 .\"
-.Dd October 11, 2011
+.Dd August 16, 2015
 .Dt EM 4
 .Os
 .Sh NAME
@@ -205,6 +205,11 @@ Tunables can be set at the
 prompt before booting the kernel or stored in
 .Xr loader.conf 5 .
 .Bl -tag -width indent
+.It Va hw.em.disable_crc_stripping
+Disable or enable hardware stripping of CRC field.
+This is mostly useful on BMC/IPMI shared interfaces where stripping the CRC
+causes remote access over IPMI to fail.
+Default 0 (enabled).
 .It Va hw.em.eee_setting
 Disable or enable Energy Efficient Ethernet.
 Default 1 (disabled).
@@ -307,10 +312,5 @@ The
 driver was written by
 .An Intel Corporation Aq free...@intel.com .
 .Sh BUGS
-Hardware-assisted VLAN processing is disabled by default.
-You can enable it on an
-.Nm
-interface using
-.Xr ifconfig 8 .
 .Pp
 Activating EM_MULTIQUEUE support requires MSI-X features.

Modified: stable/10/sys/dev/e1000/e1000_80003es2lan.c
==============================================================================
--- stable/10/sys/dev/e1000/e1000_80003es2lan.c Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/sys/dev/e1000/e1000_80003es2lan.c Wed Jan 27 22:31:08 2016        
(r294958)
@@ -1,6 +1,6 @@
 /******************************************************************************
 
-  Copyright (c) 2001-2013, Intel Corporation 
+  Copyright (c) 2001-2015, Intel Corporation 
   All rights reserved.
   
   Redistribution and use in source and binary forms, with or without 

Modified: stable/10/sys/dev/e1000/e1000_80003es2lan.h
==============================================================================
--- stable/10/sys/dev/e1000/e1000_80003es2lan.h Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/sys/dev/e1000/e1000_80003es2lan.h Wed Jan 27 22:31:08 2016        
(r294958)
@@ -1,6 +1,6 @@
 /******************************************************************************
 
-  Copyright (c) 2001-2013, Intel Corporation 
+  Copyright (c) 2001-2015, Intel Corporation 
   All rights reserved.
   
   Redistribution and use in source and binary forms, with or without 

Modified: stable/10/sys/dev/e1000/e1000_82540.c
==============================================================================
--- stable/10/sys/dev/e1000/e1000_82540.c       Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/sys/dev/e1000/e1000_82540.c       Wed Jan 27 22:31:08 2016        
(r294958)
@@ -1,6 +1,6 @@
 /******************************************************************************
 
-  Copyright (c) 2001-2011, Intel Corporation 
+  Copyright (c) 2001-2015, Intel Corporation 
   All rights reserved.
   
   Redistribution and use in source and binary forms, with or without 

Modified: stable/10/sys/dev/e1000/e1000_82541.c
==============================================================================
--- stable/10/sys/dev/e1000/e1000_82541.c       Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/sys/dev/e1000/e1000_82541.c       Wed Jan 27 22:31:08 2016        
(r294958)
@@ -1,6 +1,6 @@
 /******************************************************************************
 
-  Copyright (c) 2001-2011, Intel Corporation 
+  Copyright (c) 2001-2015, Intel Corporation 
   All rights reserved.
   
   Redistribution and use in source and binary forms, with or without 
@@ -49,34 +49,34 @@ static s32  e1000_init_mac_params_82541(
 static s32  e1000_reset_hw_82541(struct e1000_hw *hw);
 static s32  e1000_init_hw_82541(struct e1000_hw *hw);
 static s32  e1000_get_link_up_info_82541(struct e1000_hw *hw, u16 *speed,
-                                         u16 *duplex);
+                                        u16 *duplex);
 static s32  e1000_phy_hw_reset_82541(struct e1000_hw *hw);
 static s32  e1000_setup_copper_link_82541(struct e1000_hw *hw);
 static s32  e1000_check_for_link_82541(struct e1000_hw *hw);
 static s32  e1000_get_cable_length_igp_82541(struct e1000_hw *hw);
 static s32  e1000_set_d3_lplu_state_82541(struct e1000_hw *hw,
-                                          bool active);
+                                         bool active);
 static s32  e1000_setup_led_82541(struct e1000_hw *hw);
 static s32  e1000_cleanup_led_82541(struct e1000_hw *hw);
 static void e1000_clear_hw_cntrs_82541(struct e1000_hw *hw);
 static s32  e1000_read_mac_addr_82541(struct e1000_hw *hw);
 static s32  e1000_config_dsp_after_link_change_82541(struct e1000_hw *hw,
-                                                     bool link_up);
+                                                    bool link_up);
 static s32  e1000_phy_init_script_82541(struct e1000_hw *hw);
 static void e1000_power_down_phy_copper_82541(struct e1000_hw *hw);
 
-static const u16 e1000_igp_cable_length_table[] =
-    { 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
-      5, 10, 10, 10, 10, 10, 10, 10, 20, 20, 20, 20, 20, 25, 25, 25,
-      25, 25, 25, 25, 30, 30, 30, 30, 40, 40, 40, 40, 40, 40, 40, 40,
-      40, 50, 50, 50, 50, 50, 50, 50, 60, 60, 60, 60, 60, 60, 60, 60,
-      60, 70, 70, 70, 70, 70, 70, 80, 80, 80, 80, 80, 80, 90, 90, 90,
-      90, 90, 90, 90, 90, 90, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100,
-      100, 100, 100, 100, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 
110, 110,
-      110, 110, 110, 110, 110, 110, 120, 120, 120, 120, 120, 120, 120, 120, 
120, 120};
+static const u16 e1000_igp_cable_length_table[] = {
+       5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 10, 10, 10, 10, 10,
+       10, 10, 20, 20, 20, 20, 20, 25, 25, 25, 25, 25, 25, 25, 30, 30, 30, 30,
+       40, 40, 40, 40, 40, 40, 40, 40, 40, 50, 50, 50, 50, 50, 50, 50, 60, 60,
+       60, 60, 60, 60, 60, 60, 60, 70, 70, 70, 70, 70, 70, 80, 80, 80, 80, 80,
+       80, 90, 90, 90, 90, 90, 90, 90, 90, 90, 100, 100, 100, 100, 100, 100,
+       100, 100, 100, 100, 100, 100, 100, 100, 110, 110, 110, 110, 110, 110,
+       110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 120, 120,
+       120, 120, 120, 120, 120, 120, 120, 120};
 #define IGP01E1000_AGC_LENGTH_TABLE_SIZE \
-                (sizeof(e1000_igp_cable_length_table) / \
-                 sizeof(e1000_igp_cable_length_table[0]))
+               (sizeof(e1000_igp_cable_length_table) / \
+                sizeof(e1000_igp_cable_length_table[0]))
 
 /**
  *  e1000_init_phy_params_82541 - Init PHY func ptrs.
@@ -89,23 +89,23 @@ static s32 e1000_init_phy_params_82541(s
 
        DEBUGFUNC("e1000_init_phy_params_82541");
 
-       phy->addr                      = 1;
-       phy->autoneg_mask              = AUTONEG_ADVERTISE_SPEED_DEFAULT;
-       phy->reset_delay_us            = 10000;
-       phy->type                      = e1000_phy_igp;
+       phy->addr               = 1;
+       phy->autoneg_mask       = AUTONEG_ADVERTISE_SPEED_DEFAULT;
+       phy->reset_delay_us     = 10000;
+       phy->type               = e1000_phy_igp;
 
        /* Function Pointers */
-       phy->ops.check_polarity        = e1000_check_polarity_igp;
-       phy->ops.force_speed_duplex    = e1000_phy_force_speed_duplex_igp;
-       phy->ops.get_cable_length      = e1000_get_cable_length_igp_82541;
-       phy->ops.get_cfg_done          = e1000_get_cfg_done_generic;
-       phy->ops.get_info              = e1000_get_phy_info_igp;
-       phy->ops.read_reg              = e1000_read_phy_reg_igp;
-       phy->ops.reset                 = e1000_phy_hw_reset_82541;
-       phy->ops.set_d3_lplu_state     = e1000_set_d3_lplu_state_82541;
-       phy->ops.write_reg             = e1000_write_phy_reg_igp;
-       phy->ops.power_up              = e1000_power_up_phy_copper;
-       phy->ops.power_down            = e1000_power_down_phy_copper_82541;
+       phy->ops.check_polarity = e1000_check_polarity_igp;
+       phy->ops.force_speed_duplex = e1000_phy_force_speed_duplex_igp;
+       phy->ops.get_cable_length = e1000_get_cable_length_igp_82541;
+       phy->ops.get_cfg_done   = e1000_get_cfg_done_generic;
+       phy->ops.get_info       = e1000_get_phy_info_igp;
+       phy->ops.read_reg       = e1000_read_phy_reg_igp;
+       phy->ops.reset          = e1000_phy_hw_reset_82541;
+       phy->ops.set_d3_lplu_state = e1000_set_d3_lplu_state_82541;
+       phy->ops.write_reg      = e1000_write_phy_reg_igp;
+       phy->ops.power_up       = e1000_power_up_phy_copper;
+       phy->ops.power_down     = e1000_power_down_phy_copper_82541;
 
        ret_val = e1000_get_phy_id(hw);
        if (ret_val)
@@ -127,8 +127,8 @@ out:
  **/
 static s32 e1000_init_nvm_params_82541(struct e1000_hw *hw)
 {
-       struct   e1000_nvm_info *nvm = &hw->nvm;
-       s32  ret_val = E1000_SUCCESS;
+       struct e1000_nvm_info *nvm = &hw->nvm;
+       s32 ret_val = E1000_SUCCESS;
        u32 eecd = E1000_READ_REG(hw, E1000_EECD);
        u16 size;
 
@@ -152,28 +152,25 @@ static s32 e1000_init_nvm_params_82541(s
                eecd &= ~E1000_EECD_SIZE;
                break;
        default:
-               nvm->type = eecd & E1000_EECD_TYPE
-                           ? e1000_nvm_eeprom_spi
-                           : e1000_nvm_eeprom_microwire;
+               nvm->type = eecd & E1000_EECD_TYPE ? e1000_nvm_eeprom_spi
+                           : e1000_nvm_eeprom_microwire;
                break;
        }
 
        if (nvm->type == e1000_nvm_eeprom_spi) {
-               nvm->address_bits       = (eecd & E1000_EECD_ADDR_BITS)
-                                         ? 16 : 8;
-               nvm->delay_usec         = 1;
-               nvm->opcode_bits        = 8;
-               nvm->page_size          = (eecd & E1000_EECD_ADDR_BITS)
-                                         ? 32 : 8;
+               nvm->address_bits = (eecd & E1000_EECD_ADDR_BITS) ? 16 : 8;
+               nvm->delay_usec = 1;
+               nvm->opcode_bits = 8;
+               nvm->page_size = (eecd & E1000_EECD_ADDR_BITS) ? 32 : 8;
 
                /* Function Pointers */
-               nvm->ops.acquire        = e1000_acquire_nvm_generic;
-               nvm->ops.read           = e1000_read_nvm_spi;
-               nvm->ops.release        = e1000_release_nvm_generic;
-               nvm->ops.update         = e1000_update_nvm_checksum_generic;
+               nvm->ops.acquire        = e1000_acquire_nvm_generic;
+               nvm->ops.read           = e1000_read_nvm_spi;
+               nvm->ops.release        = e1000_release_nvm_generic;
+               nvm->ops.update         = e1000_update_nvm_checksum_generic;
                nvm->ops.valid_led_default = e1000_valid_led_default_generic;
-               nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
-               nvm->ops.write          = e1000_write_nvm_spi;
+               nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
+               nvm->ops.write          = e1000_write_nvm_spi;
 
                /*
                 * nvm->word_size must be discovered after the pointers
@@ -196,21 +193,19 @@ static s32 e1000_init_nvm_params_82541(s
                        nvm->word_size = 1 << size;
                }
        } else {
-               nvm->address_bits       = (eecd & E1000_EECD_ADDR_BITS)
-                                         ? 8 : 6;
-               nvm->delay_usec         = 50;
-               nvm->opcode_bits        = 3;
-               nvm->word_size          = (eecd & E1000_EECD_ADDR_BITS)
-                                         ? 256 : 64;
+               nvm->address_bits = (eecd & E1000_EECD_ADDR_BITS) ? 8 : 6;
+               nvm->delay_usec = 50;
+               nvm->opcode_bits = 3;
+               nvm->word_size = (eecd & E1000_EECD_ADDR_BITS) ? 256 : 64;
 
                /* Function Pointers */
-               nvm->ops.acquire        = e1000_acquire_nvm_generic;
-               nvm->ops.read           = e1000_read_nvm_microwire;
-               nvm->ops.release        = e1000_release_nvm_generic;
-               nvm->ops.update         = e1000_update_nvm_checksum_generic;
+               nvm->ops.acquire        = e1000_acquire_nvm_generic;
+               nvm->ops.read           = e1000_read_nvm_microwire;
+               nvm->ops.release        = e1000_release_nvm_generic;
+               nvm->ops.update         = e1000_update_nvm_checksum_generic;
                nvm->ops.valid_led_default = e1000_valid_led_default_generic;
-               nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
-               nvm->ops.write          = e1000_write_nvm_microwire;
+               nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
+               nvm->ops.write          = e1000_write_nvm_microwire;
        }
 
 out:
@@ -390,11 +385,10 @@ static s32 e1000_init_hw_82541(struct e1
                DEBUGOUT("Error initializing identification LED\n");
                /* This is not fatal and we should not stop init due to this */
        }
-        
+
        /* Storing the Speed Power Down  value for later use */
-       ret_val = hw->phy.ops.read_reg(hw,
-                                      IGP01E1000_GMII_FIFO,
-                                      &dev_spec->spd_default);
+       ret_val = hw->phy.ops.read_reg(hw, IGP01E1000_GMII_FIFO,
+                                      &dev_spec->spd_default);
        if (ret_val)
                goto out;
 
@@ -423,7 +417,7 @@ static s32 e1000_init_hw_82541(struct e1
 
        txdctl = E1000_READ_REG(hw, E1000_TXDCTL(0));
        txdctl = (txdctl & ~E1000_TXDCTL_WTHRESH) |
-                E1000_TXDCTL_FULL_TX_DESC_WB;
+                 E1000_TXDCTL_FULL_TX_DESC_WB;
        E1000_WRITE_REG(hw, E1000_TXDCTL(0), txdctl);
 
        /*
@@ -447,7 +441,7 @@ out:
  * Retrieve the current speed and duplex configuration.
  **/
 static s32 e1000_get_link_up_info_82541(struct e1000_hw *hw, u16 *speed,
-                                        u16 *duplex)
+                                       u16 *duplex)
 {
        struct e1000_phy_info *phy = &hw->phy;
        s32 ret_val;
@@ -549,6 +543,7 @@ static s32 e1000_setup_copper_link_82541
        ctrl &= ~(E1000_CTRL_FRCSPD | E1000_CTRL_FRCDPX);
        E1000_WRITE_REG(hw, E1000_CTRL, ctrl);
 
+
        /* Earlier revs of the IGP phy require us to force MDI. */
        if (hw->mac.type == e1000_82541 || hw->mac.type == e1000_82547) {
                dev_spec->dsp_config = e1000_dsp_config_disabled;
@@ -651,9 +646,8 @@ static s32 e1000_check_for_link_82541(st
         * different link partner.
         */
        ret_val = e1000_config_fc_after_link_up_generic(hw);
-       if (ret_val) {
+       if (ret_val)
                DEBUGOUT("Error configuring flow control\n");
-       }
 
 out:
        return ret_val;
@@ -671,7 +665,7 @@ out:
  *  gigabit link is achieved to improve link quality.
  **/
 static s32 e1000_config_dsp_after_link_change_82541(struct e1000_hw *hw,
-                                                    bool link_up)
+                                                   bool link_up)
 {
        struct e1000_phy_info *phy = &hw->phy;
        struct e1000_dev_spec_82541 *dev_spec = &hw->dev_spec._82541;
@@ -679,11 +673,11 @@ static s32 e1000_config_dsp_after_link_c
        u32 idle_errs = 0;
        u16 phy_data, phy_saved_data, speed, duplex, i;
        u16 ffe_idle_err_timeout = FFE_IDLE_ERR_COUNT_TIMEOUT_20;
-       u16 dsp_reg_array[IGP01E1000_PHY_CHANNEL_NUM] =
-                                                  {IGP01E1000_PHY_AGC_PARAM_A,
-                                                   IGP01E1000_PHY_AGC_PARAM_B,
-                                                   IGP01E1000_PHY_AGC_PARAM_C,
-                                                   IGP01E1000_PHY_AGC_PARAM_D};
+       u16 dsp_reg_array[IGP01E1000_PHY_CHANNEL_NUM] = {
+                                               IGP01E1000_PHY_AGC_PARAM_A,
+                                               IGP01E1000_PHY_AGC_PARAM_B,
+                                               IGP01E1000_PHY_AGC_PARAM_C,
+                                               IGP01E1000_PHY_AGC_PARAM_D};
 
        DEBUGFUNC("e1000_config_dsp_after_link_change_82541");
 
@@ -708,16 +702,16 @@ static s32 e1000_config_dsp_after_link_c
 
                        for (i = 0; i < IGP01E1000_PHY_CHANNEL_NUM; i++) {
                                ret_val = phy->ops.read_reg(hw,
-                                                           dsp_reg_array[i],
-                                                           &phy_data);
+                                                           dsp_reg_array[i],
+                                                           &phy_data);
                                if (ret_val)
                                        goto out;
 
                                phy_data &= ~IGP01E1000_PHY_EDAC_MU_INDEX;
 
                                ret_val = phy->ops.write_reg(hw,
-                                                            dsp_reg_array[i],
-                                                            phy_data);
+                                                            dsp_reg_array[i],
+                                                            phy_data);
                                if (ret_val)
                                        goto out;
                        }
@@ -737,9 +731,8 @@ static s32 e1000_config_dsp_after_link_c
 
                for (i = 0; i < ffe_idle_err_timeout; i++) {
                        usec_delay(1000);
-                       ret_val = phy->ops.read_reg(hw,
-                                                   PHY_1000T_STATUS,
-                                                   &phy_data);
+                       ret_val = phy->ops.read_reg(hw, PHY_1000T_STATUS,
+                                                   &phy_data);
                        if (ret_val)
                                goto out;
 
@@ -748,8 +741,8 @@ static s32 e1000_config_dsp_after_link_c
                                dev_spec->ffe_config = e1000_ffe_config_active;
 
                                ret_val = phy->ops.write_reg(hw,
-                                                 IGP01E1000_PHY_DSP_FFE,
-                                                 IGP01E1000_PHY_DSP_FFE_CM_CP);
+                                                 IGP01E1000_PHY_DSP_FFE,
+                                                 IGP01E1000_PHY_DSP_FFE_CM_CP);
                                if (ret_val)
                                        goto out;
                                break;
@@ -757,7 +750,7 @@ static s32 e1000_config_dsp_after_link_c
 
                        if (idle_errs)
                                ffe_idle_err_timeout =
-                                                FFE_IDLE_ERR_COUNT_TIMEOUT_100;
+                                                FFE_IDLE_ERR_COUNT_TIMEOUT_100;
                }
        } else {
                if (dev_spec->dsp_config == e1000_dsp_config_activated) {
@@ -765,9 +758,8 @@ static s32 e1000_config_dsp_after_link_c
                         * Save off the current value of register 0x2F5B
                         * to be restored at the end of the routines.
                         */
-                       ret_val = phy->ops.read_reg(hw,
-                                                   0x2F5B,
-                                                   &phy_saved_data);
+                       ret_val = phy->ops.read_reg(hw, 0x2F5B,
+                                                   &phy_saved_data);
                        if (ret_val)
                                goto out;
 
@@ -778,15 +770,14 @@ static s32 e1000_config_dsp_after_link_c
 
                        msec_delay_irq(20);
 
-                       ret_val = phy->ops.write_reg(hw,
-                                                    0x0000,
-                                                    IGP01E1000_IEEE_FORCE_GIG);
+                       ret_val = phy->ops.write_reg(hw, 0x0000,
+                                                    IGP01E1000_IEEE_FORCE_GIG);
                        if (ret_val)
                                goto out;
                        for (i = 0; i < IGP01E1000_PHY_CHANNEL_NUM; i++) {
                                ret_val = phy->ops.read_reg(hw,
-                                                           dsp_reg_array[i],
-                                                           &phy_data);
+                                                           dsp_reg_array[i],
+                                                           &phy_data);
                                if (ret_val)
                                        goto out;
 
@@ -794,24 +785,22 @@ static s32 e1000_config_dsp_after_link_c
                                phy_data |= IGP01E1000_PHY_EDAC_SIGN_EXT_9_BITS;
 
                                ret_val = phy->ops.write_reg(hw,
-                                                            dsp_reg_array[i],
-                                                            phy_data);
+                                                            dsp_reg_array[i],
+                                                            phy_data);
                                if (ret_val)
                                        goto out;
                        }
 
-                       ret_val = phy->ops.write_reg(hw,
-                                              0x0000,
-                                              IGP01E1000_IEEE_RESTART_AUTONEG);
+                       ret_val = phy->ops.write_reg(hw, 0x0000,
+                                              IGP01E1000_IEEE_RESTART_AUTONEG);
                        if (ret_val)
                                goto out;
 
                        msec_delay_irq(20);
 
                        /* Now enable the transmitter */
-                       ret_val = phy->ops.write_reg(hw,
-                                                    0x2F5B,
-                                                    phy_saved_data);
+                       ret_val = phy->ops.write_reg(hw, 0x2F5B,
+                                                    phy_saved_data);
                        if (ret_val)
                                goto out;
 
@@ -838,21 +827,18 @@ static s32 e1000_config_dsp_after_link_c
 
                msec_delay_irq(20);
 
-               ret_val = phy->ops.write_reg(hw,
-                                            0x0000,
-                                            IGP01E1000_IEEE_FORCE_GIG);
+               ret_val = phy->ops.write_reg(hw, 0x0000,
+                                            IGP01E1000_IEEE_FORCE_GIG);
                if (ret_val)
                        goto out;
 
-               ret_val = phy->ops.write_reg(hw,
-                                            IGP01E1000_PHY_DSP_FFE,
-                                            IGP01E1000_PHY_DSP_FFE_DEFAULT);
+               ret_val = phy->ops.write_reg(hw, IGP01E1000_PHY_DSP_FFE,
+                                            IGP01E1000_PHY_DSP_FFE_DEFAULT);
                if (ret_val)
                        goto out;
 
-               ret_val = phy->ops.write_reg(hw,
-                                            0x0000,
-                                            IGP01E1000_IEEE_RESTART_AUTONEG);
+               ret_val = phy->ops.write_reg(hw, 0x0000,
+                                            IGP01E1000_IEEE_RESTART_AUTONEG);
                if (ret_val)
                        goto out;
 
@@ -889,11 +875,10 @@ static s32 e1000_get_cable_length_igp_82
        u16 i, data;
        u16 cur_agc_value, agc_value = 0;
        u16 min_agc_value = IGP01E1000_AGC_LENGTH_TABLE_SIZE;
-       u16 agc_reg_array[IGP01E1000_PHY_CHANNEL_NUM] =
-                                                        {IGP01E1000_PHY_AGC_A,
-                                                         IGP01E1000_PHY_AGC_B,
-                                                         IGP01E1000_PHY_AGC_C,
-                                                         IGP01E1000_PHY_AGC_D};
+       u16 agc_reg_array[IGP01E1000_PHY_CHANNEL_NUM] = {IGP01E1000_PHY_AGC_A,
+                                                        IGP01E1000_PHY_AGC_B,
+                                                        IGP01E1000_PHY_AGC_C,
+                                                        IGP01E1000_PHY_AGC_D};
 
        DEBUGFUNC("e1000_get_cable_length_igp_82541");
 
@@ -929,12 +914,12 @@ static s32 e1000_get_cable_length_igp_82
        }
 
        phy->min_cable_length = (e1000_igp_cable_length_table[agc_value] >
-                                IGP01E1000_AGC_RANGE)
-                               ? (e1000_igp_cable_length_table[agc_value] -
-                                  IGP01E1000_AGC_RANGE)
-                               : 0;
+                                IGP01E1000_AGC_RANGE)
+                               ? (e1000_igp_cable_length_table[agc_value] -
+                                  IGP01E1000_AGC_RANGE)
+                               : 0;
        phy->max_cable_length = e1000_igp_cable_length_table[agc_value] +
-                               IGP01E1000_AGC_RANGE;
+                               IGP01E1000_AGC_RANGE;
 
        phy->cable_length = (phy->min_cable_length + phy->max_cable_length) / 2;
 
@@ -992,50 +977,48 @@ static s32 e1000_set_d3_lplu_state_82541
                 */
                if (phy->smart_speed == e1000_smart_speed_on) {
                        ret_val = phy->ops.read_reg(hw,
-                                                   IGP01E1000_PHY_PORT_CONFIG,
-                                                   &data);
+                                                   IGP01E1000_PHY_PORT_CONFIG,
+                                                   &data);
                        if (ret_val)
                                goto out;
 
                        data |= IGP01E1000_PSCFR_SMART_SPEED;
                        ret_val = phy->ops.write_reg(hw,
-                                                    IGP01E1000_PHY_PORT_CONFIG,
-                                                    data);
+                                                    IGP01E1000_PHY_PORT_CONFIG,
+                                                    data);
                        if (ret_val)
                                goto out;
                } else if (phy->smart_speed == e1000_smart_speed_off) {
                        ret_val = phy->ops.read_reg(hw,
-                                                   IGP01E1000_PHY_PORT_CONFIG,
-                                                   &data);
+                                                   IGP01E1000_PHY_PORT_CONFIG,
+                                                   &data);
                        if (ret_val)
                                goto out;
 
                        data &= ~IGP01E1000_PSCFR_SMART_SPEED;
                        ret_val = phy->ops.write_reg(hw,
-                                                    IGP01E1000_PHY_PORT_CONFIG,
-                                                    data);
+                                                    IGP01E1000_PHY_PORT_CONFIG,
+                                                    data);
                        if (ret_val)
                                goto out;
                }
        } else if ((phy->autoneg_advertised == E1000_ALL_SPEED_DUPLEX) ||
-                  (phy->autoneg_advertised == E1000_ALL_NOT_GIG) ||
-                  (phy->autoneg_advertised == E1000_ALL_10_SPEED)) {
+                  (phy->autoneg_advertised == E1000_ALL_NOT_GIG) ||
+                  (phy->autoneg_advertised == E1000_ALL_10_SPEED)) {
                data |= IGP01E1000_GMII_FLEX_SPD;
                ret_val = phy->ops.write_reg(hw, IGP01E1000_GMII_FIFO, data);
                if (ret_val)
                        goto out;
 
                /* When LPLU is enabled, we should disable SmartSpeed */
-               ret_val = phy->ops.read_reg(hw,
-                                           IGP01E1000_PHY_PORT_CONFIG,
-                                           &data);
+               ret_val = phy->ops.read_reg(hw, IGP01E1000_PHY_PORT_CONFIG,
+                                           &data);
                if (ret_val)
                        goto out;
 
                data &= ~IGP01E1000_PSCFR_SMART_SPEED;
-               ret_val = phy->ops.write_reg(hw,
-                                            IGP01E1000_PHY_PORT_CONFIG,
-                                            data);
+               ret_val = phy->ops.write_reg(hw, IGP01E1000_PHY_PORT_CONFIG,
+                                            data);
        }
 
 out:
@@ -1056,16 +1039,14 @@ static s32 e1000_setup_led_82541(struct 
 
        DEBUGFUNC("e1000_setup_led_82541");
 
-       ret_val = hw->phy.ops.read_reg(hw,
-                                      IGP01E1000_GMII_FIFO,
-                                      &dev_spec->spd_default);
+       ret_val = hw->phy.ops.read_reg(hw, IGP01E1000_GMII_FIFO,
+                                      &dev_spec->spd_default);
        if (ret_val)
                goto out;
 
-       ret_val = hw->phy.ops.write_reg(hw,
-                                       IGP01E1000_GMII_FIFO,
-                                       (u16)(dev_spec->spd_default &
-                                               ~IGP01E1000_GMII_SPD));
+       ret_val = hw->phy.ops.write_reg(hw, IGP01E1000_GMII_FIFO,
+                                       (u16)(dev_spec->spd_default &
+                                       ~IGP01E1000_GMII_SPD));
        if (ret_val)
                goto out;
 
@@ -1089,9 +1070,8 @@ static s32 e1000_cleanup_led_82541(struc
 
        DEBUGFUNC("e1000_cleanup_led_82541");
 
-       ret_val = hw->phy.ops.write_reg(hw,
-                                       IGP01E1000_GMII_FIFO,
-                                       dev_spec->spd_default);
+       ret_val = hw->phy.ops.write_reg(hw, IGP01E1000_GMII_FIFO,
+                                       dev_spec->spd_default);
        if (ret_val)
                goto out;
 
@@ -1178,14 +1158,12 @@ static s32 e1000_phy_init_script_82541(s
                u16 fused, fine, coarse;
 
                /* Move to analog registers page */
-               hw->phy.ops.read_reg(hw,
-                                 IGP01E1000_ANALOG_SPARE_FUSE_STATUS,
-                                 &fused);
+               hw->phy.ops.read_reg(hw, IGP01E1000_ANALOG_SPARE_FUSE_STATUS,
+                                    &fused);
 
                if (!(fused & IGP01E1000_ANALOG_SPARE_FUSE_ENABLED)) {
-                       hw->phy.ops.read_reg(hw,
-                                         IGP01E1000_ANALOG_FUSE_STATUS,
-                                         &fused);
+                       hw->phy.ops.read_reg(hw, IGP01E1000_ANALOG_FUSE_STATUS,
+                                            &fused);
 
                        fine = fused & IGP01E1000_ANALOG_FUSE_FINE_MASK;
                        coarse = fused & IGP01E1000_ANALOG_FUSE_COARSE_MASK;
@@ -1194,19 +1172,19 @@ static s32 e1000_phy_init_script_82541(s
                                coarse -= IGP01E1000_ANALOG_FUSE_COARSE_10;
                                fine -= IGP01E1000_ANALOG_FUSE_FINE_1;
                        } else if (coarse ==
-                                  IGP01E1000_ANALOG_FUSE_COARSE_THRESH)
+                                  IGP01E1000_ANALOG_FUSE_COARSE_THRESH)
                                fine -= IGP01E1000_ANALOG_FUSE_FINE_10;
 
                        fused = (fused & IGP01E1000_ANALOG_FUSE_POLY_MASK) |
-                               (fine & IGP01E1000_ANALOG_FUSE_FINE_MASK) |
-                               (coarse & IGP01E1000_ANALOG_FUSE_COARSE_MASK);
+                               (fine & IGP01E1000_ANALOG_FUSE_FINE_MASK) |
+                               (coarse & IGP01E1000_ANALOG_FUSE_COARSE_MASK);
 
                        hw->phy.ops.write_reg(hw,
-                                          IGP01E1000_ANALOG_FUSE_CONTROL,
-                                          fused);
+                                             IGP01E1000_ANALOG_FUSE_CONTROL,
+                                             fused);
                        hw->phy.ops.write_reg(hw,
-                                     IGP01E1000_ANALOG_FUSE_BYPASS,
-                                     IGP01E1000_ANALOG_FUSE_ENABLE_SW_CONTROL);
+                                     IGP01E1000_ANALOG_FUSE_BYPASS,
+                                     IGP01E1000_ANALOG_FUSE_ENABLE_SW_CONTROL);
                }
        }
 

Modified: stable/10/sys/dev/e1000/e1000_82541.h
==============================================================================
--- stable/10/sys/dev/e1000/e1000_82541.h       Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/sys/dev/e1000/e1000_82541.h       Wed Jan 27 22:31:08 2016        
(r294958)
@@ -1,6 +1,6 @@
 /******************************************************************************
 
-  Copyright (c) 2001-2008, Intel Corporation 
+  Copyright (c) 2001-2015, Intel Corporation 
   All rights reserved.
   
   Redistribution and use in source and binary forms, with or without 
@@ -37,55 +37,55 @@
 
 #define NVM_WORD_SIZE_BASE_SHIFT_82541 (NVM_WORD_SIZE_BASE_SHIFT + 1)
 
-#define IGP01E1000_PHY_CHANNEL_NUM                    4
+#define IGP01E1000_PHY_CHANNEL_NUM             4
 
-#define IGP01E1000_PHY_AGC_A                     0x1172
-#define IGP01E1000_PHY_AGC_B                     0x1272
-#define IGP01E1000_PHY_AGC_C                     0x1472
-#define IGP01E1000_PHY_AGC_D                     0x1872
-
-#define IGP01E1000_PHY_AGC_PARAM_A               0x1171
-#define IGP01E1000_PHY_AGC_PARAM_B               0x1271
-#define IGP01E1000_PHY_AGC_PARAM_C               0x1471
-#define IGP01E1000_PHY_AGC_PARAM_D               0x1871
-
-#define IGP01E1000_PHY_EDAC_MU_INDEX             0xC000
-#define IGP01E1000_PHY_EDAC_SIGN_EXT_9_BITS      0x8000
-
-#define IGP01E1000_PHY_DSP_RESET                 0x1F33
-
-#define IGP01E1000_PHY_DSP_FFE                   0x1F35
-#define IGP01E1000_PHY_DSP_FFE_CM_CP             0x0069
-#define IGP01E1000_PHY_DSP_FFE_DEFAULT           0x002A
-
-#define IGP01E1000_IEEE_FORCE_GIG                0x0140
-#define IGP01E1000_IEEE_RESTART_AUTONEG          0x3300
-
-#define IGP01E1000_AGC_LENGTH_SHIFT                   7
-#define IGP01E1000_AGC_RANGE                         10
-
-#define FFE_IDLE_ERR_COUNT_TIMEOUT_20                20
-#define FFE_IDLE_ERR_COUNT_TIMEOUT_100              100
-
-#define IGP01E1000_ANALOG_FUSE_STATUS            0x20D0
-#define IGP01E1000_ANALOG_SPARE_FUSE_STATUS      0x20D1
-#define IGP01E1000_ANALOG_FUSE_CONTROL           0x20DC
-#define IGP01E1000_ANALOG_FUSE_BYPASS            0x20DE
-
-#define IGP01E1000_ANALOG_SPARE_FUSE_ENABLED     0x0100
-#define IGP01E1000_ANALOG_FUSE_FINE_MASK         0x0F80
-#define IGP01E1000_ANALOG_FUSE_COARSE_MASK       0x0070
-#define IGP01E1000_ANALOG_FUSE_COARSE_THRESH     0x0040
-#define IGP01E1000_ANALOG_FUSE_COARSE_10         0x0010
-#define IGP01E1000_ANALOG_FUSE_FINE_1            0x0080
-#define IGP01E1000_ANALOG_FUSE_FINE_10           0x0500
-#define IGP01E1000_ANALOG_FUSE_POLY_MASK         0xF000
+#define IGP01E1000_PHY_AGC_A                   0x1172
+#define IGP01E1000_PHY_AGC_B                   0x1272
+#define IGP01E1000_PHY_AGC_C                   0x1472
+#define IGP01E1000_PHY_AGC_D                   0x1872
+
+#define IGP01E1000_PHY_AGC_PARAM_A             0x1171
+#define IGP01E1000_PHY_AGC_PARAM_B             0x1271
+#define IGP01E1000_PHY_AGC_PARAM_C             0x1471
+#define IGP01E1000_PHY_AGC_PARAM_D             0x1871
+
+#define IGP01E1000_PHY_EDAC_MU_INDEX           0xC000
+#define IGP01E1000_PHY_EDAC_SIGN_EXT_9_BITS    0x8000
+
+#define IGP01E1000_PHY_DSP_RESET               0x1F33
+
+#define IGP01E1000_PHY_DSP_FFE                 0x1F35
+#define IGP01E1000_PHY_DSP_FFE_CM_CP           0x0069
+#define IGP01E1000_PHY_DSP_FFE_DEFAULT         0x002A
+
+#define IGP01E1000_IEEE_FORCE_GIG              0x0140
+#define IGP01E1000_IEEE_RESTART_AUTONEG                0x3300
+
+#define IGP01E1000_AGC_LENGTH_SHIFT            7
+#define IGP01E1000_AGC_RANGE                   10
+
+#define FFE_IDLE_ERR_COUNT_TIMEOUT_20          20
+#define FFE_IDLE_ERR_COUNT_TIMEOUT_100         100
+
+#define IGP01E1000_ANALOG_FUSE_STATUS          0x20D0
+#define IGP01E1000_ANALOG_SPARE_FUSE_STATUS    0x20D1
+#define IGP01E1000_ANALOG_FUSE_CONTROL         0x20DC
+#define IGP01E1000_ANALOG_FUSE_BYPASS          0x20DE
+
+#define IGP01E1000_ANALOG_SPARE_FUSE_ENABLED   0x0100
+#define IGP01E1000_ANALOG_FUSE_FINE_MASK       0x0F80
+#define IGP01E1000_ANALOG_FUSE_COARSE_MASK     0x0070
+#define IGP01E1000_ANALOG_FUSE_COARSE_THRESH   0x0040
+#define IGP01E1000_ANALOG_FUSE_COARSE_10       0x0010
+#define IGP01E1000_ANALOG_FUSE_FINE_1          0x0080
+#define IGP01E1000_ANALOG_FUSE_FINE_10         0x0500
+#define IGP01E1000_ANALOG_FUSE_POLY_MASK       0xF000
 #define IGP01E1000_ANALOG_FUSE_ENABLE_SW_CONTROL 0x0002
 
-#define IGP01E1000_MSE_CHANNEL_D                 0x000F
-#define IGP01E1000_MSE_CHANNEL_C                 0x00F0
-#define IGP01E1000_MSE_CHANNEL_B                 0x0F00
-#define IGP01E1000_MSE_CHANNEL_A                 0xF000
+#define IGP01E1000_MSE_CHANNEL_D               0x000F
+#define IGP01E1000_MSE_CHANNEL_C               0x00F0
+#define IGP01E1000_MSE_CHANNEL_B               0x0F00
+#define IGP01E1000_MSE_CHANNEL_A               0xF000
 
 
 void e1000_init_script_state_82541(struct e1000_hw *hw, bool state);

Modified: stable/10/sys/dev/e1000/e1000_82542.c
==============================================================================
--- stable/10/sys/dev/e1000/e1000_82542.c       Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/sys/dev/e1000/e1000_82542.c       Wed Jan 27 22:31:08 2016        
(r294958)
@@ -1,6 +1,6 @@
 /******************************************************************************
 
-  Copyright (c) 2001-2014, Intel Corporation 
+  Copyright (c) 2001-2015, Intel Corporation 
   All rights reserved.
   
   Redistribution and use in source and binary forms, with or without 
@@ -62,7 +62,7 @@ static s32 e1000_init_phy_params_82542(s
 
        DEBUGFUNC("e1000_init_phy_params_82542");
 
-       phy->type               = e1000_phy_none;
+       phy->type = e1000_phy_none;
 
        return ret_val;
 }
@@ -77,18 +77,18 @@ static s32 e1000_init_nvm_params_82542(s
 
        DEBUGFUNC("e1000_init_nvm_params_82542");
 
-       nvm->address_bits       =  6;
-       nvm->delay_usec         = 50;
-       nvm->opcode_bits        =  3;
-       nvm->type               = e1000_nvm_eeprom_microwire;
-       nvm->word_size          = 64;
+       nvm->address_bits       =  6;
+       nvm->delay_usec         = 50;
+       nvm->opcode_bits        =  3;
+       nvm->type               = e1000_nvm_eeprom_microwire;
+       nvm->word_size          = 64;
 
        /* Function Pointers */
-       nvm->ops.read           = e1000_read_nvm_microwire;
-       nvm->ops.release        = e1000_stop_nvm;
-       nvm->ops.write          = e1000_write_nvm_microwire;
-       nvm->ops.update         = e1000_update_nvm_checksum_generic;
-       nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
+       nvm->ops.read           = e1000_read_nvm_microwire;
+       nvm->ops.release        = e1000_stop_nvm;
+       nvm->ops.write          = e1000_write_nvm_microwire;
+       nvm->ops.update         = e1000_update_nvm_checksum_generic;
+       nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
 
        return E1000_SUCCESS;
 }
@@ -124,7 +124,8 @@ static s32 e1000_init_mac_params_82542(s
        /* link setup */
        mac->ops.setup_link = e1000_setup_link_82542;
        /* phy/fiber/serdes setup */
-       mac->ops.setup_physical_interface = 
e1000_setup_fiber_serdes_link_generic;
+       mac->ops.setup_physical_interface =
+                                       e1000_setup_fiber_serdes_link_generic;
        /* check for link */
        mac->ops.check_for_link = e1000_check_for_fiber_link_generic;
        /* multicast address update */
@@ -143,7 +144,8 @@ static s32 e1000_init_mac_params_82542(s
        /* clear hardware counters */
        mac->ops.clear_hw_cntrs = e1000_clear_hw_cntrs_82542;
        /* link info */
-       mac->ops.get_link_up_info = 
e1000_get_speed_and_duplex_fiber_serdes_generic;
+       mac->ops.get_link_up_info =
+                               e1000_get_speed_and_duplex_fiber_serdes_generic;
 
        return E1000_SUCCESS;
 }
@@ -325,7 +327,7 @@ static s32 e1000_setup_link_82542(struct
 
        hw->fc.requested_mode &= ~e1000_fc_tx_pause;
 
-       if (mac->report_tx_early == 1)
+       if (mac->report_tx_early)
                hw->fc.requested_mode &= ~e1000_fc_rx_pause;
 
        /*
@@ -335,7 +337,7 @@ static s32 e1000_setup_link_82542(struct
        hw->fc.current_mode = hw->fc.requested_mode;
 
        DEBUGOUT1("After fix-ups FlowControl is now = %x\n",
-                                                    hw->fc.current_mode);
+                 hw->fc.current_mode);
 
        /* Call the necessary subroutine to configure the link. */
        ret_val = mac->ops.setup_physical_interface(hw);
@@ -419,9 +421,8 @@ static int e1000_rar_set_82542(struct e1
         * HW expects these in little endian so we reverse the byte order
         * from network order (big endian) to little endian
         */
-       rar_low = ((u32) addr[0] |
-                  ((u32) addr[1] << 8) |
-                  ((u32) addr[2] << 16) | ((u32) addr[3] << 24));
+       rar_low = ((u32) addr[0] | ((u32) addr[1] << 8) |
+                  ((u32) addr[2] << 16) | ((u32) addr[3] << 24));
 
        rar_high = ((u32) addr[4] | ((u32) addr[5] << 8));
 
@@ -431,6 +432,7 @@ static int e1000_rar_set_82542(struct e1
 
        E1000_WRITE_REG_ARRAY(hw, E1000_RA, (index << 1), rar_low);
        E1000_WRITE_REG_ARRAY(hw, E1000_RA, ((index << 1) + 1), rar_high);
+
        return E1000_SUCCESS;
 }
 

Modified: stable/10/sys/dev/e1000/e1000_82543.c
==============================================================================
--- stable/10/sys/dev/e1000/e1000_82543.c       Wed Jan 27 21:37:43 2016        
(r294957)
+++ stable/10/sys/dev/e1000/e1000_82543.c       Wed Jan 27 22:31:08 2016        
(r294958)
@@ -1,6 +1,6 @@
 /******************************************************************************
 
-  Copyright (c) 2001-2011, Intel Corporation 
+  Copyright (c) 2001-2015, Intel Corporation 
   All rights reserved.
   
   Redistribution and use in source and binary forms, with or without 
@@ -47,9 +47,9 @@ static s32  e1000_init_phy_params_82543(
 static s32  e1000_init_nvm_params_82543(struct e1000_hw *hw);
 static s32  e1000_init_mac_params_82543(struct e1000_hw *hw);
 static s32  e1000_read_phy_reg_82543(struct e1000_hw *hw, u32 offset,
-                                     u16 *data);
+                                    u16 *data);
 static s32  e1000_write_phy_reg_82543(struct e1000_hw *hw, u32 offset,
-                                      u16 data);
+                                     u16 data);
 static s32  e1000_phy_force_speed_duplex_82543(struct e1000_hw *hw);
 static s32  e1000_phy_hw_reset_82543(struct e1000_hw *hw);
 static s32  e1000_reset_hw_82543(struct e1000_hw *hw);
@@ -62,7 +62,7 @@ static s32  e1000_check_for_fiber_link_8
 static s32  e1000_led_on_82543(struct e1000_hw *hw);
 static s32  e1000_led_off_82543(struct e1000_hw *hw);
 static void e1000_write_vfta_82543(struct e1000_hw *hw, u32 offset,
-                                   u32 value);
+                                  u32 value);
 static void e1000_clear_hw_cntrs_82543(struct e1000_hw *hw);
 static s32  e1000_config_mac_to_phy_82543(struct e1000_hw *hw);
 static bool e1000_init_phy_disabled_82543(struct e1000_hw *hw);
@@ -71,7 +71,7 @@ static s32  e1000_polarity_reversal_work
 static void e1000_raise_mdi_clk_82543(struct e1000_hw *hw, u32 *ctrl);
 static u16  e1000_shift_in_mdi_bits_82543(struct e1000_hw *hw);
 static void e1000_shift_out_mdi_bits_82543(struct e1000_hw *hw, u32 data,
-                                           u16 count);
+                                          u16 count);
 static bool e1000_tbi_compatibility_enabled_82543(struct e1000_hw *hw);
 static void e1000_set_tbi_sbp_82543(struct e1000_hw *hw, bool state);
 static s32  e1000_read_mac_addr_82543(struct e1000_hw *hw);
@@ -89,34 +89,34 @@ static s32 e1000_init_phy_params_82543(s
        DEBUGFUNC("e1000_init_phy_params_82543");
 
        if (hw->phy.media_type != e1000_media_type_copper) {
-               phy->type               = e1000_phy_none;
+               phy->type = e1000_phy_none;
                goto out;
        } else {
-               phy->ops.power_up       = e1000_power_up_phy_copper;
-               phy->ops.power_down     = e1000_power_down_phy_copper;
+               phy->ops.power_up = e1000_power_up_phy_copper;
+               phy->ops.power_down = e1000_power_down_phy_copper;
        }
 
-       phy->addr                       = 1;
-       phy->autoneg_mask               = AUTONEG_ADVERTISE_SPEED_DEFAULT;
-       phy->reset_delay_us             = 10000;
-       phy->type                       = e1000_phy_m88;
+       phy->addr               = 1;
+       phy->autoneg_mask       = AUTONEG_ADVERTISE_SPEED_DEFAULT;
+       phy->reset_delay_us     = 10000;
+       phy->type               = e1000_phy_m88;
 
        /* Function Pointers */
-       phy->ops.check_polarity         = e1000_check_polarity_m88;
-       phy->ops.commit                 = e1000_phy_sw_reset_generic;
-       phy->ops.force_speed_duplex     = e1000_phy_force_speed_duplex_82543;
-       phy->ops.get_cable_length       = e1000_get_cable_length_m88;
-       phy->ops.get_cfg_done           = e1000_get_cfg_done_generic;
-       phy->ops.read_reg               = (hw->mac.type == e1000_82543)
-                                         ? e1000_read_phy_reg_82543
-                                         : e1000_read_phy_reg_m88;
-       phy->ops.reset                  = (hw->mac.type == e1000_82543)
-                                         ? e1000_phy_hw_reset_82543
-                                         : e1000_phy_hw_reset_generic;
-       phy->ops.write_reg              = (hw->mac.type == e1000_82543)
-                                         ? e1000_write_phy_reg_82543
-                                         : e1000_write_phy_reg_m88;
-       phy->ops.get_info               = e1000_get_phy_info_m88;
+       phy->ops.check_polarity = e1000_check_polarity_m88;
+       phy->ops.commit         = e1000_phy_sw_reset_generic;
+       phy->ops.force_speed_duplex = e1000_phy_force_speed_duplex_82543;
+       phy->ops.get_cable_length = e1000_get_cable_length_m88;
+       phy->ops.get_cfg_done   = e1000_get_cfg_done_generic;
+       phy->ops.read_reg       = (hw->mac.type == e1000_82543)
+                                 ? e1000_read_phy_reg_82543
+                                 : e1000_read_phy_reg_m88;
+       phy->ops.reset          = (hw->mac.type == e1000_82543)
+                                 ? e1000_phy_hw_reset_82543
+                                 : e1000_phy_hw_reset_generic;
+       phy->ops.write_reg      = (hw->mac.type == e1000_82543)
+                                 ? e1000_write_phy_reg_82543
+                                 : e1000_write_phy_reg_m88;
+       phy->ops.get_info       = e1000_get_phy_info_m88;
 
        /*
         * The external PHY of the 82543 can be in a funky state.
@@ -170,18 +170,18 @@ static s32 e1000_init_nvm_params_82543(s
 
        DEBUGFUNC("e1000_init_nvm_params_82543");
 
-       nvm->type               = e1000_nvm_eeprom_microwire;
-       nvm->word_size          = 64;
-       nvm->delay_usec         = 50;
-       nvm->address_bits       =  6;
-       nvm->opcode_bits        =  3;
+       nvm->type               = e1000_nvm_eeprom_microwire;
+       nvm->word_size          = 64;
+       nvm->delay_usec         = 50;
+       nvm->address_bits       =  6;
+       nvm->opcode_bits        =  3;
 
        /* Function Pointers */
-       nvm->ops.read           = e1000_read_nvm_microwire;
-       nvm->ops.update         = e1000_update_nvm_checksum_generic;
+       nvm->ops.read           = e1000_read_nvm_microwire;
+       nvm->ops.update         = e1000_update_nvm_checksum_generic;
        nvm->ops.valid_led_default = e1000_valid_led_default_generic;
-       nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
-       nvm->ops.write          = e1000_write_nvm_microwire;
+       nvm->ops.validate       = e1000_validate_nvm_checksum_generic;
+       nvm->ops.write          = e1000_write_nvm_microwire;
 
        return E1000_SUCCESS;
 }
@@ -226,19 +226,18 @@ static s32 e1000_init_mac_params_82543(s
        mac->ops.setup_link = e1000_setup_link_82543;
        /* physical interface setup */
        mac->ops.setup_physical_interface =
-               (hw->phy.media_type == e1000_media_type_copper)
-                       ? e1000_setup_copper_link_82543
-                       : e1000_setup_fiber_link_82543;
+               (hw->phy.media_type == e1000_media_type_copper)
+                ? e1000_setup_copper_link_82543 : e1000_setup_fiber_link_82543;
        /* check for link */

*** DIFF OUTPUT TRUNCATED AT 1000 LINES ***
_______________________________________________
svn-src-stable-10@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-stable-10
To unsubscribe, send any mail to "svn-src-stable-10-unsubscr...@freebsd.org"

Reply via email to