Replace the use of gcc builtin __atomic_xxx intrinsics with corresponding
rte_atomic_xxx optional stdatomic API

Signed-off-by: Tyler Retzlaff <roret...@linux.microsoft.com>
---
 lib/power/power_acpi_cpufreq.c   | 33 +++++++++++++++++----------------
 lib/power/power_cppc_cpufreq.c   | 25 +++++++++++++------------
 lib/power/power_pstate_cpufreq.c | 31 ++++++++++++++++---------------
 3 files changed, 46 insertions(+), 43 deletions(-)

diff --git a/lib/power/power_acpi_cpufreq.c b/lib/power/power_acpi_cpufreq.c
index 6e57aca..8b55f19 100644
--- a/lib/power/power_acpi_cpufreq.c
+++ b/lib/power/power_acpi_cpufreq.c
@@ -7,6 +7,7 @@
 #include <stdlib.h>
 
 #include <rte_memcpy.h>
+#include <rte_stdatomic.h>
 #include <rte_string_fns.h>
 
 #include "power_acpi_cpufreq.h"
@@ -41,13 +42,13 @@ enum power_state {
  * Power info per lcore.
  */
 struct acpi_power_info {
-       unsigned int lcore_id;                   /**< Logical core id */
+       unsigned int lcore_id;               /**< Logical core id */
        uint32_t freqs[RTE_MAX_LCORE_FREQS]; /**< Frequency array */
        uint32_t nb_freqs;                   /**< number of available freqs */
        FILE *f;                             /**< FD of scaling_setspeed */
        char governor_ori[32];               /**< Original governor name */
        uint32_t curr_idx;                   /**< Freq index in freqs array */
-       uint32_t state;                      /**< Power in use state */
+       RTE_ATOMIC(uint32_t) state;          /**< Power in use state */
        uint16_t turbo_available;            /**< Turbo Boost available */
        uint16_t turbo_enable;               /**< Turbo Boost enable/disable */
 } __rte_cache_aligned;
@@ -249,9 +250,9 @@ struct acpi_power_info {
         * ordering below as lock to make sure the frequency operations
         * in the critical section are done under the correct state.
         */
-       if (!__atomic_compare_exchange_n(&(pi->state), &exp_state,
-                                       POWER_ONGOING, 0,
-                                       __ATOMIC_ACQUIRE, __ATOMIC_RELAXED)) {
+       if (!rte_atomic_compare_exchange_strong_explicit(&(pi->state), 
&exp_state,
+                                       POWER_ONGOING,
+                                       rte_memory_order_acquire, 
rte_memory_order_relaxed)) {
                RTE_LOG(INFO, POWER, "Power management of lcore %u is "
                                "in use\n", lcore_id);
                return -1;
@@ -289,15 +290,15 @@ struct acpi_power_info {
        RTE_LOG(INFO, POWER, "Initialized successfully for lcore %u "
                        "power management\n", lcore_id);
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_USED,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_USED,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return 0;
 
 fail:
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_UNKNOWN,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_UNKNOWN,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return -1;
 }
@@ -321,9 +322,9 @@ struct acpi_power_info {
         * ordering below as lock to make sure the frequency operations
         * in the critical section are done under the correct state.
         */
-       if (!__atomic_compare_exchange_n(&(pi->state), &exp_state,
-                                       POWER_ONGOING, 0,
-                                       __ATOMIC_ACQUIRE, __ATOMIC_RELAXED)) {
+       if (!rte_atomic_compare_exchange_strong_explicit(&(pi->state), 
&exp_state,
+                                       POWER_ONGOING,
+                                       rte_memory_order_acquire, 
rte_memory_order_relaxed)) {
                RTE_LOG(INFO, POWER, "Power management of lcore %u is "
                                "not used\n", lcore_id);
                return -1;
@@ -344,15 +345,15 @@ struct acpi_power_info {
                        "'userspace' mode and been set back to the "
                        "original\n", lcore_id);
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_IDLE,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_IDLE,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return 0;
 
 fail:
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_UNKNOWN,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_UNKNOWN,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return -1;
 }
diff --git a/lib/power/power_cppc_cpufreq.c b/lib/power/power_cppc_cpufreq.c
index fc9cffe..bb70f6a 100644
--- a/lib/power/power_cppc_cpufreq.c
+++ b/lib/power/power_cppc_cpufreq.c
@@ -6,6 +6,7 @@
 #include <stdlib.h>
 
 #include <rte_memcpy.h>
+#include <rte_stdatomic.h>
 
 #include "power_cppc_cpufreq.h"
 #include "power_common.h"
@@ -49,8 +50,8 @@ enum power_state {
  * Power info per lcore.
  */
 struct cppc_power_info {
-       unsigned int lcore_id;                   /**< Logical core id */
-       uint32_t state;                      /**< Power in use state */
+       unsigned int lcore_id;               /**< Logical core id */
+       RTE_ATOMIC(uint32_t) state;          /**< Power in use state */
        FILE *f;                             /**< FD of scaling_setspeed */
        char governor_ori[32];               /**< Original governor name */
        uint32_t curr_idx;                   /**< Freq index in freqs array */
@@ -353,9 +354,9 @@ struct cppc_power_info {
         * ordering below as lock to make sure the frequency operations
         * in the critical section are done under the correct state.
         */
-       if (!__atomic_compare_exchange_n(&(pi->state), &exp_state,
-                                       POWER_ONGOING, 0,
-                                       __ATOMIC_ACQUIRE, __ATOMIC_RELAXED)) {
+       if (!rte_atomic_compare_exchange_strong_explicit(&(pi->state), 
&exp_state,
+                                       POWER_ONGOING,
+                                       rte_memory_order_acquire, 
rte_memory_order_relaxed)) {
                RTE_LOG(INFO, POWER, "Power management of lcore %u is "
                                "in use\n", lcore_id);
                return -1;
@@ -393,12 +394,12 @@ struct cppc_power_info {
        RTE_LOG(INFO, POWER, "Initialized successfully for lcore %u "
                        "power management\n", lcore_id);
 
-       __atomic_store_n(&(pi->state), POWER_USED, __ATOMIC_RELEASE);
+       rte_atomic_store_explicit(&(pi->state), POWER_USED, 
rte_memory_order_release);
 
        return 0;
 
 fail:
-       __atomic_store_n(&(pi->state), POWER_UNKNOWN, __ATOMIC_RELEASE);
+       rte_atomic_store_explicit(&(pi->state), POWER_UNKNOWN, 
rte_memory_order_release);
        return -1;
 }
 
@@ -431,9 +432,9 @@ struct cppc_power_info {
         * ordering below as lock to make sure the frequency operations
         * in the critical section are done under the correct state.
         */
-       if (!__atomic_compare_exchange_n(&(pi->state), &exp_state,
-                                       POWER_ONGOING, 0,
-                                       __ATOMIC_ACQUIRE, __ATOMIC_RELAXED)) {
+       if (!rte_atomic_compare_exchange_strong_explicit(&(pi->state), 
&exp_state,
+                                       POWER_ONGOING,
+                                       rte_memory_order_acquire, 
rte_memory_order_relaxed)) {
                RTE_LOG(INFO, POWER, "Power management of lcore %u is "
                                "not used\n", lcore_id);
                return -1;
@@ -453,12 +454,12 @@ struct cppc_power_info {
        RTE_LOG(INFO, POWER, "Power management of lcore %u has exited from "
                        "'userspace' mode and been set back to the "
                        "original\n", lcore_id);
-       __atomic_store_n(&(pi->state), POWER_IDLE, __ATOMIC_RELEASE);
+       rte_atomic_store_explicit(&(pi->state), POWER_IDLE, 
rte_memory_order_release);
 
        return 0;
 
 fail:
-       __atomic_store_n(&(pi->state), POWER_UNKNOWN, __ATOMIC_RELEASE);
+       rte_atomic_store_explicit(&(pi->state), POWER_UNKNOWN, 
rte_memory_order_release);
 
        return -1;
 }
diff --git a/lib/power/power_pstate_cpufreq.c b/lib/power/power_pstate_cpufreq.c
index 52aa645..5ca5f60 100644
--- a/lib/power/power_pstate_cpufreq.c
+++ b/lib/power/power_pstate_cpufreq.c
@@ -12,6 +12,7 @@
 #include <inttypes.h>
 
 #include <rte_memcpy.h>
+#include <rte_stdatomic.h>
 
 #include "rte_power_pmd_mgmt.h"
 #include "power_pstate_cpufreq.h"
@@ -59,7 +60,7 @@ struct pstate_power_info {
        uint32_t non_turbo_max_ratio;        /**< Non Turbo Max ratio  */
        uint32_t sys_max_freq;               /**< system wide max freq  */
        uint32_t core_base_freq;             /**< core base freq  */
-       uint32_t state;                      /**< Power in use state */
+       RTE_ATOMIC(uint32_t) state;          /**< Power in use state */
        uint16_t turbo_available;            /**< Turbo Boost available */
        uint16_t turbo_enable;               /**< Turbo Boost enable/disable */
        uint16_t priority_core;              /**< High Performance core */
@@ -555,9 +556,9 @@ struct pstate_power_info {
         * ordering below as lock to make sure the frequency operations
         * in the critical section are done under the correct state.
         */
-       if (!__atomic_compare_exchange_n(&(pi->state), &exp_state,
-                                       POWER_ONGOING, 0,
-                                       __ATOMIC_ACQUIRE, __ATOMIC_RELAXED)) {
+       if (!rte_atomic_compare_exchange_strong_explicit(&(pi->state), 
&exp_state,
+                                       POWER_ONGOING,
+                                       rte_memory_order_acquire, 
rte_memory_order_relaxed)) {
                RTE_LOG(INFO, POWER, "Power management of lcore %u is "
                                "in use\n", lcore_id);
                return -1;
@@ -600,15 +601,15 @@ struct pstate_power_info {
        RTE_LOG(INFO, POWER, "Initialized successfully for lcore %u "
                        "power management\n", lcore_id);
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_USED,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_USED,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return 0;
 
 fail:
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_UNKNOWN,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_UNKNOWN,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return -1;
 }
@@ -633,9 +634,9 @@ struct pstate_power_info {
         * ordering below as lock to make sure the frequency operations
         * in the critical section are under done the correct state.
         */
-       if (!__atomic_compare_exchange_n(&(pi->state), &exp_state,
-                                       POWER_ONGOING, 0,
-                                       __ATOMIC_ACQUIRE, __ATOMIC_RELAXED)) {
+       if (!rte_atomic_compare_exchange_strong_explicit(&(pi->state), 
&exp_state,
+                                       POWER_ONGOING,
+                                       rte_memory_order_acquire, 
rte_memory_order_relaxed)) {
                RTE_LOG(INFO, POWER, "Power management of lcore %u is "
                                "not used\n", lcore_id);
                return -1;
@@ -658,15 +659,15 @@ struct pstate_power_info {
                        "'performance' mode and been set back to the "
                        "original\n", lcore_id);
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_IDLE,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_IDLE,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return 0;
 
 fail:
        exp_state = POWER_ONGOING;
-       __atomic_compare_exchange_n(&(pi->state), &exp_state, POWER_UNKNOWN,
-                                   0, __ATOMIC_RELEASE, __ATOMIC_RELAXED);
+       rte_atomic_compare_exchange_strong_explicit(&(pi->state), &exp_state, 
POWER_UNKNOWN,
+                                   rte_memory_order_release, 
rte_memory_order_relaxed);
 
        return -1;
 }
-- 
1.8.3.1

Reply via email to