SCSI Subsystem에서 SCSI, USB, IEEE1394를 구별할 수 있는 방법

sungjin의 이미지

안녕하세요?

제가 알고 있기로는 USB나 IEEE1394외장 하드들은 SCSI subsystem에 등록이 되어서 /dev/sda, /dev/sdb 처럼 스카시 디스크로 인식되고, /dev/sda, /dev/sdb 를 마운트 해서 쓰면 되는 걸로 알고 있습니다.

그런데, 커널 2.4에서 SCSI 디스크와, USB 외장하드, IEEE외장하드가 동시에 연결되어 있으면, 각각 /dev/sda, /dev/sdb, /dev/sdc로 fdisk로 보일텐데,
/dev/sda -> SCSI
/dev/sdb -> USB
/dev/sdc -> IEEE1394
이런 식으로 각각의 디스크 디바이스가 어떤 인터페이스를 통해 사용되는 장치인지 알 수 있는 방법이 있을까요.

혹시나 해서 /proc/scsi/ 를 찾아보니 스카시 컨트롤러에 대한 정보에 보이고 컨트롤러에 연결된 디바이스가 /dev/sda 같이 연결되어 있다는 정보는 보이지가 않네요.

그럼 답변 좀 부탁드립니다.

ganadist의 이미지

커널 2.4에서는 /proc/scsi/scsi 와 /proc/scsi/스카시호스트이름-숫자 디렉토리에 있는 정보파일을 일일이 파싱해서 구분해야 합니다.
(그나마 스카시호스트 드라이버가 제대로 만들어졌을 경우입니다. 한마디로 생 노가다입니다 -.- )

커널 2.6의 sysfs를 이용하면 아주 간단하게 현재 scsi장치의 호스트가 어떤종류인지 알 수 있습니다.

----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러

sungjin의 이미지

답변 감사합니다.
2.6을 사용할 수 있으면 좋겠지만 그럴 상황이 못되서.

usb-storage 모듈이 올라간 상태에서 /proc/scsi를 살펴보면
제가 원하고자 하는 /dev/sda 디바이스로 인식되어 있는지
확인 할 수 있는 정보는 없더군요.

그럼 2.4에서는 방법이 없는 건가요?

ganadist의 이미지

/proc/scsi/scsi 에서
현재 scsi에 등록된 장치의 host, channel, id, lun을 알아낸뒤 이것으로 장치이름을 찾으면 됩니다.
그리고 /proc/scsi/호스트이름/숫자 에서 숫자가 host number입니다. 이것으로 장치의 해당 호스트의 형식을 알 수 있습니다.

----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러

sungjin의 이미지

ganadist wrote:
/proc/scsi/scsi 에서
현재 scsi에 등록된 장치의 host, channel, id, lun을 알아낸뒤 이것으로 장치이름을 찾으면 됩니다.

/proc/scsi/scsi 를 읽어서 host, channel, id, lun을 알아내고, 장치의 이름의 찾으면 된다는 말씀의 Attached된 SCSI 디바이스의 Vendor, Model을 말씀하시는 건가요?
다음과 같은 예에서는 IBM, DDYS-T18350N 뭐 이런 것 들요???
[root@Hancom scsi]# cat scsi 
Attached devices: 
Host: scsi0 Channel: 00 Id: 00 Lun: 00
  Vendor: IBM      Model: DDYS-T18350N     Rev: S96H
  Type:   Direct-Access                    ANSI SCSI revision: 03
Host: scsi1 Channel: 00 Id: 00 Lun: 00
  Vendor: IC25N020 Model: ATCS04-0         Rev: CA2O
  Type:   Direct-Access                    ANSI SCSI revision: 02

ganadist wrote:

그리고 /proc/scsi/호스트이름/숫자 에서 숫자가 host number입니다. 이것으로 장치의 해당 호스트의 형식을 알 수 있습니다.

그리고 알아된 host number를 이용하면 해당 SCSI 디바이스가 어떤 호스트 컨트롤러 SCSI 인지 USB-STORAGE인지는 알수 있지만 각각의 호스트 컨트롤러에 연결된 디스크가 sda 인지 sdb 인지 알 수 있는 방법은 없는지요.

ganadist의 이미지

sungjin wrote:

[root@Hancom scsi]# cat scsi 
Attached devices: 
Host: scsi0 Channel: 00 Id: 00 Lun: 00
  Vendor: IBM      Model: DDYS-T18350N     Rev: S96H
  Type:   Direct-Access                    ANSI SCSI revision: 03
