>-----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