1. 03 11月, 2017 17 次提交
  2. 18 10月, 2017 9 次提交
  3. 06 10月, 2017 14 次提交
    • L
      iwlwifi: remove dflt_pwr_limit from the transport · f2abcfa6
      Luca Coelho 提交于
      The default power limit read from the SPLC method in ACPI doesn't
      have anything to do with the transport and is only used in the opmode,
      so we can remove it from the trans.  Additionally, this value is only
      user when the opmode is starting, so we don't need to store it
      anywhere.
      
      Remove the dflt_pwr_limit element from the trans and move call to
      iwl_acpi_get_pwr_limit() call to mvm.
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      f2abcfa6
    • J
      iwlwifi: mvm: warn on invalid statistics size · 42fa5e0e
      Johannes Berg 提交于
      Getting the wrong statistics size is a problem, having a warning
      will help us catch it quicker during firmware/driver development.
      In released firmware/driver versions, we obviously make sure this
      won't happen.
      Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      42fa5e0e
    • L
      iwlwifi: acpi: move code that reads SPLC to acpi · 1184611e
      Luca Coelho 提交于
      Move most of the set_dflt_pwr_limit() function to acpi.c and make it
      return the pwr_limit value instead of setting directly.  Also rename
      it to iwl_acpi_get_pwr_limit().
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      1184611e
    • J
      iwlwifi: fix indentation in a000 family configuration · e59a00f4
      Johannes Berg 提交于
      Fix the double indentation in the configuration structs
      for a000 family devices.
      Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      e59a00f4
    • L
      iwlwifi: acpi: move function to get mcc into acpi code · 45f65569
      Luca Coelho 提交于
      The iwl_get_bios_mcc() function was in the iwl-nvm-parse.c file, but
      it has nothing to do with the NVM.  Move it to fw/acpi.c and rename it
      to iwl_acpi_get_mcc().
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      45f65569
    • L
      iwlwifi: acpi: remove a couple of unnecessary ifdefs · d953cdb8
      Luca Coelho 提交于
      Some of the #ifdef CONFIG_ACPI are not needed anymore, so they can be
      removed.
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      d953cdb8
    • L
      iwlwifi: acpi: make iwl_get_bios_mcc() use the common acpi functions · ed1a962d
      Luca Coelho 提交于
      The way iwl_get_bios_mcc() gets the WiFi package and checks for its
      integrity is almost identical to the new iwl_acpi_get_wifi_pkg()
      function.  Instead of having duplicate code, convert it to use the
      common code.
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      ed1a962d
    • L
      iwlwifi: acpi: use iwl_acpi_get_wifi_pkg when reading reading SPLC · 45a5c6f6
      Luca Coelho 提交于
      Instead of finding the wifi package with its own code, we can reuse
      the new iwl_acpi_get_wifi_pkg() function when reading the default
      power limit from SPLC.
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      45a5c6f6
    • L
      iwlwifi: acpi: generalize iwl_mvm_sar_find_wifi_pkg() · 2fa388cf
      Luca Coelho 提交于
      Move this function to acpi.c, renaming it to iwl_acpi_get_wifi_pkg(),
      because it can also be used with other methods (i.e. SPLC and WRDD).
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      2fa388cf
    • L
      iwlwifi: acpi: move ACPI-related definitions to acpi.h · e7a3b8d8
      Luca Coelho 提交于
      The ACPI table size definitions were spread around the different files
      that used them.  Move them all to a common place.
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      e7a3b8d8
    • L
      iwlwifi: acpi: move ACPI method definitions to acpi.h · 1c73acf5
      Luca Coelho 提交于
      Instead of defining each method where they are used and re-defining
      WIFI_DOMAIN in each one of them, move all the definitions to a central
      place and define the domain only a single time.
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      1c73acf5
    • L
      iwlwifi: acpi: add common code to read from ACPI · 813df5ce
      Luca Coelho 提交于
      There are many places where the same process of invoking a method from
      ACPI is used, causing a lot of duplicate code.  To improve this,
      introduce a new function to get an ACPI object by invoking an ACPI
      method that can be reused.
      
      Additionally, since this function needs to be called when we only have
      the trans, the opmode or the device, introduce a new debug macro that
      gets the device as a parameter so it can be used in the new function.
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      813df5ce
    • S
      iwlwifi: mvm: change warning to warn_once() · 417795a3
      Sara Sharon 提交于
      In case there is a FW bug where the BAID value in the
      metadata is not properly initialized we hit the warning for
      every RX packet.
      Change it to warn once and add elaborate message.
      Signed-off-by: NSara Sharon <sara.sharon@intel.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      417795a3
    • R
      iwlwifi: pcie: dump registers when HW becomes inaccessible · a6d24fad
      Rajat Jain 提交于
      We conclude the HW became inaccessible when we timeout waiting for
      a bit to be set in a memory mapped register (CSR_GP_CNTRL). This
      conclusion may not be true because the bit may not get set due to:
      - a firmware issue
      - a driver issue
      - a PCI bus issue
      - a platform issue
      There are a lot of such reports with really no good debug information
      beyond this message to help us.
      
      Add some debug information and attempt to dump the different register
      spaces at such a failure:
      
      * Dump some configuration space of device - this will tell us if
      something very basic is broken in the PCIe bus (so that configuration
      accesses are failing). If this works, the PCIe bus seems OK. If this
      does not work, it is definitely an PCIe issue.
      
      * Dump some memory mapped registers - if we're reading some sane'ish
      values, this will tell us that the PCIe bus is OK, but may be a firmware
      / driver issue. If this does not work, it may be a PCI configuration
      issue or a driver/firmware issue.
      
      * Dump parent and device's AER registers, will give us some straws to
      chew on.
      
      This is the sample output:
      [   13.082651] ------------[ cut here ]------------
      [   13.086791] iwlwifi 0000:01:00.0: iwlwifi transaction failed, dumping registers
      [   13.086793] iwlwifi 0000:01:00.0: iwlwifi device config registers:
      [   13.086893] iwlwifi 0000:01:00.0: 00000000: 095a8086 00100406 02800059 00000000 00000004 00000000 00000000 00000000
      [   13.086895] iwlwifi 0000:01:00.0: 00000020: 00000000 00000000 00000000 50108086 00000000 000000c8 00000000 00000100
      [   13.086901] iwlwifi 0000:01:00.0: iwlwifi device memory mapped registers:
      [   13.086989] iwlwifi 0000:01:00.0: 00000000: ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff
      [   13.086991] iwlwifi 0000:01:00.0: 00000020: ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff
      [   13.086999] iwlwifi 0000:01:00.0: iwlwifi device AER capability structure:
      [   13.087033] iwlwifi 0000:01:00.0: 00000000: 14010001 00100000 00000000 00462031 00002000 00002000 00000014 40000001
      [   13.087034] iwlwifi 0000:01:00.0: 00000020: 0000000f d140000c 00000000
      [   13.087036] iwlwifi 0000:01:00.0: iwlwifi parent port (0000:00:1c.0) config registers:
      [   13.087074] iwlwifi 0000:00:1c.0: 00000000: 9d108086 00100506 060400f1 00810010 00000000 00000000 00010100 200000f0
      [   13.087075] iwlwifi 0000:00:1c.0: 00000020: d140d140 0001fff1 00000000 00000000 00000000 00000040 00000000 0006010b
      [   13.087087] ------------[ cut here ]------------
      [   13.087095] WARNING: CPU: 0 PID: 1759 at drivers/net/wireless/iwl7000/iwlwifi/pcie/trans.c:2082 iwl_trans_pcie_reclaim+0x1ee4/0x2b9a [iwlwifi]()
      [   13.087096] Timeout waiting for hardware access (CSR_GP_CNTRL 0xffffffff)
      Signed-off-by: NRajat Jain <rajatja@google.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      a6d24fad