__FM10K_TX_DETECT_HANG,
        __FM10K_HANG_CHECK_ARMED,
        __FM10K_TX_XPS_INIT_DONE,
+       /* This must be last and is used to calculate BITMAP size */
+       __FM10K_TX_STATE_SIZE__,
 };
 
 #define check_for_tx_hang(ring) \
-       test_bit(__FM10K_TX_DETECT_HANG, &(ring)->state)
+       test_bit(__FM10K_TX_DETECT_HANG, (ring)->state)
 #define set_check_for_tx_hang(ring) \
-       set_bit(__FM10K_TX_DETECT_HANG, &(ring)->state)
+       set_bit(__FM10K_TX_DETECT_HANG, (ring)->state)
 #define clear_check_for_tx_hang(ring) \
-       clear_bit(__FM10K_TX_DETECT_HANG, &(ring)->state)
+       clear_bit(__FM10K_TX_DETECT_HANG, (ring)->state)
 
 struct fm10k_tx_buffer {
        struct fm10k_tx_desc *next_to_watch;
                struct fm10k_rx_buffer *rx_buffer;
        };
        u32 __iomem *tail;
-       unsigned long state;
+       DECLARE_BITMAP(state, __FM10K_TX_STATE_SIZE__);
        dma_addr_t dma;                 /* phys. address of descriptor ring */
        unsigned int size;              /* length in bytes */
 
        __FM10K_FLAGS_SIZE__
 };
 
+enum fm10k_state_t {
+       __FM10K_RESETTING,
+       __FM10K_DOWN,
+       __FM10K_SERVICE_SCHED,
+       __FM10K_SERVICE_DISABLE,
+       __FM10K_MBX_LOCK,
+       __FM10K_LINK_DOWN,
+       __FM10K_UPDATING_STATS,
+       /* This value must be last and determines the BITMAP size */
+       __FM10K_STATE_SIZE__,
+};
+
 struct fm10k_intfc {
        unsigned long active_vlans[BITS_TO_LONGS(VLAN_N_VID)];
        struct net_device *netdev;
        struct fm10k_l2_accel *l2_accel; /* pointer to L2 acceleration list */
        struct pci_dev *pdev;
-       unsigned long state;
+       DECLARE_BITMAP(state, __FM10K_STATE_SIZE__);
 
        /* Access flag values using atomic *_bit() operations */
        DECLARE_BITMAP(flags, __FM10K_FLAGS_SIZE__);
        u16 vid;
 };
 
-enum fm10k_state_t {
-       __FM10K_RESETTING,
-       __FM10K_DOWN,
-       __FM10K_SERVICE_SCHED,
-       __FM10K_SERVICE_DISABLE,
-       __FM10K_MBX_LOCK,
-       __FM10K_LINK_DOWN,
-       __FM10K_UPDATING_STATS,
-};
-
 static inline void fm10k_mbx_lock(struct fm10k_intfc *interface)
 {
        /* busy loop if we cannot obtain the lock as some calls
         * such as ndo_set_rx_mode may be made in atomic context
         */
-       while (test_and_set_bit(__FM10K_MBX_LOCK, &interface->state))
+       while (test_and_set_bit(__FM10K_MBX_LOCK, interface->state))
                udelay(20);
 }
 
 {
        /* flush memory to make sure state is correct */
        smp_mb__before_atomic();
-       clear_bit(__FM10K_MBX_LOCK, &interface->state);
+       clear_bit(__FM10K_MBX_LOCK, interface->state);
 }
 
 static inline int fm10k_mbx_trylock(struct fm10k_intfc *interface)
 {
-       return !test_and_set_bit(__FM10K_MBX_LOCK, &interface->state);
+       return !test_and_set_bit(__FM10K_MBX_LOCK, interface->state);
 }
 
 /* fm10k_test_staterr - test bits in Rx descriptor status and error fields */
 
 
 void fm10k_service_event_schedule(struct fm10k_intfc *interface)
 {
-       if (!test_bit(__FM10K_SERVICE_DISABLE, &interface->state) &&
-           !test_and_set_bit(__FM10K_SERVICE_SCHED, &interface->state))
+       if (!test_bit(__FM10K_SERVICE_DISABLE, interface->state) &&
+           !test_and_set_bit(__FM10K_SERVICE_SCHED, interface->state))
                queue_work(fm10k_workqueue, &interface->service_task);
 }
 
 static void fm10k_service_event_complete(struct fm10k_intfc *interface)
 {
-       WARN_ON(!test_bit(__FM10K_SERVICE_SCHED, &interface->state));
+       WARN_ON(!test_bit(__FM10K_SERVICE_SCHED, interface->state));
 
        /* flush memory to make sure state is correct before next watchog */
        smp_mb__before_atomic();
-       clear_bit(__FM10K_SERVICE_SCHED, &interface->state);
+       clear_bit(__FM10K_SERVICE_SCHED, interface->state);
 }
 
 /**
        /* put off any impending NetWatchDogTimeout */
        netif_trans_update(netdev);
 
