Re: [PATCH 05/15] be2iscsi: Fix freeing CXN specific driver resources.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 03/11/2013 11:39 PM, jayamohank@xxxxxxxxx wrote:
> From: "Jayamohan.Kallickal" <jayamohan.kallickal@xxxxxxxxxx>
> 
>  Free CXN specific resource held by driver when login redirection
>  or connection retry happens. Login redirection was failing
>  because WRB/SGL were not allocated from the CID on which
>  doorbell was rung.
> 
> Signed-off-by: John Soni Jose <sony.john-n@xxxxxxxxxx>
> Signed-off-by: Jayamohan.Kallickal <jayamohan.kallickal@xxxxxxxxxx>
> ---
>  drivers/scsi/be2iscsi/be_iscsi.c |   15 +++++++++
>  drivers/scsi/be2iscsi/be_main.c  |   68 ++++++++++++++++++++++++++------------
>  drivers/scsi/be2iscsi/be_main.h  |    1 +
>  3 files changed, 62 insertions(+), 22 deletions(-)
> 
> diff --git a/drivers/scsi/be2iscsi/be_iscsi.c b/drivers/scsi/be2iscsi/be_iscsi.c
> index 1097fa2..a4eb610 100644
> --- a/drivers/scsi/be2iscsi/be_iscsi.c
> +++ b/drivers/scsi/be2iscsi/be_iscsi.c
> @@ -990,9 +990,24 @@ static void beiscsi_put_cid(struct beiscsi_hba *phba, unsigned short cid)
>  static void beiscsi_free_ep(struct beiscsi_endpoint *beiscsi_ep)
>  {
>  	struct beiscsi_hba *phba = beiscsi_ep->phba;
> +	struct beiscsi_conn *beiscsi_conn;
>  
>  	beiscsi_put_cid(phba, beiscsi_ep->ep_cid);
>  	beiscsi_ep->phba = NULL;
> +
> +	/**
> +	 * Check if any connection resource allocated by driver
> +	 * is to be freed.This case occurs when target redirection
> +	 * or connection retry is done.
> +	 **/
> +	if (!beiscsi_ep->conn)
> +		return;
> +
> +	beiscsi_conn = beiscsi_ep->conn;
> +	if (beiscsi_conn->login_in_progress) {
> +		beiscsi_free_mgmt_task_handles(beiscsi_conn);
> +		beiscsi_conn->login_in_progress = 0;
> +	}
>  }
>  
>  /**
> diff --git a/drivers/scsi/be2iscsi/be_main.c b/drivers/scsi/be2iscsi/be_main.c
> index 72e4052..22882cb 100644
> --- a/drivers/scsi/be2iscsi/be_main.c
> +++ b/drivers/scsi/be2iscsi/be_main.c
> @@ -4066,6 +4066,49 @@ static void beiscsi_clean_port(struct beiscsi_hba *phba)
>  }
>  
>  /**
> + * beiscsi_free_mgmt_task_handles()- Free driver CXN resources
> + * @beiscsi_conn: ptr to the conn to be cleaned up
> + *
> + * Free driver mgmt resources binded to CXN.
> + **/
> +void
> +beiscsi_free_mgmt_task_handles(struct beiscsi_conn *beiscsi_conn)
> +{
> +	struct beiscsi_io_task *io_task;
> +	struct beiscsi_hba *phba = beiscsi_conn->phba;
> +	struct hwi_wrb_context *pwrb_context;
> +	struct hwi_controller *phwi_ctrlr;
> +
> +	phwi_ctrlr = phba->phwi_ctrlr;
> +	pwrb_context = &phwi_ctrlr->wrb_context
> +		       [beiscsi_conn->beiscsi_conn_cid
> +		       - phba->fw_config.iscsi_cid_start];
> +	io_task = beiscsi_conn->task->dd_data;
> +
> +	if (io_task->pwrb_handle) {
> +		memset(io_task->pwrb_handle->pwrb, 0,
> +		       sizeof(struct iscsi_wrb));
> +		free_wrb_handle(phba, pwrb_context,
> +				io_task->pwrb_handle);
> +		io_task->pwrb_handle = NULL;
> +	}
> +
> +	if (io_task->psgl_handle) {
> +		spin_lock(&phba->mgmt_sgl_lock);

I think you need to do the bh locking here. In the beiscsi_free_ep path
the bhs will not be disabled.



--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]
  Powered by Linux