ASSERT_RTNL();
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                if (rdev->wiphy_idx == wiphy_idx) {
                        result = rdev;
                        break;
        }
 
        /* Ensure another device does not already have this name. */
-       list_for_each_entry(rdev2, &cfg80211_rdev_list, list)
+       for_each_rdev(rdev2)
                if (strcmp(newname, wiphy_name(&rdev2->wiphy)) == 0)
                        return -EINVAL;
 
        struct cfg80211_registered_device *rdev;
 
        rtnl_lock();
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                if (net_eq(wiphy_net(&rdev->wiphy), net))
                        WARN_ON(cfg80211_switch_netns(rdev, &init_net));
        }
 
 extern struct list_head cfg80211_rdev_list;
 extern int cfg80211_rdev_list_generation;
 
+/* This is constructed like this so it can be used in if/else */
+static inline int for_each_rdev_check_rtnl(void)
+{
+       ASSERT_RTNL();
+       return 0;
+}
+#define for_each_rdev(rdev)                                            \
+       if (for_each_rdev_check_rtnl()) {} else                         \
+               list_for_each_entry(rdev, &cfg80211_rdev_list, list)
+
 struct cfg80211_internal_bss {
        struct list_head list;
        struct list_head hidden_list;
 
 
        ASSERT_RTNL();
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                struct wireless_dev *wdev;
 
                if (wiphy_net(&rdev->wiphy) != netns)
                cb->args[0] = (long)state;
        }
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                if (!net_eq(wiphy_net(&rdev->wiphy), sock_net(skb->sk)))
                        continue;
                if (++idx <= state->start)
                filter_wiphy = cb->args[2] - 1;
        }
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                if (!net_eq(wiphy_net(&rdev->wiphy), sock_net(skb->sk)))
                        continue;
                if (wp_idx < wp_start) {
 
        pr_debug("Verifying active interfaces after reg change\n");
        rtnl_lock();
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list)
+       for_each_rdev(rdev)
                reg_leave_invalid_chans(&rdev->wiphy);
 
        rtnl_unlock();
 
        ASSERT_RTNL();
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                wiphy = &rdev->wiphy;
                wiphy_update_regulatory(wiphy, initiator);
        }
 
        ASSERT_RTNL();
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                if (wiphy == &rdev->wiphy)
                        continue;
                wiphy_share_dfs_chan_state(wiphy, &rdev->wiphy);
        struct cfg80211_registered_device *rdev;
        struct wiphy *wiphy;
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                wiphy = &rdev->wiphy;
                if (wiphy->regulatory_flags & REGULATORY_WIPHY_SELF_MANAGED &&
                    request->initiator == NL80211_REGDOM_SET_BY_USER)
                list_del_init(&pending_beacon->list);
 
                /* Applies the beacon hint to current wiphys */
-               list_for_each_entry(rdev, &cfg80211_rdev_list, list)
+               for_each_rdev(rdev)
                        wiphy_update_new_beacon(&rdev->wiphy, pending_beacon);
 
                /* Remembers the beacon hint for new wiphys or reg changes */
 
        ASSERT_RTNL();
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                wiphy_lock(&rdev->wiphy);
                reg_process_self_managed_hint(&rdev->wiphy);
                wiphy_unlock(&rdev->wiphy);
        world_alpha2[0] = cfg80211_world_regdom->alpha2[0];
        world_alpha2[1] = cfg80211_world_regdom->alpha2[1];
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                if (rdev->wiphy.regulatory_flags & REGULATORY_WIPHY_SELF_MANAGED)
                        continue;
                if (rdev->wiphy.regulatory_flags & REGULATORY_CUSTOM_REG)
        struct cfg80211_registered_device *rdev;
        struct wireless_dev *wdev;
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                list_for_each_entry(wdev, &rdev->wiphy.wdev_list, list) {
                        wdev_lock(wdev);
                        if (!(wdev->wiphy->regulatory_flags & flag)) {
        if (WARN_ON(!cfg80211_chandef_valid(chandef)))
                return;
 
-       list_for_each_entry(rdev, &cfg80211_rdev_list, list) {
+       for_each_rdev(rdev) {
                if (wiphy == &rdev->wiphy)
                        continue;