-       while (test_and_set_bit(__FM10K_RESETTING, &interface->state))
+       while (test_and_set_bit(__FM10K_RESETTING, interface->state))
                usleep_range(1000, 2000);
 
        rtnl_lock();
 
        rtnl_unlock();
 
-       clear_bit(__FM10K_RESETTING, &interface->state);
+       clear_bit(__FM10K_RESETTING, interface->state);
 
        return err;
 err_open:
 
        rtnl_unlock();
 
-       clear_bit(__FM10K_RESETTING, &interface->state);
+       clear_bit(__FM10K_RESETTING, interface->state);
 
        return err;
 }
        struct fm10k_hw *hw = &interface->hw;
        s32 err;
 
-       if (test_bit(__FM10K_LINK_DOWN, &interface->state)) {
+       if (test_bit(__FM10K_LINK_DOWN, interface->state)) {
                interface->host_ready = false;
                if (time_is_after_jiffies(interface->link_down_event))
                        return;
-               clear_bit(__FM10K_LINK_DOWN, &interface->state);
+               clear_bit(__FM10K_LINK_DOWN, interface->state);
        }
 
        if (test_bit(FM10K_FLAG_SWPRI_CONFIG, interface->flags)) {
        int i;
 
        /* ensure only one thread updates stats at a time */
-       if (test_and_set_bit(__FM10K_UPDATING_STATS, &interface->state))
+       if (test_and_set_bit(__FM10K_UPDATING_STATS, interface->state))
                return;
 
        /* do not allow stats update via service task for next second */
        net_stats->rx_errors = rx_errors;
        net_stats->rx_dropped = interface->stats.nodesc_drop.count;
 
-       clear_bit(__FM10K_UPDATING_STATS, &interface->state);
+       clear_bit(__FM10K_UPDATING_STATS, interface->state);
 }
 
 /**
 static void fm10k_watchdog_subtask(struct fm10k_intfc *interface)
 {
        /* if interface is down do nothing */
-       if (test_bit(__FM10K_DOWN, &interface->state) ||
-           test_bit(__FM10K_RESETTING, &interface->state))
+       if (test_bit(__FM10K_DOWN, interface->state) ||
+           test_bit(__FM10K_RESETTING, interface->state))
                return;
 
        if (interface->host_ready)
        int i;
 
        /* If we're down or resetting, just bail */
-       if (test_bit(__FM10K_DOWN, &interface->state) ||
-           test_bit(__FM10K_RESETTING, &interface->state))
+       if (test_bit(__FM10K_DOWN, interface->state) ||
+           test_bit(__FM10K_RESETTING, interface->state))
                return;
 
        /* rate limit tx hang checks to only once every 2 seconds */
                        FM10K_PFVTCTL_FTAG_DESC_ENABLE);
 
        /* Initialize XPS */
