staging/rdma/hfi1: Change num_rcv_contexts to num_user_contexts and its meaning
authorSebastian Sanchez <sebastian.sanchez@intel.com>
Fri, 11 Dec 2015 13:44:48 +0000 (08:44 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 21 Dec 2015 22:00:17 +0000 (14:00 -0800)
num_rcv_contexts sets the number of user contexts, both receive and send.
Renaming it to num_user_contexts makes sense to reflect its true meaning.
When num_rcv_contexts is 0, the default behavior is the number of CPU
cores instead of 0 contexts. This commit changes the variable
num_rcv_contexts to num_user_contexts, and it also makes any negative
value for this variable default to the number of CPU cores, so if
num_user_contexts is set >= 0, the value will number of contexts.

Reviewed-by: Mike Marciniszyn <mike.marciniszyn@intel.com>
Signed-off-by: Sebastian Sanchez <sebastian.sanchez@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/rdma/hfi1/chip.c
drivers/staging/rdma/hfi1/hfi.h
drivers/staging/rdma/hfi1/init.c

index 371f13fec68da16696e381f0487acfa418e76cd5..ec4bac00dbdad2f23a718362570fbc5bc764223e 100644 (file)
@@ -12426,7 +12426,6 @@ fail:
 static int set_up_context_variables(struct hfi1_devdata *dd)
 {
        int num_kernel_contexts;
-       int num_user_contexts;
        int total_contexts;
        int ret;
        unsigned ngroups;
@@ -12463,12 +12462,10 @@ static int set_up_context_variables(struct hfi1_devdata *dd)
        }
        /*
         * User contexts: (to be fixed later)
-        *      - set to num_rcv_contexts if non-zero
-        *      - default to 1 user context per CPU
+        *      - default to 1 user context per CPU if num_user_contexts is
+        *        negative
         */
-       if (num_rcv_contexts)
-               num_user_contexts = num_rcv_contexts;
-       else
+       if (num_user_contexts < 0)
                num_user_contexts = num_online_cpus();
 
        total_contexts = num_kernel_contexts + num_user_contexts;
index 7aea874b3dfce6ae0c8aace260e852583d34813e..2611bb2e764d84ef354c8910f8554ae4ca49035c 100644 (file)
@@ -1665,7 +1665,7 @@ void update_sge(struct hfi1_sge_state *ss, u32 length);
 extern unsigned int hfi1_max_mtu;
 extern unsigned int hfi1_cu;
 extern unsigned int user_credit_return_threshold;
-extern uint num_rcv_contexts;
+extern int num_user_contexts;
 extern unsigned n_krcvqs;
 extern u8 krcvqs[];
 extern int krcvqsset;
index 467ff26bcab0ee9c6cbf90de867387025d47886e..7ad9eb1825142d4934a4b88a0d86f1a207b2c8bb 100644 (file)
  * Number of user receive contexts we are configured to use (to allow for more
  * pio buffers per ctxt, etc.)  Zero means use one user context per CPU.
  */
-uint num_rcv_contexts;
-module_param_named(num_rcv_contexts, num_rcv_contexts, uint, S_IRUGO);
+int num_user_contexts = -1;
+module_param_named(num_user_contexts, num_user_contexts, uint, S_IRUGO);
 MODULE_PARM_DESC(
-       num_rcv_contexts, "Set max number of user receive contexts to use");
+       num_user_contexts, "Set max number of user contexts to use");
 
 u8 krcvqs[RXE_NUM_DATA_VL];
 int krcvqsset;