struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
        struct iwl_context_info *ctxt_info;
        struct iwl_context_info_rbd_cfg *rx_cfg;
-       u32 control_flags = 0, rb_size;
+       u32 control_flags = 0, rb_size, cb_size;
        dma_addr_t phys;
        int ret;
 
                rb_size = IWL_CTXT_INFO_RB_SIZE_4K;
        }
 
-       WARN_ON(RX_QUEUE_CB_SIZE(iwl_trans_get_num_rbds(trans)) > 12);
+       cb_size = RX_QUEUE_CB_SIZE(iwl_trans_get_num_rbds(trans));
+       if (WARN_ON(cb_size > 12))
+               cb_size = 12;
+
        control_flags = IWL_CTXT_INFO_TFD_FORMAT_LONG;
-       control_flags |=
-               u32_encode_bits(RX_QUEUE_CB_SIZE(iwl_trans_get_num_rbds(trans)),
-                               IWL_CTXT_INFO_RB_CB_SIZE);
+       control_flags |= u32_encode_bits(cb_size, IWL_CTXT_INFO_RB_CB_SIZE);
        control_flags |= u32_encode_bits(rb_size, IWL_CTXT_INFO_RB_SIZE);
        ctxt_info->control.control_flags = cpu_to_le32(control_flags);