From owner-freebsd-hackers Mon Aug 19 10:46:12 2002 Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.FreeBSD.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id AC7A837B400 for ; Mon, 19 Aug 2002 10:46:06 -0700 (PDT) Received: from smtp-relay-2.adobe.com (smtp-relay-2.adobe.com [192.150.11.2]) by mx1.FreeBSD.org (Postfix) with ESMTP id 37F7943E6A for ; Mon, 19 Aug 2002 10:46:06 -0700 (PDT) (envelope-from gardner.buchanan@adobe.com) Received: from inner-relay-1.corp.adobe.com (inner-relay-1 [153.32.1.51]) by smtp-relay-2.adobe.com (8.12.3/8.12.3) with ESMTP id g7JHhSvJ011850 for ; Mon, 19 Aug 2002 10:43:28 -0700 (PDT) Received: from rossini.can.adobe.com (rossini [172.16.2.28]) by inner-relay-1.corp.adobe.com (8.12.3/8.12.3) with ESMTP id g7JHkUuE011867 for ; Mon, 19 Aug 2002 10:46:30 -0700 (PDT) Received: by rossini.accelio.com with Internet Mail Service (5.5.2653.19) id ; Mon, 19 Aug 2002 13:45:55 -0400 Message-ID: From: Gardner Buchanan To: "'freebsd-hackers@freebsd.org'" Subject: CAM "wiring", LUNs and duplicate wired entries Date: Mon, 19 Aug 2002 13:45:52 -0400 MIME-Version: 1.0 X-Mailer: Internet Mail Service (5.5.2653.19) Content-Type: text/plain; charset="iso-8859-1" Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG Recently I've noticed that the SCSI ID "wiring" logic is missidentifying duplicate IDs with seperate LUNs as "duplicates": my kernel config says this: # Wired down SCSI unit numbers. # device scbus0 at sym0 device da0 at scbus0 target 3 unit 0 device cd0 at scbus0 target 3 unit 1 device da1 at scbus0 target 6 device da2 at scbus0 target 9 Here cd0 and da0 have the same bus and target, but are different LUNs. The probe messages look like this: Aug 18 17:26:38 akbar /kernel: FreeBSD 4.6-STABLE #7: Sat Aug 17 19:19:11 EDT 2002 ... Aug 18 17:26:39 akbar /kernel: Waiting 3 seconds for SCSI devices to settle Aug 18 17:26:39 akbar /kernel: (noperiph:sym0:0:-1:-1): SCSI BUS reset delivered Aug 18 17:26:39 akbar /kernel: (da0:sym0:0:3:0): Duplicate Wired Device entry! Aug 18 17:26:39 akbar /kernel: (da0:sym0:0:3:0): Second device (da device at scbus0 target 8 lun 0) will not be wired Aug 18 17:26:39 akbar /kernel: da3 at sym0 bus 0 target 8 lun 0 Aug 18 17:26:39 akbar /kernel: da3: Fixed Direct Access SCSI-2 device Aug 18 17:26:39 akbar /kernel: da3: 20.000MB/s transfers (10.000MHz, offset 15, 16bit), Tagged Queueing Enabled Aug 18 17:26:39 akbar /kernel: da3: 2050MB (4199760 512 byte sectors: 255H 63S/T 261C) Aug 18 17:26:39 akbar /kernel: da2 at sym0 bus 0 target 9 lun 0 Aug 18 17:26:39 akbar /kernel: da2: Fixed Direct Access SCSI-2 device Aug 18 17:26:39 akbar /kernel: da2: 40.000MB/s transfers (20.000MHz, offset 16, 16bit), Tagged Queueing Enabled Aug 18 17:26:39 akbar /kernel: da2: 4341MB (8890760 512 byte sectors: 255H 63S/T 553C) Aug 18 17:26:39 akbar /kernel: da1 at sym0 bus 0 target 6 lun 0 Aug 18 17:26:39 akbar /kernel: da1: Fixed Direct Access SCSI-2 device Aug 18 17:26:39 akbar /kernel: da1: 10.000MB/s transfers (10.000MHz, offset 15), Tagged Queueing Enabled Aug 18 17:26:39 akbar /kernel: da1: 1003MB (2054864 512 byte sectors: 64H 32S/T 1003C) Aug 18 17:26:39 akbar /kernel: Mounting root from ufs:/dev/da1s1a Aug 18 17:26:39 akbar /kernel: cd0 at sym0 bus 0 target 3 lun 1 Aug 18 17:26:39 akbar /kernel: cd0: Removable CD-ROM SCSI-2 device Aug 18 17:26:39 akbar /kernel: cd0: 5.000MB/s transfers (5.000MHz, offset 8) Aug 18 17:26:40 akbar /kernel: cd0: Attempt to query device size failed: NOT READY, Medium not present Aug 18 17:26:40 akbar /kernel: da0 at sym0 bus 0 target 3 lun 0 Aug 18 17:26:40 akbar /kernel: da0: Removable Optical SCSI-2 device Aug 18 17:26:40 akbar /kernel: da0: 5.000MB/s transfers (5.000MHz, offset 8) Aug 18 17:26:40 akbar /kernel: da0: Attempt to query device size failed: NOT READY, Medium not present As near as I can make out, the code in cam_periph.c doesn't take into account LUN when testing for duplicates. I seem to be getting the correct wired value though. My understanding is I should get cd1, rather than cd0, if the "wired" cd0 doesn't probe properly. Am I missing the boat on how wiring is meant to work? See you, Gardner Buchanan Adobe Systems Canada +1 613 751 4800 x5635 To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message