From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751852AbcFUKwm (ORCPT ); Tue, 21 Jun 2016 06:52:42 -0400 Received: from szxga01-in.huawei.com ([58.251.152.64]:8801 "EHLO szxga01-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751432AbcFUKwN (ORCPT ); Tue, 21 Jun 2016 06:52:13 -0400 Subject: Re: [PATCH v10 06/22] IB/hns: Add initial cmd operation To: , Lijun Ou References: <1466087730-54856-1-git-send-email-oulijun@huawei.com> <1466087730-54856-7-git-send-email-oulijun@huawei.com> <20160620133310.GB4526@leon.nu> CC: , , , , , , , , , , , , , , , , , From: "Wei Hu (Xavier)" Message-ID: <57691C0B.8090509@huawei.com> Date: Tue, 21 Jun 2016 18:50:51 +0800 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:38.0) Gecko/20100101 Thunderbird/38.5.1 MIME-Version: 1.0 In-Reply-To: <20160620133310.GB4526@leon.nu> Content-Type: text/plain; charset="windows-1252"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.57.115.113] X-CFilter-Loop: Reflected X-Mirapoint-Virus-RAPID-Raw: score=unknown(0), refid=str=0001.0A090204.57691C18.006A,ss=1,re=0.000,recu=0.000,reip=0.000,cl=1,cld=1,fgs=0, ip=0.0.0.0, so=2013-06-18 04:22:30, dmn=2013-03-21 17:37:32 X-Mirapoint-Loop-Id: 58f71c7169d434af9c552e143372fa81 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2016/6/20 21:33, Leon Romanovsky wrote: > On Thu, Jun 16, 2016 at 10:35:14PM +0800, Lijun Ou wrote: >> This patch added the operation for cmd, and added some functions >> for initializing eq table and selecting cmd mode. >> >> Signed-off-by: Wei Hu >> Signed-off-by: Nenglong Zhao >> Signed-off-by: Lijun Ou >> --- >> PATCH v9/v8/v7/v6: >> - No change over the PATCH v5 >> >> PATCH v5: >> - The initial patch which was redesigned based on the second patch >> in PATCH v4 >> --- > <...> > >> +#define CMD_MAX_NUM 32 >> + >> +int hns_roce_cmd_init(struct hns_roce_dev *hr_dev) >> +{ >> + struct device *dev = &hr_dev->pdev->dev; >> + >> + mutex_init(&hr_dev->cmd.hcr_mutex); >> + sema_init(&hr_dev->cmd.poll_sem, 1); >> + hr_dev->cmd.use_events = 0; >> + hr_dev->cmd.toggle = 1; >> + hr_dev->cmd.max_cmds = CMD_MAX_NUM; > <...> > >> + for (hr_cmd->token_mask = 1; hr_cmd->token_mask < hr_cmd->max_cmds; >> + hr_cmd->token_mask <<= 1) >> + ; >> + --hr_cmd->token_mask; > It doesn't look that you dynamically change max_cmds supported. > Why do you need to calculate token_mask dynamically? Hi, Leon 1. The four lines above are in the function named hns_roce_cmd_use_events. and now this function is only called once in hns_roce_probe. 2. In hns_roce_cmd_use_events, we use these 4 lines to achieve the value of hr_cmd->token_mask according to hr_cmd->max_cmds dynamically, then we only define one marco for hr_cmd->max_cmds as below: #define CMD_MAX_NUM 32 And it looks more flexible. Regards Wei Hu