net/sfc: factor out libefx-based Rx datapath
[dpdk.git] / drivers / net / sfc / sfc_kvargs.h
index ffce851..e86a7e9 100644 (file)
@@ -1,5 +1,7 @@
 /*-
- * Copyright (c) 2016 Solarflare Communications Inc.
+ *   BSD LICENSE
+ *
+ * Copyright (c) 2016-2017 Solarflare Communications Inc.
  * All rights reserved.
  *
  * This software was jointly developed between OKTET Labs (under contract
@@ -42,6 +44,24 @@ extern "C" {
 
 #define SFC_KVARG_MCDI_LOGGING         "mcdi_logging"
 
+#define SFC_KVARG_PERF_PROFILE         "perf_profile"
+
+#define SFC_KVARG_PERF_PROFILE_AUTO            "auto"
+#define SFC_KVARG_PERF_PROFILE_THROUGHPUT      "throughput"
+#define SFC_KVARG_PERF_PROFILE_LOW_LATENCY     "low-latency"
+#define SFC_KVARG_VALUES_PERF_PROFILE \
+       "[" SFC_KVARG_PERF_PROFILE_AUTO "|" \
+           SFC_KVARG_PERF_PROFILE_THROUGHPUT "|" \
+           SFC_KVARG_PERF_PROFILE_LOW_LATENCY "]"
+
+#define SFC_KVARG_STATS_UPDATE_PERIOD_MS       "stats_update_period_ms"
+
+#define SFC_KVARG_DATAPATH_EFX         "efx"
+
+#define SFC_KVARG_RX_DATAPATH          "rx_datapath"
+#define SFC_KVARG_VALUES_RX_DATAPATH \
+       "[" SFC_KVARG_DATAPATH_EFX "]"
+
 struct sfc_adapter;
 
 int sfc_kvargs_parse(struct sfc_adapter *sa);
@@ -52,6 +72,10 @@ int sfc_kvargs_process(struct sfc_adapter *sa, const char *key_match,
 
 int sfc_kvarg_bool_handler(const char *key, const char *value_str,
                           void *opaque);
+int sfc_kvarg_long_handler(const char *key, const char *value_str,
+                          void *opaque);
+int sfc_kvarg_string_handler(const char *key, const char *value_str,
+                            void *opaque);
 
 #ifdef __cplusplus
 }