Host: scsi1 Channel: 00 Id: 00 Lun: 00
  Vendor: IC25N020 Model: ATCS04-0         Rev: CA2O
  Type:   Direct-Access                    ANSI SCSI revision: 02


여기서 "Host: scsi0 Channel: 00 Id: 00 Lun: 00" 이것으로 Guessing을 하는수 밖에 없습니다. 이 장치가 disk인지 cdrom인지 tape인지는 여기서 전혀 알 수가 없습니다. 어쨋든 이 번호순서대로 장치이름이 배정되기 때문에 적당히 추정하는수 밖에요.

그나마 조금 나은 방법이라면 devfs로 추적하는 것일겁니다. devfs에서는 scsi/host?/bus?/target?/lun?/xxxx 로 지정되어있기 때문에 해당 장치노드가 이런파일로 링크되어있는지 살펴보고 링크이름을 파싱하는수는 있을것입니다.

----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러

sungjin의 이미지

계속 답변을 올려주셔서 많은 도움이 되고 있습니다.

Quote:

여기서 "Host: scsi0 Channel: 00 Id: 00 Lun: 00" 이것으로 Guessing을 하는수 밖에 없습니다. 이 장치가 disk인지 cdrom인지 tape인지는 여기서 전혀 알 수가 없습니다. 어쨋든 이 번호순서대로 장치이름이 배정되기 때문에 적당히 추정하는수 밖에요.

위의 말씀이 잘 이해가 안가는 군요.
Guessing 하신다고 하셨는데, 구체적으로 무엇을 Guessing해야 하는 지 모르겠습니다.
host, channel, id, lun 값으로 무엇을 Guessing 할수 있나요.
만약, scsi0 Channel:00 Id:00 Lun:00, scsi0 Channel:00 Id:01 Lun:00, scsi1 Channel:00 Id:00 Lun:00 이 있다고 가정한다면
scsi0 Channel:00 Id:00 Lun:00 -> /dev/sda
scsi0 Channel:00 Id:01 Lun:00 -> /dev/sdb
scsi1 Channel:00 Id:00 Lun:00 -> /dev/sdc
이렇게 추측해야 한다는 이야기 인지요.
죄송한데 다시한번 자세한 답변 좀 부탁드립니다.
ganadist의 이미지

sungjin wrote:

scsi0 Channel:00 Id:00 Lun:00 -> /dev/sda
scsi0 Channel:00 Id:01 Lun:00 -> /dev/sdb
scsi1 Channel:00 Id:00 Lun:00 -> /dev/sdc

문제는 scsi0 Channel:00 Id:00 Lun:00 장치가 disc가 아닐수 도 있습니다. (cdrom이라던가 tape라던가)
이럴 때에는 그다음 장치인 scsi0 Channel:00 Id:01 Lun:00 가 /dev/sda가 될 수도 있다는 이야기이죠.

그래서 제가 꼭 집어서 "scsi0 Channel:00 Id:00 Lun:00 가 /dev/sda 이다" 말씀을 못드리고 Guessing해야 한다고 표현한 것입니다.

만약 devfs, devfsd 콤비네이션을 쓰신다면 /dev/sda가 가르키는 링크로 부터
호스트, 채널, id, lun을 알아내어서 /proc/scsi/scsi 와 /proc/scsi/*/? 파일로부터 해당 장치가 어느쪽에 물려있는지 위의 방법보다 좀 더 정확히 알 수 있을 것입니다.

그래도 제일 편한방법은 커널 2.6의 sysfs, hal 콤비네이션이겠군요 ;;

----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러

ganadist의 이미지

아. totem의 소스를 훔쳐보다보니 /proc/scsi/sg/devices 를 파싱해서 쓰고 있네요.

각각의 한 줄은 host_no, channel, scsi_id, scsi_lun, scsi_type, access_count, queue_depth, device_busy, online 을 가르키고있습니다.

scsi_type의 1번이면 disc이고요. 여기에 등록된 대로 sda, sdb, sdc 이런식으로 배정하면 될껍니다.

----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러

sungjin의 이미지

좋은 정보에 감사드립니다.
totem 이라는 프로그램은 어떤 프로그램이고, 어디서 구할 수 있는지
알려주시면 더욱 고마울 것 같습니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.