1. 28 3月, 2019 21 次提交
    • K
      fou: Support binding FoU socket · 1713cb37
      Kristian Evensen 提交于
      An FoU socket is currently bound to the wildcard-address. While this
      works fine, there are several use-cases where the use of the
      wildcard-address is not desirable. For example, I use FoU on some
      multi-homed servers and would like to use FoU on only one of the
      interfaces.
      
      This commit adds support for binding FoU sockets to a given source
      address/interface, as well as connecting the socket to a given
      destination address/port. udp_tunnel already provides the required
      infrastructure, so most of the code added is for exposing and setting
      the different attributes (local address, peer address, etc.).
      
      The lookups performed when we add, delete or get an FoU-socket has also
      been updated to compare all the attributes a user can set. Since the
      comparison now involves several elements, I have added a separate
      comparison-function instead of open-coding.
      
      In order to test the code and ensure that the new comparison code works
      correctly, I started by creating a wildcard socket bound to port 1234 on
      my machine. I then tried to create a non-wildcarded socket bound to the
      same port, as well as fetching and deleting the socket (including source
      address, peer address or interface index in the netlink request).  Both
      the create, fetch and delete request failed. Deleting/fetching the
      socket was only successful when my netlink request attributes matched
      those used to create the socket.
      
      I then repeated the tests, but with a socket bound to a local ip
      address, a socket bound to a local address + interface, and a bound
      socket that was also «connected» to a peer. Add only worked when no
      socket with the matching source address/interface (or wildcard) existed,
      while fetch/delete was only successful when all attributes matched.
      
      In addition to testing that the new code work, I also checked that the
      current behavior is kept. If none of the new attributes are provided,
      then an FoU-socket is configured as before (i.e., wildcarded).  If any
      of the new attributes are provided, the FoU-socket is configured as
      expected.
      
      v1->v2:
      * Fixed building with IPv6 disabled (kbuild).
      * Fixed a return type warning and make the ugly comparison function more
      readable (kbuild).
      * Describe more in detail what has been tested (thanks David Miller).
      * Make peer port required if peer address is specified.
      Signed-off-by: NKristian Evensen <kristian.evensen@gmail.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      1713cb37
    • D
      Merge branch '100GbE' of git://git.kernel.org/pub/scm/linux/kernel/git/jkirsher/next-queue · eec7e295
      David S. Miller 提交于
      Jeff Kirsher says:
      
      ====================
      100GbE Intel Wired LAN Driver Updates 2019-03-26
      
      This series contains more updates to the ice driver only.
      
      Jeremiah provides his first patch to the Linux kernel to clean up
      un-necessary newlines in driver log messages.
      
      Mitch updates the ice driver to use existing status codes in the iavf
      driver so that when errors occur, it will not report nonsensical
      results.  Adds support for VF admin queue interrupts by programming the
      VPINT_MBX_CTL register array.
      
      Brett adds a check for a bit that we set while preparing for a reset, to
      ensure we are prepared to do a proper reset.  Also implemented PCI error
      handling operations.  Went through and audited the hot path with pahole
      and made modifications based on the results since 2 structures were
      taking up more space than necessary due to cache alignment issues.
      Fixed an issue where when flow control was disabled, the state of flow
      control was being displayed as "Unknown".
      
      Anirudh fixes adaptive interrupt moderation changes by adding code that
      was missed, that should have been added in the initial patch to add that
      support.  Cleaned up a function prototype that was never implemented.
      Did additional code cleanup by removing unneeded braces and redundant
      code comments.
      
      Akeem fixes an issue that occurs when the VF is attempting to remove the
      default LAN/MAC address, which is programmed by the administrator by
      updating the error message to explicitly say that the VF cannot change
      the MAC programmed by the PF.
      
      Preethi fixes the driver to not fall into the error path when a added
      filter already exists, but instead continue to process the rest of the
      function and add appropriate checks after adding MAC filters.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      eec7e295
    • D
      Merge branch 'net-mvpp2-Classifier-updates-and-cleanups' · b0be25c5
      David S. Miller 提交于
      Maxime Chevallier says:
      
      ====================
      net: mvpp2: Classifier updates and cleanups
      
      In preparation for the future addition of classification offload
      support, this series cleans-up the current code dealing with the
      classification engines.
      
      As of today, the classification code only deals with RSS, which is a
      very narrow use-case when considering all of the classifier's features.
      
      This lead to design and naming decisions that don't really stand when
      considering using more classification features.
      
      This series therefore includes quite a lot a renaming of functions and
      macros, and tries to make the naming schemes more consistent and the
      code more readable.
      
      The debugfs interface that allows reading the various Parsing and
      Classification engines has been cleaned-up and made more generic,
      allowing to read the Flow Table and C2 engine hit counters on a
      per-entry basis.
      
      The Classifier itself has been made more robust by introducing the
      lu_type field in classification lookups, that prevents false-positive
      matches in the future. We also initialise the various engine in a more
      extensive and less error-prone way by assining default values to all
      entries in the C2 and Flow table.
      
      This is a pretty big series considering it's mostly cleanup, but my goal
      is to make the future series that will contain new big features easier
      to review, focusing on the real logic.
      
      Besides the debugfs interface, this series doesn't intend to introduce any
      new features or change in behaviours.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      b0be25c5
    • M
      net: mvpp2: cls: Rework C2 engine macros · c2d3d8ee
      Maxime Chevallier 提交于
      The C2 classification engine has a 256 entry TCAM, used for ternary
      matches on an 8 byte Header Extracted Key. For now, we compute the
      various indices for classification and RSS that use this engine thanks
      to a set of macros.
      
      This commit mainly renames the macros used to make it clear that they
      should be used with the C2 engine, but also make use of the full 256
      entries in the engine. For now, the C2 entries are only used for RSS.
      
      These entries are put at the end of the TCAM range, in case we want to
      add higher priority matches later on.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      c2d3d8ee
    • M
      net: mvpp2: cls: Initialize lookup priorities for all entries in the flow · 693131db
      Maxime Chevallier 提交于
      When classifying a packet pertaining to a given flow, the classifier
      will issue multiple lookup commands until it finds one with the 'last'
      bit set. It expects all prorities to be assign continuously (although
      not necessarily in an ordered fashion) from 0 to the number of lookups.
      
      We can initialize this once, and make sure unused lookups are given an
      empty port map. This avoids having to maintain priorities and the
      information of which lookup is the last.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      693131db
    • M
      net: mvpp2: cls: Invalidate all C2 entries except the ones we use · 8d2847d9
      Maxime Chevallier 提交于
      C2 TCAM entries can be invalidated to avoid unwanted matches. Make sure
      all entries are invalidated at init, then validate only the ones we use.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      8d2847d9
    • M
      net: mvpp2: cls: Rename the flow table macros · ff2f3cb6
      Maxime Chevallier 提交于
      The Flow Table dictates what lookups will be issued for each flow type.
      The lookup sequence for each flow is similar, and the index of each
      lookup is computed by some macros.
      
      There are similar mechanisms for the C2 TCAM lookups, so in order to
      avoid confusion, rename the flow table index computing macros with a
      common prefix.
      
      The only difference in behaviour is that we now use the very first entry
      in the flow for the RSS lookup (the first entry was previously unused).
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      ff2f3cb6
    • M
      net: mvpp2: cls: Don't use the sequence attribute for classification · 5b353806
      Maxime Chevallier 提交于
      The classifier allows to combine multiple lookups in one "sequence" that
      is counted as a single lookup to an engine, with a single result.
      
      We don't actually use that feature, so remove any places where we set
      this field, so that the classifier doesn't try to interpret these
      fields.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      5b353806
    • M
      net: mvpp2: cls: Rename classifer per-port functions · 6310f77d
      Maxime Chevallier 提交于
      This commit renames some of the classifier functions to follow the
      naming 'mvpp2_port_*' that's used for function that act on a given port.
      
      This commit is purely cosmetic.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      6310f77d
    • M
      net: mvpp2: cls: Move C2 read/write helpers around · b11ffdc5
      Maxime Chevallier 提交于
      Move C2 read/write helpers higher in the file to ease future work that
      rely on these helpers
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      b11ffdc5
    • M
      net: mvpp2: cls: Write C2 TCAM data last when writing a C2 entry · 147c538e
      Maxime Chevallier 提交于
      When writing a C2 entry to hardware, some registers writes will only
      take effect when the TCAM_DATA4 register is written. This includes all
      C2 TCAM registers, and the C2 invalidate register.
      
      To make sure we always write C2 entries correctly, document that
      behaviour with a comment, and move TCAM writes to the end of the
      mvpp2_cls_c2_write helper.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      147c538e
    • M
      net: mvpp2: cls: Use iterators to go through the cls_table · e4bfb4ac
      Maxime Chevallier 提交于
      The cls_table is a global read-only table containing the different
      parameters that are used by various tables in the classifier. It
      describes the links between the Header Parser, the decoding table and
      the flow_table.
      
      There are several possible way we want to iterate over that table,
      depending on wich classifier engine we want to configure. For the Header
      Parser, we want to iterate over each entry. For the Decoding table, we
      want to iterate over each entry having a unique flow_id. Finally, when
      configuring an ethtool flow, we want to iterate over each entry having a
      unique flow_id and that has a given flow_type.
      
      This commit introduces some iterator to both provide syntactic sugar and
      also clarify the way we want to iterate over the table.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      e4bfb4ac
    • M
      net: mvpp2: debugfs: Allow reading the C2 engine table from debugfs · b607cc61
      Maxime Chevallier 提交于
      PPv2's Classifier uses multiple engines to perform classification. So
      far, only the C2 engine is used, which has a 256 entries TCAM.
      
      So far, we only accessed the relevant entries from the C2 engines, which
      are the one implementing RSS. To implement and debug ntuple
      classification offload, beaing able to see the hit count for each C2
      entry is helpful, so this commit moves the logic to a dedicated
      directory allowing to access each entry.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      b607cc61
    • M
      net: mvpp2: debugfs: Allow reading the flow table from debugfs · 8aa65106
      Maxime Chevallier 提交于
      The Classifier flow table is the central part of the PPv2 Classifier,
      since it describes all classification steps performed for each flow.
      
      It has 512 entries, shared between all ports, which are divided into
      sequences that are pointed-to by the decoding table. Being able to see
      which entries in the flow table were hit is a key point when
      implementing and debugging classification offload.
      
      This commit allows reading each flow table entry's hit count
      independently, with a clear-on-read behaviour.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      8aa65106
    • M
      net: mvpp2: debugfs: Store debugfs entries data in mvpp2 struct · 7cb5e368
      Maxime Chevallier 提交于
      The current way to store the required private data needed to access
      various debugfs entries is to alloc them on the fly, share them within
      the entries that need to access them, and finally have one entry free
      that data upon closing. This leads to hard to maintain code, and is very
      error-prone.
      
      This commit stores all debugfs related data in the same place, making
      sure this is allocated only when the debugfs directory is successfully
      created, so that we don't waste memory when we don't use this feature.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      7cb5e368
    • M
      net: mvpp2: cls: Make the flow definitions const · 0b27f865
      Maxime Chevallier 提交于
      The cls_flow table represent the overall configuration of the
      classifier, used to match the different traffic classes in the Parsing
      and Classification engines.
      
      This configuration is static, and applies to all PPv2 instances, we must
      therefore keep it const so that no modifications of this table are
      performed at runtime.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      0b27f865
    • M
      net: mvpp2: cls: Rename MVPP2_N_FLOWS to MVPP2_N_PRS_FLOWS · 93c2589c
      Maxime Chevallier 提交于
      The macro definition MVPP2_N_FLOWS is ambiguous because it really
      represents the number of entries in the Header Parser that are used to
      identify the classification flows.
      
      Rename the macro to clearly state that we represent the number of flows
      in the Header Parser.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      93c2589c
    • M
      net: mvpp2: cls: use Lookup Type in classification engines · 32f1a672
      Maxime Chevallier 提交于
      The PPv2 classifier allows to perform multiple lookups on the same
      engine when classifying a packet. These lookups can match similar parts
      of a packet header, but perform different actions upon matching. To
      differentiate these types of lookups, it's possible to specify a Lookup
      Type in the flow table entries, which will be part of the key for the
      lookup engines.
      
      This commit introduces the use of Lookup Types for C2 matches. Since for
      now we only perform C2 lookups to enable RSS, we only need one Lookup
      Type.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      32f1a672
    • M
      net: mvpp2: cls: Start cls flow entries from beginning of table · dc61b37f
      Maxime Chevallier 提交于
      The Classifier flow table has 512 entries, that contains lookups
      commands executed consecutively for every flow. Since we have 21
      different flows, we have to carefully manage the flow table use.
      
      As of today, the start index of a lookup sequence is computed
      directly based in the flow->id. There are 8 reserved flow ids, from
      0-7, which don't have any corresponding sequence in the flow table. We
      can therefore ignore them when computing the index, and make so that the
      first non-reserved flow point to the very beginning of the flow table.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Suggested-by: NAlan Winkowski <walan@marvell.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      dc61b37f
    • M
      net: mvpp2: cls: Add missing MAC_DA field extraction · 1f29a8c4
      Maxime Chevallier 提交于
      PPv2's classifier supports extracting the MAC Destination Address from the
      L2 header to perform RSS and flow steering. Add the missing case when
      setting the Header Extracted Key fields in the flow table.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      1f29a8c4
    • M
      net: mvpp2: Don't use an int to store netdev_features_t · c9dbb6cf
      Maxime Chevallier 提交于
      int is not long enough to store all netdev_features, use the correct
      dedicated type to store them when building the list of dev->features.
      Signed-off-by: NMaxime Chevallier <maxime.chevallier@bootlin.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      c9dbb6cf
  2. 27 3月, 2019 19 次提交