RE: [PATCH 13/15] qla4xxx: Added bsg support

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

 



>-----Original Message-----
>From: James Bottomley [mailto:James.Bottomley@xxxxxxx]
>Sent: Saturday, June 12, 2010 3:38 PM
>To: Mike Christie
>Cc: Vikas Chaudhary; linux-scsi@xxxxxxxxxxxxxxx; Ravi Anand
>Subject: Re: [PATCH 13/15] qla4xxx: Added bsg support
>
>On Fri, 2010-06-11 at 19:23 -0500, Mike Christie wrote:
>> On 06/11/2010 02:49 AM, Vikas Chaudhary wrote:
>> > Added BSG support to enable application support to configure
>> > ISP40XX/ISP82XX adapter.
>> >
>> > This patch is on top of: http://marc.info/?l=linux-
>scsi&m=126999297630764&w=2
>> >
>>
>> Did James say that using vendor specific commands was ok? I did not see
>> anything on the list.
>
>In principle, the point about vendor specific host commands has already
>been conceded ... lpfc and qla2xxx already use them.
>
>I think the real rule is that for host specific BSG commands, it's only
>for stuff that's specific to the host ... so not stuff which should be
>done generically.
>
>There are no hard and fast rules for applying the test above.  In
>theory, the management interfaces exposed by FC_BSG_HST_VENDOR could be
>used to send commands ... but it tends to get tolerated as long as the
>drivers support the standardised rport commands.
>
>If I look at what the qla4xxx interface would do
>
>     1. it only supports vendor specific commands ... this is a bit of a
>        red flag since it's proposing to do nothing in a vendor neutral
>        way.  This one, I punt back to you: what should an iscsi device
>        implementing BSG support of the standard commands (which have
>        only very recently been proposed for definition)

That's not true. For ex : Look at the ping support we have added which other
iSCSI HBA vendors can use as well. Here's the thread : 
http://article.gmane.org/gmane.linux.scsi/59535

Also we are adding support in iSCSI transport for other stuff which we think
is the right interface to use. Here's the thread :
http://article.gmane.org/gmane.linux.scsi/59532

But the reason we are trying to implement most of the commands using vendor
specific way is because *setting up the card/configuration* related stuff
are communicated using mailbox command interface with our firmware which
do blob data transfer back and forth. Driver is basically funneling info 
back and forth between F/W and API in a blob format. So we need this to allow
end user's to configure the card using QLogic Application or *iscsiadm* in
future as we are migrating from ioctl interface to bsg/netlink/sysfs route
which will require API changes.

Additionally we are working on to add support in  libiscsi user space to
support qla4xxx which will manipulate this blob and hookup with Linux Native
*iscsiadm*  tool. Mike was OK with this approach as long as user space
iscsiadm support will be enabled. This is something we are working on
parallely as well. Here's the email thread where Mike responded and we pretty
much agreed to it :
http://article.gmane.org/gmane.linux.scsi/58849/match=qla4xxx+bsg


>     2. QL4_SET_FLASH looks a bit suspicious ... the only thing I think
>        you could really set from that is the mac addresses ... is this
>        so?

It's used for multiple purpose, for ex :-
	1. write firmware image to flash
	2. write target configuration to flash and make target persistent
	3. write firmware control block to flash
	4. write chap information to flash, etc..

>     3. the DDB commands seem to be for manipulating the end point
>        table ... which is basically the iscsi connection table ... does
>        manipulating that from BSG make sense?

For qla4xxx firmware establishes  Connection/Session and qla4xxx driver
works in session mode. We are using ddb commands here to establish
session with target.
Let us know if you have any suggestions over here.

>     4. What is ACB and IFCB?  It's undocumented

It is control block containing qla4xxx firmware related settings.

>     5. GET/SET_ISCSI_STAT seems to be statistics related by the name;
>        is it? if so, why not use the more standard statistics interface
>        in the iscsi transport class?
>

we added it via BSG using vendor command as it blob data transfer.
API interprets the data and displays the statistics. Driver is just a passthru.

>>  If he did, then instead of the patch above from
>> Jay, you want to use iscsi bsg patches that I sent that handle Tomos's
>> comments about not duplicating fc code. I sent the bsg lib to the list
>> and then in my tree on kernel.org I ported the fc drivers (those might
>> need a update for some patches James Smart recently sent). For those bsg
>> patches you will want to then also add the vendor specific command back.
>
>Agreed, having a standard way of doing bsg helps.

We will do patches again on top of bsg lib patches.

>
>James
>

��.n��������+%������w��{.n�����{������ܨ}���Ơz�j:+v�����w����ޙ��&�)ߡ�a����z�ޗ���ݢj��w�f



[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