-       if (!test_and_set_bit(__FM10K_TX_XPS_INIT_DONE, &ring->state) &&
+       if (!test_and_set_bit(__FM10K_TX_XPS_INIT_DONE, ring->state) &&
            ring->q_vector)
                netif_set_xps_queue(ring->netdev,
                                    &ring->q_vector->affinity_mask,
        int i;
 
        /* if interface is down do nothing */
-       if (test_bit(__FM10K_DOWN, &interface->state))
+       if (test_bit(__FM10K_DOWN, interface->state))
                return;
 
        for (i = 0; i < interface->num_q_vectors; i++)
        if (eicr & FM10K_EICR_SWITCHNOTREADY) {
                /* force link down for at least 4 seconds */
                interface->link_down_event = jiffies + (4 * HZ);
-               set_bit(__FM10K_LINK_DOWN, &interface->state);
+               set_bit(__FM10K_LINK_DOWN, interface->state);
 
                /* reset dglort_map back to no config */
                hw->mac.dglort_map = FM10K_DGLORTMAP_NONE;
        if (!err && hw->swapi.status) {
                /* force link down for a reasonable delay */
                interface->link_down_event = jiffies + (2 * HZ);
-               set_bit(__FM10K_LINK_DOWN, &interface->state);
+               set_bit(__FM10K_LINK_DOWN, interface->state);
 
                /* reset dglort_map back to no config */
                hw->mac.dglort_map = FM10K_DGLORTMAP_NONE;
        hw->mac.ops.update_int_moderator(hw);
 
        /* enable statistics capture again */
-       clear_bit(__FM10K_UPDATING_STATS, &interface->state);
+       clear_bit(__FM10K_UPDATING_STATS, interface->state);
 
        /* clear down bit to indicate we are ready to go */
-       clear_bit(__FM10K_DOWN, &interface->state);
+       clear_bit(__FM10K_DOWN, interface->state);
 
        /* enable polling cleanups */
        fm10k_napi_enable_all(interface);
        int err, i = 0, count = 0;
 
        /* signal that we are down to the interrupt handler and service task */
-       if (test_and_set_bit(__FM10K_DOWN, &interface->state))
+       if (test_and_set_bit(__FM10K_DOWN, interface->state))
                return;
 
        /* call carrier off first to avoid false dev_watchdog timeouts */
        fm10k_update_stats(interface);
 
        /* prevent updating statistics while we're down */
-       while (test_and_set_bit(__FM10K_UPDATING_STATS, &interface->state))
+       while (test_and_set_bit(__FM10K_UPDATING_STATS, interface->state))
                usleep_range(1000, 2000);
 
        /* skip waiting for TX DMA if we lost PCIe link */
        memcpy(interface->rssrk, rss_key, sizeof(rss_key));
 
        /* Start off interface as being down */
-       set_bit(__FM10K_DOWN, &interface->state);
-       set_bit(__FM10K_UPDATING_STATS, &interface->state);
+       set_bit(__FM10K_DOWN, interface->state);
+       set_bit(__FM10K_UPDATING_STATS, interface->state);
 
        return 0;
 }
         * must ensure it is disabled since we haven't yet requested the timer
         * or work item.
         */
-       set_bit(__FM10K_SERVICE_DISABLE, &interface->state);
+       set_bit(__FM10K_SERVICE_DISABLE, interface->state);
 
        err = fm10k_mbx_request_irq(interface);
        if (err)
        fm10k_iov_configure(pdev, 0);
 
        /* clear the service task disable bit to allow service task to start */
-       clear_bit(__FM10K_SERVICE_DISABLE, &interface->state);
+       clear_bit(__FM10K_SERVICE_DISABLE, interface->state);
 
        return 0;
 
 
        del_timer_sync(&interface->service_timer);
 
-       set_bit(__FM10K_SERVICE_DISABLE, &interface->state);
+       set_bit(__FM10K_SERVICE_DISABLE, interface->state);
        cancel_work_sync(&interface->service_task);
 
        /* free netdev, this may bounce the interrupts due to setup_tc */
         * stopped. We stop the watchdog task until after we resume software
         * activity.
         */
-       set_bit(__FM10K_SERVICE_DISABLE, &interface->state);
+       set_bit(__FM10K_SERVICE_DISABLE, interface->state);
        cancel_work_sync(&interface->service_task);
 
        fm10k_prepare_for_reset(interface);
 
        /* force link to stay down for a second to prevent link flutter */
        interface->link_down_event = jiffies + (HZ);
-       set_bit(__FM10K_LINK_DOWN, &interface->state);
+       set_bit(__FM10K_LINK_DOWN, interface->state);
 
        /* clear the service task disable bit to allow service task to start */
-       clear_bit(__FM10K_SERVICE_DISABLE, &interface->state);
+       clear_bit(__FM10K_SERVICE_DISABLE, interface->state);
        fm10k_service_event_schedule(interface);
 
        return err;