1. 06 12月, 2015 22 次提交
  2. 05 12月, 2015 13 次提交
    • D
      Merge branch 'qmi_wwan_MDM9x30' · 2141eaf0
      David S. Miller 提交于
      Bjørn Mork says:
      
      ====================
      net: qmi_wwan: MDM9x30 support
      
      We add new device IDs all the time, often without any testing on
      actual hardware. This is usually OK as long as the device is similar
      to already supported devices, using the same chipset and firmware
      basis.  But the Sierra Wireless MC7455 is an example of a new chipset
      generation. Adding it based on assumed similarity with its ancestors
      proved too optimistic.
      
      This series adds the missing bits and pieces necessary to support LTE
      Advanced modems based on the Qualcomm MDM9x30 chipset. A big thanks to
      Sierra Wireless for providing MC7455 samples for testing
      
      The most important change is the "raw-ip" support. The series also
      adds a necessary control request, removes an unsupported device ID,
      and adds a driver specific entry in MAINTAINERS.
      
      A few random notes about "raw-ip":
      
      "I rather have these all running in raw IP mode. The 802.3 framing is
      utterly stupid." - Marcel Holtmann in Jan 2012 [1]
      
      Marcel was right.  I should have listened to him. What more can I say?
      
      The 802.3 framing has provided a steady supply of firmware bugs for
      many years. We've added driver workarounds for many of these, but
      there are still known bugs where the workaround is so yucky that we
      have refused to apply it. But all that is over now.  The latest
      generation Qualcomm chips no longer supports 802.3 framing at all.
      
      I had two open questions regarding the "raw-ip" userspace API:
      
      1) Should we continue faking an ethernet device, even if we don't use
         the L2 headers on the USB link anymore?
      
         There was a vote in favour of the "headerless" device. This is the
         honest representation of the hardware/firmware interface.
      
      2) What input should the driver base its framing on?
      
         Snooping or directly manipulating QMI is considered out of the
         question. We delegated all QMI handling to userspace from the
         beginning.
      
         We have so far required userspace to configure the firmware for
         "802.3" framing, or fail if that proved impossible.  This
         requirement is now changed.  Userspace must now inform the driver
         if it negotiates "raw-ip" framing.  Two alternative interfaces were
         proposed:
          - ethtool private driver flag, or
          - sysfs file
      
         The NetworkManager/ModemManager developers were in favour of the
         sysfs alternative.
      
      These questions (or any other you migh have :) are of course still
      open.  This patch set presents the solutions I currently prefer,
      considering the above.
      
      All comments are appreciated, even simple '+1' ones.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      2141eaf0
    • B
      MAINTAINERS: add qmi_wwan driver entry · 4521b477
      Bjørn Mork 提交于
      Signed-off-by: NBjørn Mork <bjorn@mork.no>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      4521b477
    • B
      net: qmi_wwan: document the qmi/raw_ip sysfs file · 40dd0d94
      Bjørn Mork 提交于
      Signed-off-by: NBjørn Mork <bjorn@mork.no>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      40dd0d94
    • B
      net: qmi_wwan: support "raw IP" mode · 32f7adf6
      Bjørn Mork 提交于
      QMI wwan devices have traditionally emulated ethernet devices
      by default. But they have always had the capability of operating
      without any L2 header at all, transmitting and receiving "raw"
      IP packets over the USB link.  This firmware feature used to be
      configurable through the QMI management protocol.
      
      Traditionally there was no way to verify the firmware mode
      without attempting to change it.  And the firmware would often
      disallow changes anyway, i.e. due to a session already being
      established.  In some cases, this could be a hidden firmware
      internal session, completely outside host control.  For these
      reasons, sticking with the "well known" default mode was safest.
      
      But newer generations of QMI hardware and firmware have moved
      towards defaulting to "raw IP" mode instead, followed by an
      increasing number of bugs in the already buggy "802.3" firmware
      implementation. At the same time, the QMI management protocol
      gained the ability to detect the current mode.  This has enabled
      the userspace QMI management application to verify the current
      firmware mode without trying to modify it.
      
      Following this development, the latest QMI hardware and firmware
      (the MDM9x30 generation) has dropped support for "802.3" mode
      entirely. Support for "raw IP" framing in the driver is therefore
      necessary for these devices, and to a certain degree to work
      around problems with the previous generation,
      
      This patch adds support for "raw IP" framing for QMI devices,
      changing the netdev from an ethernet device to an ARPHRD_NONE
      p-t-p device when "raw IP" framing is enabled.
      
      The firmware setup is fully delegated to the QMI userspace
      management application, through simple tunneling of the QMI
      protocol. The driver will therefore not know which mode has been
      "negotiated" between firmware and userspace. Allowing userspace
      to inform the driver of the result through a sysfs switch is
      considered a better alternative than to change the well established
      clean delegation of firmware management to userspace.
      Signed-off-by: NBjørn Mork <bjorn@mork.no>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      32f7adf6
    • B
      usbnet: allow mini-drivers to consume L2 headers · 81e0ce79
      Bjørn Mork 提交于
      Assume the minidriver has taken care of all L2 header parsing
      if it sets skb->protocol.  This allows the minidriver to
      support non-ethernet L2 headers, and even operate without
      any L2 header at all.
      Signed-off-by: NBjørn Mork <bjorn@mork.no>
      Acked-by: NOliver Neukum <oneukum@suse.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      81e0ce79
    • B
      net: qmi_wwan: remove 1199:9070 device id · 544c8f65
      Bjørn Mork 提交于
      This turned out to be a bootloader device ID.  No need for
      that in this driver.  It will only provide a single serial
      function.
      Signed-off-by: NBjørn Mork <bjorn@mork.no>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      544c8f65
    • B
      net: qmi_wwan: MDM9x30 specific power management · 93725149
      Bjørn Mork 提交于
      MDM9x30 based modems appear to go into a deeper sleep when
      suspended without "Remote Wakeup" enabled.  The QMI interface
      will not respond unless a "set DTR" control request is sent
      on resume. The effect is similar to a QMI_CTL SYNC request,
      resetting (some of) the firmware state.
      
      We allow userspace sessions to span multiple character device
      open/close sequences.  This means that userspace can depend
      on firmware state while both the netdev and the character
      device are closed.  We have disabled "needs_remote_wakeup" at
      this point to allow devices without remote wakeup support to
      be auto-suspended.
      
      To make sure the MDM9x30 keeps firmware state, we need to
      keep "needs_remote_wakeup" always set. We also need to
      issue a "set DTR" request to enable the QMI interface.
      Signed-off-by: NBjørn Mork <bjorn@mork.no>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      93725149
    • D
      Merge branch 'hip06-soc' · 43dd7a8b
      David S. Miller 提交于
      Salil Mehta says:
      
      ====================
      net:hns: Add support of Hip06 SoC to the Hislicon Network Subsystem
      
      This PATCH V7 addresses the TAB formatting comments by
      Sergei Shtylyov. Missing TABs at some other palces have
      also been corrected.
      
      PATCH V6:
      This addresses the review comments provided by
      David Miller over the existing use of ENABLE/DISABLE
      hash defines with the code. These hash defines are doing
      a similar job as implicit type bool would do. So these are
      kind of duplicate and are redundant.
      
      PATCH V5:
      This PATCH addresses the review comments by Yuval Mintz
       <Yuval.Mintz@qlogic.com>. This rework of comments are basically
       related to:
       1) styling of the code,
       2) RSS default Key initiailization related code
       3) redundant code removal
      
      PATCH V4:
      This addresses the review comment provided by
      Sergei Shtylyov. The changelog of every patch has also
      been modified.
      
      PATCH V3:
       Addresses the review comment floated by David Miller
      
      PATCH V2:
      1) Bug Fixes and Clean-up: Internally identified
      2) Addresses internal review comments by Kenneth Lee and
         by Huang Daode
      3) Addresses the review comment from "Yisen.Zhuang(Zhuangyuzeng)"
      4) Adds fix from Fengguang Wu for an error generated from
         "kbuild test robot" from Intel
      5) Ethtool support for TSO set option from Lisheng
      
      PATCH V1:
      Adds initial support of Hip06 SoC with below changes:
      This patch-set adds support of new Hisilicon Hip06 SoC to the existing
      (already part of net-next) HNS ethernet driver for Hip05 SoC. Hip06 is
      a multi-core SoC and is a derivative of Hip05 SoC with lots of new
      hardware featres supported like RSS, TSO, hardware VLAN assist etc.
      
      The changes in the driver are mainly due to following:
       1) changes in the DMA descriptor provided by the Hip06 ethernet
          hardware. These changes need to co-exist with already present
          Hip05 DMA descriptor and its operating functions. The decision
          to choose the correct type of DMA descriptor is taken dynamically
          depending upon the version of the hardware (i.e. V1/hip05 or
          V2/hip06, see already existing hisilicon-hns-nic.txt binding file
          for the detailed description version and naming).
       2) To support new features added to the Hip06 ethernet hardware:
          a. RSS (Receive Side Scaling)
          b. TSO (TCP Segment Offload)
          c. Hardware VLAN support (currently we are initializing hardware
             to not assist in stripping the vlan tag at hardware level.
             Proper support of this feature and ethtool would come after
             these patches have been accepted)
      
      Kindly note that, this patchset has been based on latest net-next.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      43dd7a8b
    • S
      net:hns: Add the init code to disable Hip06 "Hardware VLAN assist" · 8044f97e
      Salil 提交于
      This patch adds the initializzation code to disable the hardware
      vlan support for VLAN Tag stripping by default for now.
      
      Proper support of "hardware VLAN assitance" feature would
      soon come in the next coming patches.
      Signed-off-by: NSalil Mehta <salil.mehta@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      8044f97e
    • S
      net:hns: Add support of ethtool TSO set option for Hip06 in HNS · 38f616da
      Salil 提交于
      This patch adds the support of ethtool TSO option to support
      Hip06 SoC to HNS
      Signed-off-by: NSalil Mehta <salil.mehta@huawei.com>
      Signed-off-by: Nlisheng <lisheng011@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      38f616da
    • S
      net:hns: Add Hip06 "TSO(TCP Segment Offload)" support HNS Driver · 64353af6
      Salil 提交于
      This patch adds the support of "TSO (TCP Segment Offload)" feature
      provided by the Hip06 ethernet hardware to the HNS ethernet
      driver.
      
      Enabling this feature would help offload the TCP Segmentation
      process to the Hip06 ethernet hardware. This eventually would help
      in saving precious cpu cycles.
      Signed-off-by: NSalil Mehta <salil.mehta@huawei.com>
      Signed-off-by: Nlisheng <lisheng011@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      64353af6
    • S
      net:hns: Add Hip06 "RSS(Receive Side Scaling)" support to HNS Driver · 6bc0ce7d
      Salil 提交于
      This patch adds the support of "RSS (Receive Side Scaling)" feature
      provided by the Hip06 ethernet hardware to the HNS ethernet
      driver.
      
      This feature helps in distributing the different flows (mapped as
      hash by hardware using Toeplitz Hash) to different Queues asssociated
      with the processor cores. The mapping of flow-hash values to the
      different queues is stored in indirection table (which is per Packet-
      parse-Engine/PPE). This patch also provides the changes to re-program
      the (flow-hash<->Qid) mapping using the ethtool.
      Signed-off-by: NSalil Mehta <salil.mehta@huawei.com>
      Reviewed-by: NKenneth Lee <liguozhu@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      6bc0ce7d
    • S
      net:hns: Add support of Hip06 SoC to the Hislicon Network Subsystem · 13ac695e
      Salil 提交于
      This patchset adds support of Hisilicon Hip06 SoC to the existing HNS
      ethernet driver.
      
      The changes in the driver are mainly due to changes in the DMA
      descriptor provided by the Hip06 ethernet hardware. These changes
      need to co-exist with already present Hip05 DMA descriptor and its
      operating functions. The decision to choose the correct type of DMA
      descriptor is taken dynamically depending upon the version of the
      hardware (i.e. V1/hip05 or V2/hip06, see already existing
      hisilicon-hns-nic.txt binding file for detailed description). other
      changes includes in SBM, DSAF and PPE modules as well. Changes
      affecting the driver related to the newly added ethernet hardware
      features in Hip06 would be added as separate patch over this and
      subsequent patches.
      Signed-off-by: NSalil Mehta <salil.mehta@huawei.com>
      Signed-off-by: Nyankejian <yankejian@huawei.com>
      Signed-off-by: Nhuangdaode <huangdaode@hisilicon.com>
      Signed-off-by: Nlipeng <lipeng321@huawei.com>
      Signed-off-by: Nlisheng <lisheng011@huawei.com>
      Signed-off-by: NFengguang Wu <fengguang.wu@intel.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      13ac695e
  3. 04 12月, 2015 5 次提交
    • Y
      net: bonding: remove redudant brackets · ce3ea1c7
      yzhu1 提交于
      It is not necessary to use two brackets. As such, the redudant brackets
      are removed.
      
      CC: Jay Vosburgh <j.vosburgh@gmail.com>
      CC: Veaceslav Falico <vfalico@gmail.com>
      CC: Andy Gospodarek <gospo@cumulusnetworks.com>
      Signed-off-by: NZhu Yanjun <yanjun.zhu@windriver.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      ce3ea1c7
    • D
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net · f188b951
      David S. Miller 提交于
      Conflicts:
      	drivers/net/ethernet/renesas/ravb_main.c
      	kernel/bpf/syscall.c
      	net/ipv4/ipmr.c
      
      All three conflicts were cases of overlapping changes.
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      f188b951
    • L
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net · 071f5d10
      Linus Torvalds 提交于
      Pull networking fixes from David Miller:
       "A lot of Thanksgiving turkey leftovers accumulated, here goes:
      
         1) Fix bluetooth l2cap_chan object leak, from Johan Hedberg.
      
         2) IDs for some new iwlwifi chips, from Oren Givon.
      
         3) Fix rtlwifi lockups on boot, from Larry Finger.
      
         4) Fix memory leak in fm10k, from Stephen Hemminger.
      
         5) We have a route leak in the ipv6 tunnel infrastructure, fix from
            Paolo Abeni.
      
         6) Fix buffer pointer handling in arm64 bpf JIT,f rom Zi Shen Lim.
      
         7) Wrong lockdep annotations in tcp md5 support, fix from Eric
            Dumazet.
      
         8) Work around some middle boxes which prevent proper handling of TCP
            Fast Open, from Yuchung Cheng.
      
         9) TCP repair can do huge kmalloc() requests, build paged SKBs
            instead.  From Eric Dumazet.
      
        10) Fix msg_controllen overflow in scm_detach_fds, from Daniel
            Borkmann.
      
        11) Fix device leaks on ipmr table destruction in ipv4 and ipv6, from
            Nikolay Aleksandrov.
      
        12) Fix use after free in epoll with AF_UNIX sockets, from Rainer
            Weikusat.
      
        13) Fix double free in VRF code, from Nikolay Aleksandrov.
      
        14) Fix skb leaks on socket receive queue in tipc, from Ying Xue.
      
        15) Fix ifup/ifdown crach in xgene driver, from Iyappan Subramanian.
      
        16) Fix clearing of persistent array maps in bpf, from Daniel
            Borkmann.
      
        17) In TCP, for the cross-SYN case, we don't initialize tp->copied_seq
            early enough.  From Eric Dumazet.
      
        18) Fix out of bounds accesses in bpf array implementation when
            updating elements, from Daniel Borkmann.
      
        19) Fill gaps in RCU protection of np->opt in ipv6 stack, from Eric
            Dumazet.
      
        20) When dumping proxy neigh entries, we have to accomodate NULL
            device pointers properly, from Konstantin Khlebnikov.
      
        21) SCTP doesn't release all ipv6 socket resources properly, fix from
            Eric Dumazet.
      
        22) Prevent underflows of sch->q.qlen for multiqueue packet
            schedulers, also from Eric Dumazet.
      
        23) Fix MAC and unicast list handling in bnxt_en driver, from Jeffrey
            Huang and Michael Chan.
      
        24) Don't actively scan radar channels, from Antonio Quartulli"
      
      * git://git.kernel.org/pub/scm/linux/kernel/git/davem/net: (110 commits)
        net: phy: reset only targeted phy
        bnxt_en: Setup uc_list mac filters after resetting the chip.
        bnxt_en: enforce proper storing of MAC address
        bnxt_en: Fixed incorrect implementation of ndo_set_mac_address
        net: lpc_eth: remove irq > NR_IRQS check from probe()
        net_sched: fix qdisc_tree_decrease_qlen() races
        openvswitch: fix hangup on vxlan/gre/geneve device deletion
        ipv4: igmp: Allow removing groups from a removed interface
        ipv6: sctp: implement sctp_v6_destroy_sock()
        arm64: bpf: add 'store immediate' instruction
        ipv6: kill sk_dst_lock
        ipv6: sctp: add rcu protection around np->opt
        net/neighbour: fix crash at dumping device-agnostic proxy entries
        sctp: use GFP_USER for user-controlled kmalloc
        sctp: convert sack_needed and sack_generation to bits
        ipv6: add complete rcu protection around np->opt
        bpf: fix allocation warnings in bpf maps and integer overflow
        mvebu: dts: enable IP checksum with jumbo frames for Armada 38x on Port0
        net: mvneta: enable setting custom TX IP checksum limit
        net: mvneta: fix error path for building skb
        ...
      071f5d10
    • L
      Merge branch 'for-linus' of git://git.kernel.dk/linux-block · 2873d32f
      Linus Torvalds 提交于
      Pull block fixes from Jens Axboe:
       "A collection of fixes from this series.  The most important here is a
        regression fix for an issue that some folks would hit in blk-merge.c,
        and the NVMe queue depth limit for the screwed up Apple "nvme"
        controller.
      
        In more detail, this pull request contains:
      
         - a set of fixes for null_blk, including a fix for a few corner cases
           where we could hang the device.  From Arianna and Paolo.
      
         - lightnvm:
              - A build improvement from Keith.
              - Update the qemu pci id detection from Matias.
              - Error handling fixes for leaks and other little fixes from
                Sudip and Wenwei.
      
         - fix from Eric where BLKRRPART would not return EBUSY for whole
           device mounts, only when partitions were mounted.
      
         - fix from Jan Kara, where EOF O_DIRECT reads would return
           negatively.
      
         - remove check for rq_mergeable() when checking limits for cloned
           requests.  The check doesn't make any sense.  It's assuming that
           since NOMERGE is set on the request that we don't have to
           recalculate limits since the request didn't change, but that's not
           true if the request has been redirected.  From Hannes.
      
         - correctly get the bio front segment value set for single segment
           bio's, fixing a BUG() in blk-merge.  From Ming"
      
      * 'for-linus' of git://git.kernel.dk/linux-block:
        nvme: temporary fix for Apple controller reset
        null_blk: change type of completion_nsec to unsigned long
        null_blk: guarantee device restart in all irq modes
        null_blk: set a separate timer for each command
        blk-merge: fix computing bio->bi_seg_front_size in case of single segment
        direct-io: Fix negative return from dio read beyond eof
        block: Always check queue limits for cloned requests
        lightnvm: missing nvm_lock acquire
        lightnvm: unconverted ppa returned in get_bb_tbl
        lightnvm: refactor and change vendor id for qemu
        lightnvm: do device max sectors boundary check first
        lightnvm: fix ioctl memory leaks
        lightnvm: free memory when gennvm register fails
        lightnvm: Simplify config when disabled
        Return EBUSY from BLKRRPART for mounted whole-dev fs
      2873d32f
    • L
      Merge tag 'trace-v4.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace · c041f087
      Linus Torvalds 提交于
      Pull tracing fix from Steven Rostedt:
       "During the merge window I added a new file that is used to filter
        trace events on pids.  It filters all events where only tasks with
        their pid in that file exists.  It also handles the sched_switch and
        sched_wakeup trace events where the current task does not have its pid
        in the file, but the task either being switched to or awaken does.
      
        Unfortunately, I forgot about sched_wakeup_new and sched_waking.  Both
        of these tracepoints use the same class as the sched_wakeup
        tracepoint, and they too should be included in what gets filtered by
        the set_event_pid file"
      
      * tag 'trace-v4.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace:
        tracing: Add sched_wakeup_new and sched_waking tracepoints for pid filter
      c041f087