From: Liang Ma <liang.j.ma@intel.com> To: dev@dpdk.org Cc: anatoly.burakov@intel.com, Liang Ma <liang.j.ma@intel.com> Subject: [dpdk-dev] [RFC v2 2/5] ethdev: add simple power management API and callback Date: Tue, 11 Aug 2020 11:27:43 +0100 Message-ID: <1597141666-20621-2-git-send-email-liang.j.ma@intel.com> (raw) In-Reply-To: <1597141666-20621-1-git-send-email-liang.j.ma@intel.com> Add a simple on/off switch that will enable saving power when no packets are arriving. It is based on counting the number of empty polls and, when the number reaches a certain threshold, entering an architecture-defined optimized power state that will either wait until a TSC timestamp expires, or when packets arrive. This API is limited to 1 core 1 queue use case as there is no coordination between queues/cores in ethdev. This design leverage RX Callback mechnaism which allow three different power management methodology co exist. 1. umwait/umonitor: The TSC timestamp is automatically calculated using current link speed and RX descriptor ring size, such that the sleep time is not longer than it would take for a NIC to fill its entire RX descriptor ring. 2. Pause instruction Instead of move the core into deeper C state, this lightweight method use Pause instruction to releaf the processor from busy polling. 3. Frequency Scaling Reuse exist rte power library to scale up/down core frequency depend on traffic volume. Signed-off-by: Liang Ma <liang.j.ma@intel.com> Signed-off-by: Anatoly Burakov <anatoly.burakov@intel.com> --- config/common_base | 4 +- lib/Makefile | 1 + lib/librte_ethdev/Makefile | 2 +- lib/librte_ethdev/meson.build | 2 +- lib/librte_ethdev/rte_ethdev.c | 198 +++++++++++++++++++++++ lib/librte_ethdev/rte_ethdev.h | 59 +++++++ lib/librte_ethdev/rte_ethdev_core.h | 43 ++++- lib/librte_ethdev/rte_ethdev_version.map | 4 + lib/meson.build | 5 +- mk/rte.app.mk | 2 +- 10 files changed, 311 insertions(+), 9 deletions(-) diff --git a/config/common_base b/config/common_base index f76585f16..e0948f0cb 100644 --- a/config/common_base +++ b/config/common_base @@ -155,7 +155,7 @@ CONFIG_RTE_MAX_ETHPORTS=32 CONFIG_RTE_MAX_QUEUES_PER_PORT=1024 CONFIG_RTE_LIBRTE_IEEE1588=n CONFIG_RTE_ETHDEV_QUEUE_STAT_CNTRS=16 -CONFIG_RTE_ETHDEV_RXTX_CALLBACKS=y +CONFIG_RTE_ETHDEV_RXTX_CALLBACKS=n CONFIG_RTE_ETHDEV_PROFILE_WITH_VTUNE=n # @@ -978,7 +978,7 @@ CONFIG_RTE_LIBRTE_ACL_DEBUG=n # # Compile librte_power # -CONFIG_RTE_LIBRTE_POWER=n +CONFIG_RTE_LIBRTE_POWER=y CONFIG_RTE_LIBRTE_POWER_DEBUG=n CONFIG_RTE_MAX_LCORE_FREQS=64 diff --git a/lib/Makefile b/lib/Makefile index 8f5b68a2d..87646698a 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -28,6 +28,7 @@ DEPDIRS-librte_ethdev := librte_net librte_eal librte_mempool librte_ring DEPDIRS-librte_ethdev += librte_mbuf DEPDIRS-librte_ethdev += librte_kvargs DEPDIRS-librte_ethdev += librte_meter +DEPDIRS-librte_ethdev += librte_power DIRS-$(CONFIG_RTE_LIBRTE_BBDEV) += librte_bbdev DEPDIRS-librte_bbdev := librte_eal librte_mempool librte_mbuf DIRS-$(CONFIG_RTE_LIBRTE_CRYPTODEV) += librte_cryptodev diff --git a/lib/librte_ethdev/Makefile b/lib/librte_ethdev/Makefile index 47747150b..6a4ce14cf 100644 --- a/lib/librte_ethdev/Makefile +++ b/lib/librte_ethdev/Makefile @@ -11,7 +11,7 @@ LIB = librte_ethdev.a CFLAGS += -O3 CFLAGS += $(WERROR_FLAGS) LDLIBS += -lrte_net -lrte_eal -lrte_mempool -lrte_ring -LDLIBS += -lrte_mbuf -lrte_kvargs -lrte_meter -lrte_telemetry +LDLIBS += -lrte_mbuf -lrte_kvargs -lrte_meter -lrte_telemetry -lrte_power EXPORT_MAP := rte_ethdev_version.map diff --git a/lib/librte_ethdev/meson.build b/lib/librte_ethdev/meson.build index 8fc24e8c8..e09e2395e 100644 --- a/lib/librte_ethdev/meson.build +++ b/lib/librte_ethdev/meson.build @@ -27,4 +27,4 @@ headers = files('rte_ethdev.h', 'rte_tm.h', 'rte_tm_driver.h') -deps += ['net', 'kvargs', 'meter', 'telemetry'] +deps += ['net', 'kvargs', 'meter', 'telemetry', 'power'] diff --git a/lib/librte_ethdev/rte_ethdev.c b/lib/librte_ethdev/rte_ethdev.c index 7858ad5f1..b43de88ce 100644 --- a/lib/librte_ethdev/rte_ethdev.c +++ b/lib/librte_ethdev/rte_ethdev.c @@ -16,6 +16,7 @@ #include <netinet/in.h> #include <rte_byteorder.h> +#include <rte_cpuflags.h> #include <rte_log.h> #include <rte_debug.h> #include <rte_interrupts.h> @@ -39,6 +40,7 @@ #include <rte_class.h> #include <rte_ether.h> #include <rte_telemetry.h> +#include <rte_power.h> #include "rte_ethdev_trace.h" #include "rte_ethdev.h" @@ -185,6 +187,100 @@ enum { STAT_QMAP_RX }; + +static uint16_t +rte_ethdev_pmgmt_umait(uint16_t port_id, uint16_t qidx, + struct rte_mbuf **pkts __rte_unused, uint16_t nb_rx, + uint16_t max_pkts __rte_unused, void *_ __rte_unused) +{ + + struct rte_eth_dev *dev = &rte_eth_devices[port_id]; + + if (dev->pwr_mgmt_state == RTE_ETH_DEV_POWER_MGMT_ENABLED) { + if (unlikely(nb_rx == 0)) { + dev->empty_poll_stats[qidx].num++; + if (unlikely(dev->empty_poll_stats[qidx].num > + ETH_EMPTYPOLL_MAX)) { + volatile void *target_addr; + uint64_t expected, mask; + uint16_t ret; + + /* + * get address of next descriptor in the RX + * ring for this queue, as well as expected + * value and a mask. + */ + ret = (*dev->dev_ops->next_rx_desc) + (dev->data->rx_queues[qidx], + &target_addr, &expected, &mask); + if (ret == 0) + /* -1ULL is maximum value for TSC */ + rte_power_monitor(target_addr, + expected, mask, + 0, -1ULL); + } + } else + dev->empty_poll_stats[qidx].num = 0; + } + + return 0; +} + +static uint16_t +rte_ethdev_pmgmt_pause(uint16_t port_id, uint16_t qidx, + struct rte_mbuf **pkts __rte_unused, uint16_t nb_rx, + uint16_t max_pkts __rte_unused, void *_ __rte_unused) +{ + struct rte_eth_dev *dev = &rte_eth_devices[port_id]; + + int i; + + if (dev->pwr_mgmt_state == RTE_ETH_DEV_POWER_MGMT_ENABLED) { + if (unlikely(nb_rx == 0)) { + + dev->empty_poll_stats[qidx].num++; + + if (unlikely(dev->empty_poll_stats[qidx].num > + ETH_EMPTYPOLL_MAX)) { + + for (i = 0; i < RTE_ETH_PAUSE_NUM; i++) + rte_pause(); + + } + } else + dev->empty_poll_stats[qidx].num = 0; + } + + return 0; +} + +static uint16_t +rte_ethdev_pmgmt_scalefreq(uint16_t port_id, uint16_t qidx, + struct rte_mbuf **pkts __rte_unused, uint16_t nb_rx, + uint16_t max_pkts __rte_unused, void *_ __rte_unused) +{ + struct rte_eth_dev *dev = &rte_eth_devices[port_id]; + + if (dev->pwr_mgmt_state == RTE_ETH_DEV_POWER_MGMT_ENABLED) { + if (unlikely(nb_rx == 0)) { + dev->empty_poll_stats[qidx].num++; + if (unlikely(dev->empty_poll_stats[qidx].num > + ETH_EMPTYPOLL_MAX)) { + + /*scale down freq */ + rte_power_freq_min(rte_lcore_id()); + + } + } else { + dev->empty_poll_stats[qidx].num = 0; + /* scal up freq */ + rte_power_freq_max(rte_lcore_id()); + } + } + + return 0; +} + int rte_eth_iterator_init(struct rte_dev_iterator *iter, const char *devargs_str) { @@ -5113,6 +5209,108 @@ rte_eth_dev_pool_ops_supported(uint16_t port_id, const char *pool) return (*dev->dev_ops->pool_ops_supported)(dev, pool); } +int +rte_eth_dev_power_mgmt_enable(unsigned int lcore_id, + uint16_t port_id, + enum rte_eth_dev_power_mgmt_cb_mode mode) +{ + struct rte_eth_dev *dev; + + RTE_ETH_VALID_PORTID_OR_ERR_RET(port_id, -EINVAL); + dev = &rte_eth_devices[port_id]; + + /* allocate memory for empty poll stats */ + dev->empty_poll_stats = rte_malloc_socket(NULL, + sizeof(struct rte_eth_ep_stat) + * RTE_MAX_QUEUES_PER_PORT, + 0, dev->data->numa_node); + + if (dev->empty_poll_stats == NULL) + return -ENOMEM; + + if (dev->pwr_mgmt_state == RTE_ETH_DEV_POWER_MGMT_ENABLED) + return -EINVAL; + + dev->cb_mode = mode; + + switch (mode) { + + case RTE_ETH_DEV_POWER_MGMT_CB_UMWAIT: + + if (!rte_cpu_get_flag_enabled(RTE_CPUFLAG_WAITPKG)) + return -ENOTSUP; + + dev->cur_pwr_cb = rte_eth_add_rx_callback(port_id, 0, + rte_ethdev_pmgmt_umait, NULL); + break; + + case RTE_ETH_DEV_POWER_MGMT_CB_SCALE: + + /* init scale freq */ + if (rte_power_init(lcore_id)) + return -EINVAL; + + dev->cur_pwr_cb = rte_eth_add_rx_callback(port_id, 0, + rte_ethdev_pmgmt_scalefreq, NULL); + break; + + case RTE_ETH_DEV_POWER_MGMT_CB_PAUSE: + + dev->cur_pwr_cb = rte_eth_add_rx_callback(port_id, 0, + rte_ethdev_pmgmt_pause, NULL); + break; + + } + + dev->pwr_mgmt_state = RTE_ETH_DEV_POWER_MGMT_ENABLED; + return 0; +} + +int +rte_eth_dev_power_mgmt_disable(unsigned int lcore_id, + uint16_t port_id) +{ + struct rte_eth_dev *dev; + + RTE_ETH_VALID_PORTID_OR_ERR_RET(port_id, -EINVAL); + dev = &rte_eth_devices[port_id]; + + /*add flag check */ + + if (dev->pwr_mgmt_state == RTE_ETH_DEV_POWER_MGMT_ENABLED) { + /* rte_free ignores NULL so safe to call without checks */ + rte_free(dev->empty_poll_stats); + + switch (dev->cb_mode) { + + case RTE_ETH_DEV_POWER_MGMT_CB_UMWAIT: + + case RTE_ETH_DEV_POWER_MGMT_CB_PAUSE: + + rte_eth_remove_rx_callback(port_id, 0, + dev->cur_pwr_cb); + + break; + + case RTE_ETH_DEV_POWER_MGMT_CB_SCALE: + + rte_power_freq_max(lcore_id); + + rte_eth_remove_rx_callback(port_id, 0, + dev->cur_pwr_cb); + + if (rte_power_exit(lcore_id)) + return -EINVAL; + + break; + } + + dev->pwr_mgmt_state = RTE_ETH_DEV_POWER_MGMT_DISABLED; + + } + return 0; +} + /** * A set of values to describe the possible states of a switch domain. */ diff --git a/lib/librte_ethdev/rte_ethdev.h b/lib/librte_ethdev/rte_ethdev.h index 57e4a6ca5..6858c0338 100644 --- a/lib/librte_ethdev/rte_ethdev.h +++ b/lib/librte_ethdev/rte_ethdev.h @@ -157,6 +157,7 @@ extern "C" { #include <rte_common.h> #include <rte_config.h> #include <rte_ether.h> +#include <rte_power_intrinsics.h> #include "rte_ethdev_trace_fp.h" #include "rte_dev_info.h" @@ -775,6 +776,7 @@ rte_eth_rss_hf_refine(uint64_t rss_hf) /** Maximum nb. of vlan per mirror rule */ #define ETH_MIRROR_MAX_VLANS 64 +#define ETH_EMPTYPOLL_MAX 512 /**< Empty poll number threshlold */ #define ETH_MIRROR_VIRTUAL_POOL_UP 0x01 /**< Virtual Pool uplink Mirroring. */ #define ETH_MIRROR_UPLINK_PORT 0x02 /**< Uplink Port Mirroring. */ #define ETH_MIRROR_DOWNLINK_PORT 0x04 /**< Downlink Port Mirroring. */ @@ -1603,6 +1605,25 @@ enum rte_eth_dev_state { RTE_ETH_DEV_REMOVED, }; +#define RTE_ETH_PAUSE_NUM 64 /* How many times to pause */ +/** + * Possible power management states of an ethdev port. + */ +enum rte_eth_dev_power_mgmt_state { + /** Device power management is disabled. */ + RTE_ETH_DEV_POWER_MGMT_DISABLED = 0, + /** Device power management is enabled. */ + RTE_ETH_DEV_POWER_MGMT_ENABLED, +}; + +enum rte_eth_dev_power_mgmt_cb_mode { + /** Device power management is disabled. */ + RTE_ETH_DEV_POWER_MGMT_CB_UMWAIT = 0, + /** Device power management is enabled. */ + RTE_ETH_DEV_POWER_MGMT_CB_PAUSE, + RTE_ETH_DEV_POWER_MGMT_CB_SCALE, +}; + struct rte_eth_dev_sriov { uint8_t active; /**< SRIOV is active with 16, 32 or 64 pools */ uint8_t nb_q_per_pool; /**< rx queue number per pool */ @@ -4415,6 +4436,40 @@ __rte_experimental int rte_eth_dev_hairpin_capability_get(uint16_t port_id, struct rte_eth_hairpin_cap *cap); +/** + * @warning + * @b EXPERIMENTAL: this API may change, or be removed, without prior notice + * + * Enable device power management. + * + * @param port_id + * The port identifier of the Ethernet device. + * + * @return + * 0 on success + * <0 on error + */ +__rte_experimental +int rte_eth_dev_power_mgmt_enable(unsigned int lcore_id, + uint16_t port_id, + enum rte_eth_dev_power_mgmt_cb_mode mode); + +/** + * @warning + * @b EXPERIMENTAL: this API may change, or be removed, without prior notice + * + * Disable device power management. + * + * @param port_id + * The port identifier of the Ethernet device. + * + * @return + * 0 on success + * <0 on error + */ +__rte_experimental +int rte_eth_dev_power_mgmt_disable(unsigned int lcore_id, uint16_t port_id); + #include <rte_ethdev_core.h> /** @@ -4535,6 +4590,7 @@ rte_eth_rx_burst(uint16_t port_id, uint16_t queue_id, return nb_rx; } + /** * Get the number of used descriptors of a rx queue * @@ -4993,6 +5049,9 @@ rte_eth_tx_buffer(uint16_t port_id, uint16_t queue_id, return rte_eth_tx_buffer_flush(port_id, queue_id, buffer); } + + + #ifdef __cplusplus } #endif diff --git a/lib/librte_ethdev/rte_ethdev_core.h b/lib/librte_ethdev/rte_ethdev_core.h index 32407dd41..7d6d85ddc 100644 --- a/lib/librte_ethdev/rte_ethdev_core.h +++ b/lib/librte_ethdev/rte_ethdev_core.h @@ -603,6 +603,27 @@ typedef int (*eth_tx_hairpin_queue_setup_t) uint16_t nb_tx_desc, const struct rte_eth_hairpin_conf *hairpin_conf); +/** + * @internal + * Get the next RX ring descriptor address. + * + * @param rxq + * ethdev queue pointer. + * @param tail_desc_addr + * the pointer point to descriptor address var. + * + * @return + * Negative errno value on error, 0 on success. + * + * @retval 0 + * Success. + * @retval -EINVAL + * Failed to get descriptor address. + */ +typedef int (*eth_next_rx_desc_t) + (void *rxq, volatile void **tail_desc_addr, + uint64_t *expected, uint64_t *mask); + /** * @internal A structure containing the functions exported by an Ethernet driver. */ @@ -752,6 +773,8 @@ struct eth_dev_ops { /**< Set up device RX hairpin queue. */ eth_tx_hairpin_queue_setup_t tx_hairpin_queue_setup; /**< Set up device TX hairpin queue. */ + eth_next_rx_desc_t next_rx_desc; + /**< Get next RX ring descriptor address. */ }; /** @@ -768,6 +791,14 @@ struct rte_eth_rxtx_callback { void *param; }; +/** + * @internal + * Structure used to hold counters for empty poll + */ +struct rte_eth_ep_stat { + uint64_t num; +} __rte_cache_aligned; + /** * @internal * The generic data structure associated with each ethernet device. @@ -807,8 +838,16 @@ struct rte_eth_dev { enum rte_eth_dev_state state; /**< Flag indicating the port state */ void *security_ctx; /**< Context for security ops */ - uint64_t reserved_64s[4]; /**< Reserved for future fields */ - void *reserved_ptrs[4]; /**< Reserved for future fields */ + /**< Empty poll number */ + enum rte_eth_dev_power_mgmt_state pwr_mgmt_state; + enum rte_eth_dev_power_mgmt_cb_mode cb_mode; + uint32_t reserved_32; + uint64_t reserved_64s[3]; /**< Reserved for future fields */ + + /**< Flag indicating the port power state */ + struct rte_eth_ep_stat *empty_poll_stats; + const struct rte_eth_rxtx_callback *cur_pwr_cb; + void *reserved_ptrs[3]; /**< Reserved for future fields */ } __rte_cache_aligned; struct rte_eth_dev_sriov; diff --git a/lib/librte_ethdev/rte_ethdev_version.map b/lib/librte_ethdev/rte_ethdev_version.map index 1212a17d3..4d5b63a5b 100644 --- a/lib/librte_ethdev/rte_ethdev_version.map +++ b/lib/librte_ethdev/rte_ethdev_version.map @@ -241,6 +241,10 @@ EXPERIMENTAL { __rte_ethdev_trace_rx_burst; __rte_ethdev_trace_tx_burst; rte_flow_get_aged_flows; + + # added in 20.08 + rte_eth_dev_power_mgmt_disable; + rte_eth_dev_power_mgmt_enable; }; INTERNAL { diff --git a/lib/meson.build b/lib/meson.build index 3852c0156..54cc0db7d 100644 --- a/lib/meson.build +++ b/lib/meson.build @@ -14,17 +14,18 @@ libraries = [ 'eal', # everything depends on eal 'ring', 'rcu', # rcu depends on ring + 'timer', # eventdev depends on this + 'power', # eventdev depends on this 'mempool', 'mbuf', 'net', 'meter', 'ethdev', 'pci', # core 'cmdline', 'metrics', # bitrate/latency stats depends on this 'hash', # efd depends on this - 'timer', # eventdev depends on this 'acl', 'bbdev', 'bitratestats', 'cfgfile', 'compressdev', 'cryptodev', 'distributor', 'efd', 'eventdev', 'gro', 'gso', 'ip_frag', 'jobstats', 'kni', 'latencystats', 'lpm', 'member', - 'power', 'pdump', 'rawdev', 'regexdev', + 'pdump', 'rawdev', 'regexdev', 'rib', 'reorder', 'sched', 'security', 'stack', 'vhost', # ipsec lib depends on net, crypto and security 'ipsec', diff --git a/mk/rte.app.mk b/mk/rte.app.mk index a54425997..b87abb26e 100644 --- a/mk/rte.app.mk +++ b/mk/rte.app.mk @@ -58,7 +58,6 @@ endif _LDLIBS-$(CONFIG_RTE_LIBRTE_METRICS) += --no-whole-archive _LDLIBS-$(CONFIG_RTE_LIBRTE_BITRATE) += -lrte_bitratestats _LDLIBS-$(CONFIG_RTE_LIBRTE_LATENCY_STATS) += -lrte_latencystats -_LDLIBS-$(CONFIG_RTE_LIBRTE_POWER) += -lrte_power _LDLIBS-$(CONFIG_RTE_LIBRTE_EFD) += -lrte_efd _LDLIBS-$(CONFIG_RTE_LIBRTE_BPF) += -lrte_bpf @@ -80,6 +79,7 @@ _LDLIBS-$(CONFIG_RTE_LIBRTE_KVARGS) += -lrte_kvargs _LDLIBS-y += -lrte_telemetry _LDLIBS-$(CONFIG_RTE_LIBRTE_MBUF) += -lrte_mbuf _LDLIBS-$(CONFIG_RTE_LIBRTE_NET) += -lrte_net +_LDLIBS-$(CONFIG_RTE_LIBRTE_POWER) += -lrte_power _LDLIBS-$(CONFIG_RTE_LIBRTE_ETHER) += -lrte_ethdev _LDLIBS-$(CONFIG_RTE_LIBRTE_BBDEV) += -lrte_bbdev _LDLIBS-$(CONFIG_RTE_LIBRTE_CRYPTODEV) += -lrte_cryptodev -- 2.17.1
next prev parent reply other threads:[~2020-08-11 10:28 UTC|newest] Thread overview: 421+ messages / expand[flat|nested] mbox.gz Atom feed top 2020-05-27 17:02 [dpdk-dev] [RFC 0/6] Power-optimized RX for Ethernet devices Anatoly Burakov 2020-05-27 17:02 ` [dpdk-dev] [RFC 1/6] eal: add power management intrinsics Anatoly Burakov 2020-05-28 11:39 ` Ananyev, Konstantin 2020-05-28 14:40 ` Burakov, Anatoly 2020-05-28 14:58 ` Bruce Richardson 2020-05-28 15:38 ` Ananyev, Konstantin 2020-05-29 6:56 ` Jerin Jacob 2020-06-02 10:15 ` Ananyev, Konstantin 2020-06-03 6:22 ` Honnappa Nagarahalli 2020-06-03 6:31 ` Jerin Jacob 2020-11-02 11:09 ` [dpdk-dev] [PATCH v11 0/6] Add PMD power mgmt Liang Ma 2020-11-02 11:10 ` [dpdk-dev] [PATCH v11 1/6] ethdev: add simple power management API Liang Ma 2020-11-02 12:23 ` Burakov, Anatoly 2020-11-02 11:10 ` [dpdk-dev] [PATCH v11 2/6] power: add PMD power management API and callback Liang Ma 2020-11-02 11:10 ` [dpdk-dev] [PATCH v11 3/6] net/ixgbe: implement power management API Liang Ma 2020-11-02 11:10 ` [dpdk-dev] [PATCH v11 4/6] net/i40e: " Liang Ma 2020-11-02 11:10 ` [dpdk-dev] [PATCH v11 5/6] net/ice: " Liang Ma 2020-11-02 11:10 ` [dpdk-dev] [PATCH v11 6/6] examples/l3fwd-power: enable PMD power mgmt Liang Ma 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 00/11] Add PMD power management Anatoly Burakov 2020-12-17 16:12 ` David Marchand 2021-01-08 16:42 ` Burakov, Anatoly 2021-01-11 8:44 ` David Marchand 2021-01-11 8:52 ` David Marchand 2021-01-11 10:21 ` Burakov, Anatoly 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 " Anatoly Burakov 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 01/11] eal: uninline power intrinsics Anatoly Burakov 2021-01-12 15:54 ` Ananyev, Konstantin 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 02/11] eal: avoid invalid API usage in " Anatoly Burakov 2021-01-08 19:58 ` Stephen Hemminger 2021-01-11 10:21 ` Burakov, Anatoly 2021-01-12 15:56 ` Ananyev, Konstantin 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 03/11] eal: change API of " Anatoly Burakov 2021-01-12 15:58 ` Ananyev, Konstantin 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 04/11] eal: remove sync version of power monitor Anatoly Burakov 2021-01-12 15:59 ` Ananyev, Konstantin 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 05/11] eal: add monitor wakeup function Anatoly Burakov 2021-01-12 16:02 ` Ananyev, Konstantin 2021-01-12 16:18 ` Burakov, Anatoly 2021-01-12 16:25 ` Burakov, Anatoly 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 06/11] ethdev: add simple power management API Anatoly Burakov 2021-01-09 8:04 ` Andrew Rybchenko 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 07/11] power: add PMD power management API and callback Anatoly Burakov 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 08/11] net/ixgbe: implement power management API Anatoly Burakov 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 09/11] net/i40e: " Anatoly Burakov 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 10/11] net/ice: " Anatoly Burakov 2021-01-08 17:42 ` [dpdk-dev] [PATCH v13 11/11] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 00/11] Add PMD power management Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 01/11] eal: uninline power intrinsics Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 02/11] eal: avoid invalid API usage in " Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 03/11] eal: change API of " Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 04/11] eal: remove sync version of power monitor Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 05/11] eal: add monitor wakeup function Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 06/11] ethdev: add simple power management API Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 07/11] power: add PMD power management API and callback Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 08/11] net/ixgbe: implement power management API Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 09/11] net/i40e: " Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 10/11] net/ice: " Anatoly Burakov 2021-01-11 14:35 ` [dpdk-dev] [PATCH v14 11/11] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 00/11] Add PMD power management Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 01/11] eal: uninline power intrinsics Anatoly Burakov 2021-01-12 16:09 ` Ananyev, Konstantin 2021-01-12 16:14 ` Burakov, Anatoly 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 02/11] eal: avoid invalid API usage in " Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 03/11] eal: change API of " Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 04/11] eal: remove sync version of power monitor Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 05/11] eal: add monitor wakeup function Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 06/11] ethdev: add simple power management API Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 07/11] power: add PMD power management API and callback Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 08/11] net/ixgbe: implement power management API Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 09/11] net/i40e: " Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 10/11] net/ice: " Anatoly Burakov 2021-01-11 14:58 ` [dpdk-dev] [PATCH v15 11/11] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 00/11] Add PMD power management Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 01/11] eal: uninline power intrinsics Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 02/11] eal: avoid invalid API usage in " Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 03/11] eal: change API of " Anatoly Burakov 2021-01-13 13:01 ` Ananyev, Konstantin 2021-01-13 17:22 ` Burakov, Anatoly 2021-01-13 18:01 ` Ananyev, Konstantin 2021-01-14 10:23 ` Burakov, Anatoly 2021-01-14 12:33 ` Ananyev, Konstantin 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 04/11] eal: remove sync version of power monitor Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 05/11] eal: add monitor wakeup function Anatoly Burakov 2021-01-13 12:46 ` Ananyev, Konstantin 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 06/11] ethdev: add simple power management API Anatoly Burakov 2021-01-13 13:18 ` Ananyev, Konstantin 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 07/11] power: add PMD power management API and callback Anatoly Burakov 2021-01-13 12:58 ` Ananyev, Konstantin 2021-01-13 17:29 ` Burakov, Anatoly 2021-01-14 13:00 ` Burakov, Anatoly 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 08/11] net/ixgbe: implement power management API Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 09/11] net/i40e: " Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 10/11] net/ice: " Anatoly Burakov 2021-01-12 17:37 ` [dpdk-dev] [PATCH v16 11/11] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-14 9:36 ` [dpdk-dev] [PATCH v16 00/11] Add PMD power management David Marchand 2021-01-14 10:25 ` Burakov, Anatoly 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 " Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 01/11] eal: uninline power intrinsics Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 02/11] eal: avoid invalid API usage in " Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 03/11] eal: change API of " Anatoly Burakov 2021-01-18 22:26 ` Thomas Monjalon 2021-01-19 10:29 ` Burakov, Anatoly 2021-01-19 10:42 ` Thomas Monjalon 2021-01-19 11:23 ` Burakov, Anatoly 2021-01-19 14:17 ` Thomas Monjalon 2021-01-20 10:32 ` Burakov, Anatoly 2021-01-20 10:38 ` Thomas Monjalon 2021-01-20 11:05 ` Burakov, Anatoly 2021-01-20 11:11 ` Thomas Monjalon 2021-01-20 11:17 ` Burakov, Anatoly 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 04/11] eal: remove sync version of power monitor Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 05/11] eal: add monitor wakeup function Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 06/11] ethdev: add simple power management API Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 07/11] power: add PMD power management API and callback Anatoly Burakov 2021-01-18 12:41 ` David Hunt 2021-01-19 16:45 ` [dpdk-dev] [PATCH v18 0/2] Add PMD power management Anatoly Burakov 2021-01-19 16:45 ` [dpdk-dev] [PATCH v18 1/2] power: add PMD power management API and callback Anatoly Burakov 2021-01-19 16:45 ` [dpdk-dev] [PATCH v18 2/2] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-20 11:50 ` [dpdk-dev] [PATCH v19 0/4] Add PMD power management Anatoly Burakov 2021-01-20 11:50 ` [dpdk-dev] [PATCH v19 1/4] eal: rename power monitor condition member Anatoly Burakov 2021-01-20 11:50 ` [dpdk-dev] [PATCH v19 2/4] eal: improve comments around power monitoring API Anatoly Burakov 2021-01-20 11:50 ` [dpdk-dev] [PATCH v19 3/4] power: add PMD power management API and callback Anatoly Burakov 2021-01-20 11:50 ` [dpdk-dev] [PATCH v19 4/4] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-22 17:12 ` [dpdk-dev] [PATCH v20 0/4] Add PMD power management Anatoly Burakov 2021-01-22 17:12 ` [dpdk-dev] [PATCH v20 1/4] eal: rename power monitor condition member Anatoly Burakov 2021-01-29 11:26 ` Thomas Monjalon 2021-01-22 17:12 ` [dpdk-dev] [PATCH v20 2/4] eal: improve comments around power monitoring API Anatoly Burakov 2021-01-29 11:27 ` Thomas Monjalon 2021-01-22 17:12 ` [dpdk-dev] [PATCH v20 3/4] power: add PMD power management API and callback Anatoly Burakov 2021-01-22 17:12 ` [dpdk-dev] [PATCH v20 4/4] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-29 14:15 ` Thomas Monjalon 2021-01-29 14:20 ` [dpdk-dev] [PATCH v20 0/4] Add PMD power management Thomas Monjalon 2021-01-29 14:47 ` Burakov, Anatoly 2021-01-18 22:48 ` [dpdk-dev] [PATCH v17 07/11] power: add PMD power management API and callback Thomas Monjalon 2021-01-19 12:25 ` Burakov, Anatoly 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 08/11] net/ixgbe: implement power management API Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 09/11] net/i40e: " Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 10/11] net/ice: " Anatoly Burakov 2021-01-14 14:46 ` [dpdk-dev] [PATCH v17 11/11] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2021-01-18 12:53 ` David Hunt 2021-01-18 15:24 ` [dpdk-dev] [PATCH v17 00/11] Add PMD power management David Marchand 2021-01-18 15:45 ` Burakov, Anatoly 2021-01-18 16:06 ` Thomas Monjalon 2021-01-18 17:02 ` Burakov, Anatoly 2021-01-18 17:54 ` David Marchand 2021-01-18 22:52 ` Thomas Monjalon 2021-01-19 10:30 ` Burakov, Anatoly 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 01/11] eal: uninline power intrinsics Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 02/11] eal: avoid invalid API usage in " Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 03/11] eal: change API of " Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 04/11] eal: remove sync version of power monitor Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 05/11] eal: add monitor wakeup function Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 06/11] ethdev: add simple power management API Anatoly Burakov 2020-12-28 11:00 ` Andrew Rybchenko 2021-01-08 16:30 ` Burakov, Anatoly 2021-01-12 20:32 ` Lance Richardson 2021-01-13 13:04 ` Burakov, Anatoly 2021-01-13 13:25 ` Ananyev, Konstantin 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 07/11] power: add PMD power management API and callback Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 08/11] net/ixgbe: implement power management API Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 09/11] net/i40e: " Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 10/11] net/ice: " Anatoly Burakov 2020-12-17 14:05 ` [dpdk-dev] [PATCH v12 11/11] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2020-05-27 17:02 ` [dpdk-dev] [RFC 2/6] ethdev: add simple power management API Anatoly Burakov 2020-05-28 12:15 ` Ananyev, Konstantin 2020-05-27 17:02 ` [dpdk-dev] [RFC 3/6] net/ixgbe: implement " Anatoly Burakov 2020-05-27 17:02 ` [dpdk-dev] [RFC 4/6] net/i40e: " Anatoly Burakov 2020-05-27 17:02 ` [dpdk-dev] [RFC 5/6] net/ice: " Anatoly Burakov 2020-05-27 17:02 ` [dpdk-dev] [RFC 6/6] app/testpmd: add command for power management on a port Anatoly Burakov 2020-05-27 17:33 ` [dpdk-dev] [RFC 0/6] Power-optimized RX for Ethernet devices Jerin Jacob 2020-05-27 20:57 ` Stephen Hemminger 2020-08-11 10:27 ` [dpdk-dev] [RFC v2 1/5] eal: add power management intrinsics Liang Ma 2020-08-11 10:27 ` Liang Ma [this message] 2020-08-13 18:11 ` [dpdk-dev] [RFC v2 2/5] ethdev: add simple power management API and callback Liang, Ma 2020-08-11 10:27 ` [dpdk-dev] [RFC v2 3/5] net/ixgbe: implement power management API Liang Ma 2020-08-11 10:27 ` [dpdk-dev] [RFC v2 4/5] net/i40e: " Liang Ma 2020-08-11 10:27 ` [dpdk-dev] [RFC v2 5/5] net/ice: " Liang Ma 2020-08-13 18:04 ` [dpdk-dev] [RFC v2 1/5] eal: add power management intrinsics Liang, Ma 2020-09-03 16:06 ` [dpdk-dev] [RFC PATCH v3 1/6] " Liang Ma 2020-09-03 16:07 ` [dpdk-dev] [RFC PATCH v3 2/6] ethdev: add simple power management API Liang Ma 2020-09-03 16:07 ` [dpdk-dev] [RFC PATCH v3 3/6] power: add simple power management API and callback Liang Ma 2020-09-03 16:07 ` [dpdk-dev] [RFC PATCH v3 4/6] net/ixgbe: implement power management API Liang Ma 2020-09-03 16:07 ` [dpdk-dev] [RFC PATCH v3 5/6] net/i40e: " Liang Ma 2020-09-03 16:07 ` [dpdk-dev] [RFC PATCH v3 6/6] net/ice: " Liang Ma 2020-09-04 10:18 ` [dpdk-dev] [PATCH v3 1/6] eal: add power management intrinsics Liang Ma 2020-09-04 10:18 ` [dpdk-dev] [PATCH v3 2/6] ethdev: add simple power management API Liang Ma 2020-09-04 16:37 ` Stephen Hemminger 2020-09-14 21:04 ` Liang, Ma 2020-09-04 20:54 ` Ananyev, Konstantin 2020-09-04 10:18 ` [dpdk-dev] [PATCH v3 3/6] power: add simple power management API and callback Liang Ma 2020-09-04 16:36 ` Stephen Hemminger 2020-09-14 20:52 ` Liang, Ma 2020-09-04 18:33 ` Ananyev, Konstantin 2020-09-14 21:01 ` Liang, Ma 2020-09-16 14:53 ` Ananyev, Konstantin 2020-09-16 16:39 ` Liang, Ma 2020-09-16 16:44 ` Ananyev, Konstantin 2020-09-04 10:18 ` [dpdk-dev] [PATCH v3 4/6] net/ixgbe: implement power management API Liang Ma 2020-09-04 10:18 ` [dpdk-dev] [PATCH v3 5/6] net/i40e: " Liang Ma 2020-09-04 10:19 ` [dpdk-dev] [PATCH v3 6/6] net/ice: " Liang Ma 2020-09-04 16:23 ` [dpdk-dev] [PATCH v3 1/6] eal: add power management intrinsics Stephen Hemminger 2020-09-14 20:48 ` Liang, Ma 2020-09-04 16:37 ` Stephen Hemminger 2020-09-14 20:49 ` Liang, Ma 2020-09-04 18:42 ` Stephen Hemminger 2020-09-14 21:12 ` Liang, Ma 2020-09-16 16:34 ` Liang, Ma 2020-09-06 21:44 ` Ananyev, Konstantin 2020-09-18 5:01 ` Jerin Jacob 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 01/10] eal: add new x86 cpuid support for WAITPKG Liang Ma 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 02/10] eal: add power management intrinsics Liang Ma 2020-10-08 8:33 ` Thomas Monjalon 2020-10-08 8:44 ` Jerin Jacob 2020-10-08 9:41 ` Thomas Monjalon 2020-10-08 13:26 ` Burakov, Anatoly 2020-10-08 15:13 ` Jerin Jacob 2020-10-08 17:07 ` Ananyev, Konstantin 2020-10-09 5:42 ` Jerin Jacob 2020-10-09 9:25 ` Burakov, Anatoly 2020-10-09 9:29 ` Thomas Monjalon 2020-10-09 9:40 ` Burakov, Anatoly 2020-10-09 9:54 ` Jerin Jacob 2020-10-09 10:03 ` Burakov, Anatoly 2020-10-09 10:17 ` Thomas Monjalon 2020-10-09 10:22 ` Burakov, Anatoly 2020-10-09 10:45 ` Jerin Jacob 2020-10-09 10:48 ` Ananyev, Konstantin 2020-10-09 11:12 ` Burakov, Anatoly 2020-10-09 11:36 ` Bruce Richardson 2020-10-09 11:42 ` Burakov, Anatoly 2020-10-09 10:19 ` Jerin Jacob 2020-10-08 17:15 ` Ananyev, Konstantin 2020-10-09 9:11 ` Burakov, Anatoly 2020-10-09 15:39 ` Ananyev, Konstantin 2020-10-09 16:10 ` Burakov, Anatoly 2020-10-09 16:56 ` Ananyev, Konstantin 2020-10-09 16:59 ` Burakov, Anatoly 2020-10-10 13:19 ` Ananyev, Konstantin 2020-10-12 10:35 ` Burakov, Anatoly 2020-10-12 10:36 ` Burakov, Anatoly 2020-10-12 12:50 ` Ananyev, Konstantin 2020-10-12 13:13 ` Burakov, Anatoly 2020-10-13 9:45 ` Burakov, Anatoly 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 03/10] ethdev: add simple power management API Liang Ma 2020-10-08 8:46 ` Thomas Monjalon 2020-10-08 11:39 ` Ananyev, Konstantin 2020-10-08 22:26 ` Ananyev, Konstantin 2020-10-09 16:11 ` Burakov, Anatoly 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 04/10] power: add simple power management API and callback Liang Ma 2020-10-09 16:38 ` Ananyev, Konstantin 2020-10-09 16:47 ` Burakov, Anatoly 2020-10-09 16:51 ` Ananyev, Konstantin 2020-10-09 16:56 ` Burakov, Anatoly 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 05/10] net/ixgbe: implement power management API Liang Ma 2020-10-09 15:53 ` Ananyev, Konstantin 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 06/10] net/i40e: " Liang Ma 2020-10-09 16:01 ` Ananyev, Konstantin 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 07/10] net/ice: " Liang Ma 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 08/10] examples/l3fwd-power: enable PMD power mgmt Liang Ma 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 09/10] doc: update release notes for PMD power management Liang Ma 2020-10-02 14:11 ` [dpdk-dev] [PATCH v4 10/10] doc: update the programming guide " Liang Ma 2020-10-02 14:44 ` [dpdk-dev] [PATCH v4 01/10] eal: add new x86 cpuid support for WAITPKG Bruce Richardson 2020-10-08 22:08 ` Ananyev, Konstantin 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 " Anatoly Burakov 2020-10-09 17:06 ` Burakov, Anatoly 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 " Anatoly Burakov 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 " Anatoly Burakov 2020-10-23 17:17 ` [dpdk-dev] [PATCH v8 " Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 00/10] Add PMD power mgmt Liang Ma 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 0/9] " Liang Ma 2020-10-27 16:02 ` Thomas Monjalon 2020-10-28 13:35 ` Liang, Ma 2020-10-28 13:49 ` Jerin Jacob 2020-10-28 14:21 ` Thomas Monjalon 2020-10-28 14:57 ` Ananyev, Konstantin 2020-10-28 15:14 ` Jerin Jacob 2020-10-28 15:30 ` Liang, Ma 2020-10-28 15:36 ` Jerin Jacob 2020-10-28 15:44 ` Liang, Ma 2020-10-28 16:01 ` Jerin Jacob 2020-10-28 16:21 ` Liang, Ma 2020-10-28 15:33 ` Ananyev, Konstantin 2020-10-28 15:39 ` Jerin Jacob 2020-10-28 15:49 ` Ananyev, Konstantin 2020-10-28 15:57 ` Jerin Jacob 2020-10-28 16:38 ` Ananyev, Konstantin 2020-10-28 16:47 ` Liang, Ma 2020-10-28 16:54 ` McDaniel, Timothy 2020-10-29 9:19 ` Liang, Ma 2020-10-28 17:02 ` Ajit Khaparde 2020-10-28 18:10 ` Ananyev, Konstantin 2020-10-27 20:53 ` Ajit Khaparde 2020-10-28 12:13 ` Liang, Ma 2020-10-29 17:42 ` Thomas Monjalon 2020-10-30 9:36 ` Liang, Ma 2020-10-30 9:58 ` Thomas Monjalon 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 1/9] eal: add new x86 cpuid support for WAITPKG Liang Ma 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 2/9] eal: add power management intrinsics Liang Ma 2020-10-29 17:39 ` Thomas Monjalon 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 3/9] eal: add intrinsics support check infrastructure Liang Ma 2020-10-29 21:27 ` David Marchand 2020-10-30 10:09 ` Burakov, Anatoly 2020-10-30 10:14 ` Thomas Monjalon 2020-10-30 13:37 ` Burakov, Anatoly 2020-10-30 14:09 ` Thomas Monjalon 2020-10-30 15:27 ` Burakov, Anatoly 2020-10-30 15:44 ` Thomas Monjalon 2020-10-30 16:36 ` Burakov, Anatoly 2020-10-30 16:50 ` Thomas Monjalon 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 4/9] ethdev: add simple power management API Liang Ma 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 5/9] power: add PMD power management API and callback Liang Ma 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 6/9] net/ixgbe: implement power management API Liang Ma 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 7/9] net/i40e: " Liang Ma 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 8/9] net/ice: " Liang Ma 2020-10-27 14:59 ` [dpdk-dev] [PATCH v10 9/9] examples/l3fwd-power: enable PMD power mgmt Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 01/10] eal: add new x86 cpuid support for WAITPKG Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 02/10] eal: add power management intrinsics Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 03/10] eal: add intrinsics support check infrastructure Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 04/10] ethdev: add simple power management API Liang Ma 2020-10-24 20:39 ` Thomas Monjalon 2020-10-27 11:15 ` Liang, Ma 2020-10-27 15:52 ` Thomas Monjalon 2020-10-27 17:43 ` Ananyev, Konstantin 2020-10-27 18:30 ` Thomas Monjalon 2020-10-27 23:29 ` Ananyev, Konstantin 2020-10-28 3:24 ` Ajit Khaparde 2020-10-28 12:24 ` Liang, Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 05/10] power: add PMD power management API and callback Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 06/10] net/ixgbe: implement power management API Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 07/10] net/i40e: " Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 08/10] net/ice: " Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 09/10] examples/l3fwd-power: enable PMD power mgmt Liang Ma 2020-10-23 23:06 ` [dpdk-dev] [PATCH v9 10/10] doc: update programmer's guide for power library Liang Ma 2020-10-24 20:49 ` Thomas Monjalon 2020-10-27 11:04 ` Liang, Ma 2020-10-23 17:20 ` [dpdk-dev] [PATCH v8 02/10] eal: add power management intrinsics Liang Ma 2020-10-23 17:21 ` [dpdk-dev] [PATCH v8 03/10] eal: add intrinsics support check infrastructure Liang Ma 2020-10-23 17:22 ` [dpdk-dev] [PATCH v8 04/10] ethdev: add simple power management API Liang Ma 2020-10-23 17:23 ` [dpdk-dev] [PATCH v8 05/10] power: add PMD power management API and callback Liang Ma 2020-10-23 17:26 ` [dpdk-dev] [PATCH v8 06/10] net/ixgbe: implement power management API Liang Ma 2020-10-23 17:26 ` [dpdk-dev] [PATCH v8 07/10] net/i40e: " Liang Ma 2020-10-23 17:27 ` [dpdk-dev] [PATCH v8 08/10] net/ice: " Liang Ma 2020-10-23 17:30 ` [dpdk-dev] [PATCH v8 09/10] examples/l3fwd-power: enable PMD power mgmt Liang Ma 2020-10-23 17:36 ` [dpdk-dev] [PATCH v8 10/10] doc: update programmer's guide for power library Liang Ma 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 02/10] eal: add power management intrinsics Anatoly Burakov 2020-10-15 12:06 ` Jerin Jacob 2020-10-15 13:16 ` Ferruh Yigit 2020-10-16 8:44 ` Ruifeng Wang 2020-10-15 16:43 ` Ananyev, Konstantin 2020-10-19 21:12 ` Thomas Monjalon 2020-10-20 2:49 ` Ruifeng Wang 2020-10-20 7:35 ` Thomas Monjalon 2020-10-20 14:01 ` David Hunt 2020-10-20 14:17 ` David Hunt 2020-10-20 14:33 ` Thomas Monjalon 2020-10-20 17:26 ` Ananyev, Konstantin 2020-10-20 19:28 ` Thomas Monjalon 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 03/10] eal: add intrinsics support check infrastructure Anatoly Burakov 2020-10-16 9:02 ` Ruifeng Wang 2020-10-16 11:21 ` Kinsella, Ray 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 04/10] ethdev: add simple power management API Anatoly Burakov 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 05/10] power: add PMD power management API and callback Anatoly Burakov 2020-10-15 16:52 ` Ananyev, Konstantin 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 06/10] net/ixgbe: implement power management API Anatoly Burakov 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 07/10] net/i40e: " Anatoly Burakov 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 08/10] net/ice: " Anatoly Burakov 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 09/10] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2020-10-15 12:04 ` [dpdk-dev] [PATCH v7 10/10] doc: update programmer's guide for power library Anatoly Burakov 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 02/10] eal: add power management intrinsics Anatoly Burakov 2020-10-14 17:48 ` Ananyev, Konstantin 2020-10-15 10:09 ` Burakov, Anatoly 2020-10-15 10:45 ` Burakov, Anatoly 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 03/10] eal: add intrinsics support check infrastructure Anatoly Burakov 2020-10-14 17:51 ` Ananyev, Konstantin 2020-10-14 17:59 ` Jerin Jacob 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 04/10] ethdev: add simple power management API Anatoly Burakov 2020-10-14 17:06 ` Ananyev, Konstantin 2020-10-15 11:29 ` Liang, Ma 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 05/10] power: add PMD power management API and callback Anatoly Burakov 2020-10-14 14:19 ` David Hunt 2020-10-14 18:41 ` Ananyev, Konstantin 2020-10-15 10:31 ` Burakov, Anatoly 2020-10-15 16:02 ` Ananyev, Konstantin 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 06/10] net/ixgbe: implement power management API Anatoly Burakov 2020-10-14 17:04 ` Wang, Haiyue 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 07/10] net/i40e: " Anatoly Burakov 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 08/10] net/ice: " Anatoly Burakov 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 09/10] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2020-10-14 14:24 ` David Hunt 2020-10-14 13:30 ` [dpdk-dev] [PATCH v6 10/10] doc: update programmer's guide for power library Anatoly Burakov 2020-10-14 14:27 ` David Hunt 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 02/10] eal: add power management intrinsics Anatoly Burakov 2020-10-09 16:09 ` Jerin Jacob 2020-10-09 16:24 ` Burakov, Anatoly 2020-10-12 19:47 ` David Christensen 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 03/10] eal: add intrinsics support check infrastructure Anatoly Burakov 2020-10-11 10:07 ` Jerin Jacob 2020-10-12 9:26 ` Burakov, Anatoly 2020-10-12 19:52 ` David Christensen 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 04/10] ethdev: add simple power management API Anatoly Burakov 2020-10-14 3:10 ` Guo, Jia 2020-10-14 9:07 ` Burakov, Anatoly 2020-10-14 9:15 ` Guo, Jia 2020-10-14 9:30 ` Burakov, Anatoly 2020-10-14 9:23 ` Bruce Richardson 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 05/10] power: add PMD power management API and callback Anatoly Burakov 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 06/10] net/ixgbe: implement power management API Anatoly Burakov 2020-10-12 7:46 ` Wang, Haiyue 2020-10-12 9:28 ` Burakov, Anatoly 2020-10-12 9:44 ` Burakov, Anatoly 2020-10-12 15:58 ` Wang, Haiyue 2020-10-12 8:09 ` Wang, Haiyue 2020-10-12 9:28 ` Burakov, Anatoly 2020-10-13 1:17 ` Wang, Haiyue 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 07/10] net/i40e: " Anatoly Burakov 2020-10-14 3:19 ` Guo, Jia 2020-10-14 9:08 ` Burakov, Anatoly 2020-10-14 9:17 ` Guo, Jia 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 08/10] net/ice: " Anatoly Burakov 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 09/10] examples/l3fwd-power: enable PMD power mgmt Anatoly Burakov 2020-10-09 16:02 ` [dpdk-dev] [PATCH v5 10/10] doc: update programmer's guide for power library Anatoly Burakov
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=1597141666-20621-2-git-send-email-liang.j.ma@intel.com \ --to=liang.j.ma@intel.com \ --cc=anatoly.burakov@intel.com \ --cc=dev@dpdk.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
DPDK patches and discussions This inbox may be cloned and mirrored by anyone: git clone --mirror http://inbox.dpdk.org/dev/0 dev/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 dev dev/ http://inbox.dpdk.org/dev \ dev@dpdk.org public-inbox-index dev Example config snippet for mirrors. Newsgroup available over NNTP: nntp://inbox.dpdk.org/inbox.dpdk.dev AGPL code for this site: git clone https://public-inbox.org/public-inbox.git