summaryrefslogtreecommitdiff
path: root/sys/dev/pci
AgeCommit message (Collapse)Author
2016-07-26Fix byteswap errors in rtwn(4) and urtwn(4) introduced by me on June 17.Stefan Sperling
Repairs urtwn(4) on macppc. Problem reported by juanfra@. ok millert@ deraadt@
2016-07-21Make rtwn(4) and urtwn(4) respect the RTS threshold set by net80211.Stefan Sperling
ok mpi@
2016-07-20Disable the beacon filter in iwm(4). This allows beacons to pass through toStefan Sperling
the stack while associated, which in turn makes it possible to keep track of HT protection changes. ok mpi@
2016-07-20Make the iwn(4) LED flash 10 times slower in monitor mode.Stefan Sperling
Makes running monitor mode over extended periods of time much less annoying. ok benno@
2016-07-20Bring iwn_update_htprot() back, so iwn(4) will properly keep trackStefan Sperling
of HT protection changes while associated. HT protection affects behaviour on Tx but is configured along with Rx settings (because Intel likes it that way). And our previous iwn_update_htprot() implementation had a bug where it would accidentally clear bits which enable CCK rates for Rx. The Intel Wireless-N 2200 chip accordingly stopped receiving some frames (most notably broadcast frames) and the link broke down. Also, restore the power-saving level after updating the Rx config (like Linux does), and add some DELAYs for good measure to ensure the firmware has time to process asynchronous commands we send. tested by myself and mlarkin@ ok mlarkin@
2016-07-20ATI controllers seem to need the same workaround as VIA controllers.Martin Pieuchot
This should hopefully help people reporting errors with SB700. From FreeBSD, ok kettenis@, krw@
2016-07-19virtio_pci: Always allow MSI/MSI-XStefan Fritsch
For virtio devices, ignore the black/white-listing depending on the PCI bridge. This enables MSI-X with qemu's old "82441FX" pci-bridge. Suggested by kettenis@
2016-07-18Explicitly set iwm(4) firmware Tx aggregation limit to one (which disablesStefan Sperling
Tx aggregation), instead of the maximum (63 frames). Tx aggregation should already be disabled, so this change should be a no-op. It just avoids any side effects in case the firmware happens to interpret the limit we set here. ok mpi@
2016-07-18Fix inverted logic in iwm_tx(). The PROT_REQUIRE flag in should be set forStefan Sperling
data frames above a certain length, but we were setting it for !data frames above a certain length, which makes no sense at all. Found while comparing our driver's Tx code to iwlwifi. ok mpi@
2016-07-18Make iwm(4) retry Tx of management frames less often. We now retry managementStefan Sperling
frames the same number of times as Linux iwlwifi does.
2016-07-16Support MSI-X in virtioStefan Fritsch
This increases performance for interrupt heavy loads. While suspend/resume support for MSI-X is missing, this is also missing for virtio. So no new issue there. Currently, qemu's old "82441FX" pci-bridge is still blacklisted for MSI. But MSI-X is used if qemu is started with "-M q35".
2016-07-14vioblk: Properly handle poll timeoutStefan Fritsch
The only way to ensure that the device does not do DMA for the timed out request is a device reset. Also increase the timeout to 15s
2016-07-14rename virtio_ops.intr to poll_intrStefan Fritsch
This describes more accurately what it is good for. Also introduce a virtio_poll_intr macro.
2016-07-14virtio: Move interrupt handler into transport specific codeStefan Fritsch
For MSI-X (and also possibly for other transports), the interrupt handler must do different things. Move it out of virtio.c and into virtio_pci. ARM part tested by patrick@
2016-06-27Revert if_iwm.c r1.166. We are still seeing links dropping upon HT protectionStefan Sperling
updates with some iwn chips, such as the 2200. Reported by mlarkin and krw.
2016-06-22In iwm(4), clear the in_assoc flag when going down. This flag affects behaviourStefan Sperling
early during startup, e.g. where the BSSID for the MAC context is copied from. Pointed out by Imre Vadasz.
2016-06-22Remove code from iwm(4) which sends DTIM and TSF information to theStefan Sperling
firmware based on information from the wireless stack. Letting the firmware deal with these details by itself seems to work better. Fixes association issues with 8260 hardware for me and Bryan Vyhmeister. Also tested by jcs@.
2016-06-22Make iwm(4) explicitly send multicast frames at the lowest rate, instead ofStefan Sperling
picking a rate from the firmware RS table. This matches what other drivers do. Also, pass the correct Tx rate to BPF (tcpdump) for 5GHz, and don't loop over CCK rates when building the Link-Quality command's RS table for 5GHz. tested by myself and jcs@
2016-06-20In iwm(4), send PHY DB commands as async commands.Stefan Sperling
This means we won't sleep and wait for the firmware to send an interrupt when it's done processing the command. For unknown reasons, sometimes the firmware never wakes the driver after a phy db command so the driver gives up partway through the hardware init sequence. We already have a DELAY in place after each phy db command we send to give the firmware some time for processing, so skipping the sleep is not expected to cause problems. If it does, we'll have to revisit this change. For now, this change makes iwm(4) work better in bsd.rd. Problem reported by Remi Locherer on bugs@, and confirmed by kettenis@. Lots of help with testing and ok tb@
2016-06-19Make some noise in dmesg when iwm(4) fails to bring up the hardware.Stefan Sperling
ok tb@ earlier version
2016-06-18Plug some memory leaks in error paths of iwm(4).Stefan Sperling
Patch by Imre Vadasz.
2016-06-17Merge a lot of code from urtwn(4) into rtwn(4). Both drivers now share codeStefan Sperling
in the file sys/dev/ic/rtwn.c. This reduces kernel bloat and will make it easier to have both drivers benefit from future enhancements. ok mpi@
2016-06-05Continue preparing a future merge of urtwn(4) and rtwn(4).Stefan Sperling
This mostly copies r88e support code to ic/rtwn.c and moves some functions which are not trivial to merge with USB counterparts back to pci/if_rtwn.c. ok mpi@
2016-06-03Put iwn_update_htprot() back, with a fixed implementation this time.Stefan Sperling
I hope this will fix problems due to collisions and interference. tested by tb@ and Marcus MERIGHI ok tb@
2016-06-03In iwm(4), fix multicast Rx by updating the MAC context again afterStefan Sperling
sending multicast filter and STA settings during association. Makes ARP and inet6 autoconf work again. ok kettenis@
2016-06-02Fix two issues in the MSI-X code. First, actually read the MSI-X capabilityMark Kettenis
register. Second, correctly decode the table sizefromits contents. First issue pointed out by David Hill (with the help of clang). Second issue spotted after seeing a diff from Christiano Hasbaert.
2016-06-01Fix the loop iterating on extended capabilities. It turns out that weMartin Pieuchot
never did the handoff between the BIOS and the OS correctly. Should make xhci(4) usable on machines with xHCI BIOS support like most of the recent DELL. Tested by Hrvoje Popovski and David Hill. ok kettenis@, mikeb@
2016-06-01regenDavid Gwynne
2016-06-01intel use the same device id for multiple nvme parts, so just callDavid Gwynne
it NVMe. samsung do the same. pointed out by Evgeniy Sudyr who has a SSD 750 using the same id as the DC parts.
2016-05-30replace m_copym2 with m_dup_pkt.David Gwynne
ok mpi@
2016-05-28Add support for Intel Wireless 3165 devices to iwm(4).Stefan Sperling
Patch by Imre Vadasz.
2016-05-28In iwm(4), don't parse nvram antenna data for 7k devices, they don't have it.Stefan Sperling
And don't complain if no data is provided in nvram, needed for 3165 devices. Patch by Imre Vadasz.
2016-05-28Add support for Intel Wireless 8260 devices to iwm(4).Stefan Sperling
Firmware has been available in fw_update(1) for some time (thanks sthen!). Tested by robert, reyk, Imre Vadasz, Bryan Vyhmeister. Thank you, Emmanuel Grumbach, for helping me diagnose issues during development. ok kettenis
2016-05-25regenStefan Sperling
2016-05-25Add PCI ID for RTL8188EE. Prompted by Ross L Richardson.Stefan Sperling
2016-05-25Update iwm(4) to firmware API 16 and enable RTS/CTS frame protection.Stefan Sperling
Requires new firmware! Which has been available in fw_update(1) for some time. With helpful hints from Emmanuel Grumbach and contributions from Imre Vadasz. Tested verbatim by phessler@, jasper@, gilles@. Tested as part of a larger diff by reyk@, robert@, Imre Vadasz, and Bryan Vyhmeister. Earlier version tested by many. Also passed by kettenis@ very early on.
2016-05-24Add PCI_PRODUCT_INTEL_100SERIES_LP_THERM, suggested by kettenis@Reyk Floeter
2016-05-23regenChris Cappuccio
2016-05-23VIA VL805 xHCIChris Cappuccio
2016-05-23remove the function pointer from mbufs. this memory is shared with dataTed Unangst
via unions, and we don't want to make it easy to control the target. instead an integer index into an array of acceptable functions is used. drivers using custom functions must register them to receive an index. ok deraadt
2016-05-23regenDavid Gwynne
2016-05-23add the intel xl710 device ids from the documentationDavid Gwynne
i think some parts are called X710, not XL710, but i cant find where and why. defaulting to XL710 for now.
2016-05-21syncReyk Floeter
2016-05-21Add ids found in x1 carbon 2016:Reyk Floeter
- GMM (intel skylake general mixture model) - ISH (intel 100 series integrated sensor hub) - RTS525A (realtek card reader, not supported by rtsx(4))
2016-05-20regenMike Larkin
2016-05-20Add Xeon-D devices. Move one item that was out of order to the right placeMike Larkin
and fix a typo in an earlier E5 device ID.
2016-05-18Fix several nitpicks in iwm(4).Stefan Sperling
Move some declarations to if_iwmreg.h so we can use iwm_phy_db_* prototypes. Remove redundant declaration of iwm_send_phy_db_data(). Remove pointless iwm_fw_alive(); just call iwm_post_alive() directly. Simplify iwm_prepare_card_hw() and iwm_mvm_add_sta(). Return timeout error from iwm_apm_init(). Print a message when init (i.e. boot) firmware fails to load. Remove some commented-out code which wouldn't compile anyway. Move iwm_mvm_tx_fifo to if_iwmreg.h to match better where Linux puts it. ok kettenis@ mpi@
2016-05-18In iwm(4), add bit-polling in Rx-DMA init code path.Stefan Sperling
According to a comment in iwlwifi: * Clearing FH_MEM_RCSR_CHNL0_CONFIG_REG to 0 turns off Rx DMA. * Driver should poll FH_MEM_RSSR_RX_STATUS_REG for * FH_RSSR_CHNL0_RX_STATUS_CHNL_IDLE (bit 24) before continuing. ok kettenis@
2016-05-16enable reception and transmission of jumbo frames.David Gwynne
xge can go up to 9622 bytes in a frame. support for rx ring moderation is coming. from marisa emerson
2016-05-13Unbreak build when AUDIO_DEBUG is defined: fix printf(9) formatAlexandre Ratchov
mistakes.