리눅스로 부팅 후, 휴대폰을 컴퓨터에 연결 하고 나서 dmesg 의 내용중 휴대폰 관련 부분을 볼 수 있습니다.
freecatz@freecatz-linux:~$ dmesg | tail [ 290.445255] scsi6 : usb-storage 2-5:1.6 [ 290.446204] usbcore: registered new interface driver usb-storage [ 290.446216] USB Mass Storage support registered. [ 290.458458] cdc_acm 2-5:1.0: Zero length descriptor references [ 290.458482] cdc_acm: probe of 2-5:1.0 failed with error -22 [ 290.458778] usbcore: registered new interface driver cdc_acm [ 290.458789] cdc_acm: v0.26:USB Abstract Control Model driver for USB modems and ISDN adapters [ 291.446094] scsi 6:0:0:0: Direct-Access SKY Mass storage ffff PQ: 0 ANSI: 2 [ 291.447739] sd 6:0:0:0: Attached scsi generic sg2 type 0 [ 291.453288] sd 6:0:0:0: [sdb] Attached SCSI removable disk
저는 SKY 의 IM-A690L 이라는 휴대폰(나오자 마자 보급용 폰이 된 비운의 폰) 을 사용중이라서 위와 같이 나왔습니다. 위의 메시지 중에서 자세히 보셔야 할 부분은 여러분의 안드로이드 폰이 어느 장치 설정이 되느냐 입니다. 저는 sdb 로 되었으 나, 사용 하시는 운영체제나 휴대폰에 따라 USB 등으로 잡히는 경우도 있습니다. 해당 휴대폰이 USB 로 잡히는 경우 usb 라고 기억해 두시면 됩니다. 이제 휴대폰과 컴퓨터 사이에 연결된 인터페이스인 USB 장치의 VID 와 PID 를 알아 내기 위해 lsusb 라는 명령을 실행 합니다.
freecatz@freecatz-linux:~$ lsusb Bus 004 Device 002: ID 1241:1503 Belkin Keyboard Bus 004 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub Bus 003 Device 005: ID 0cf3:3002 Atheros Communications, Inc. Bus 003 Device 003: ID 046d:08ad Logitech, Inc. QuickCam Communicate STX Bus 003 Device 002: ID 192f:0416 Avago Technologies, Pte. Bus 003 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub Bus 002 Device 003: ID 10a9:1104 SK Teletech Co., Ltd Bus 002 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
제 휴대폰은 LGU+ 를 하용하는데 왜 SK Teletech 로 나와 있는지는 모르겠으나, 일단 휴대폰과 관련된 USB 장치는 하나 뿐이라 Bus 002 Device 003: ID 10a9:1104 SK Teletech Co., Ltd 의 정보중 PID 는 10a9 으로 그리고 VID 는 1104 이라고 판단 하였습니다. PID 와 VID 를 쉽게 알 수 있는 윈도즈용 유틸리티도 있습니다. lsusb 명령으로 PID 와 VID 를 알아낼 수 없는 경우 윈도즈로 부팅 후, USB 의 PID 와 VID를 알아낼 수 있는 유틸리티 등을 이용 하여 PID 와 VID 를 알아내시고 다음 단계로 진행 하셔도 됩니다. 리눅스에서는 PID 나 VID 를 알아내는 다른 유틸리티를 몰라서 알아 보고 있는 중입니다.
udev 를 이용 하기위해 이제 root 의 권한으로 /etc/udev/rules.d/ 디렉터리 아래 파일을 하나 만들어 줍니다. 파일은 두자리의 숫자로 시작 되어야 합니다. 9x 번의 숫자를 사용 하시면 됩니다. 아니면, 저 처럼 그냥 99를 사용 하셔도 괜찮고요. 저는 파일 이 름을 99-SKY-android.rules 로 정했습니다. SUBSYSTEM 의 장치명은 dmesg 에서 확인된 장치명을 기입하여 주세요.
root@freecatz-linux:~# vi /etc/udev/rules.d/99-SKY-android.rules
위의 두 줄이 99-SKY-android.rules 파일의 내용 입니다. 이때 lsusb 명령으로 알아낸 USB 장치의 PID 와 VID 를 넣어 주서야 합니다. idVendor 는 VID 를, idProduct 는 PID를 입력 하여 주시고, OWNER 는 여러분이 사용 하시는 일반 유저의 계정을 입력 하여 주시면 됩니다. 저는 제 시스템에서 freecatz 라는 계정을 사용 하므로 freecatz 라고 작성 하였습니다. 만약 개인 사용자가 아닌 그룹을 지정 하고 싶으시다면, OWNER 대신 GROUP 을 사용 할 수 있습니다.
root@freecatz-linux:~# restart udev udev start/running, process 2180 이제 root 권한으로 udev 를 다시 실행 하여 변경된 rules 파일(위에서 만들었던 99-SKY-android.rules 파일) 의 내용을 적용 하여야 합니다. (참고 : 앞의 두자리 숫자가 룰파일을 읽어 들이는 순서 입니다.)
root@freecatz-linux:~# cd /home/freecatz/eclipse/android-sdk-linux_x86/platform-tools/ udev 가 다시 실행 이 되고 나면, 안드로이드 SDK 의 압축이 풀려진 디렉터리 아래 adb 라는 도구가 있는 위치로 이동 합니다. (참고 : 저는 나중에 귀찮아서 ADB_HOME 변수를 등록 하고 PATH 에 추가 했습니다.)
root@freecatz-linux:/home/freecatz/eclipse/android-sdk-linux_x86/platform-tools# adb kill-server adb 명령을 이용 하여 서버를 중지 시킵니다.
root@freecatz-linux:/home/freecatz/eclipse/android-sdk-linux_x86/platform-tools# adb start-server * daemon not running. starting it now on port 5037 * * daemon started successfully * adb 명령을 이용 하여 서버를 시작 합니다.
root@freecatz-linux:/home/freecatz/eclipse/android-sdk-linux_x86/platform-tools# adb devices List of devices attached
emulator-5554 device EF13L01110142016217 device
adb 명령을 이용 하여 연결된 장치의 정보를 출력해 봅니다. 저는 EF13L01110142016217 이름의 장치가 연결 되어 있군요.
freecatz@freecatz-linux:~$ adb devices List of devices attached
emulator-5554 device EF13L01110142016217 device
일반 유저의 계정으로(위에서 만든 rules 파일에 OWNER 의 사용자 이름) adb 명령을 이용하여 연결된 장치를 보니,
root 유저와 동일 하게 EF13L01110142016217 라는 이름의 장치가 연결 되어 있군요.
root@raspberrypi:~# whoami root # 불필요 하지만 권한을 확인해 봤습니다.
root@raspberrypi:~# mkdir shared # 윈도즈 공유 디렉터리를 마운트할 디렉터리를 라즈베리 파이에 생성 합니다. 디렉터리 이름은 편하신 걸로 하시면 됩니다.
root@raspberrypi:~# ls shared/ # 당연히 지금 만든 디렉터리니 아무 것도 없겠죠.
root@raspberrypi:~# smbmount '\\192.168.0.169\shared' ./shared/ -o username=freecatz,password=********,uid=pi # 192.168.0.169 의 윈도즈 시스템에서 shared 이름으로 공유된 디렉터리를 ./shared 에 mount 합니다. 이때 윈도즈의 공유된 디렉터리에 접근 할 수 있는 계정과 비밀번호가 필요 하며, uid 옵션으로 라즈베리 파이에 생성된 특정 계정의 사용자가 사용 할 수 있도록 합니다. 여기서는 pi 사용자가 되겠네요.
root@raspberrypi:~# ls shared/ hello_world.txt # 윈도즈 공유 디렉터리에 hello_world.txt 파일이 있습니다.
root@raspberrypi:~# cat shared/hello_world.txt
hello world!!
# 파일의 내용은 보니, hello world!! 라는 문자열이 있네요. 필요시 pi 사용자 계정으로 해당 파일을 수정 할 수 도 있습니다.
root@raspberrypi:~# umount ./shared/ # 공유 디렉터리를 다 사용 하고 사용할 일이 없다면, umount 명령으로 공유 해제 합니다.
root@raspberrypi:~# ls ./shared/ root@raspberrypi:~#
참고 : 다음과 같이 mount 명령으로도 윈도즈의 공유 폴더를 마운트 할 수 있습니다.
root@raspberrypi:~# mount -t cifs '\\192.168.0.169\shared' ./shared/ -o username=freecatz,password= ********,uid=pi
root@raspberrypi:~# umount ./shared/ # umount 명령으로 공유 해제 합니다.
본인의 경우 내부 네트워크의 다른 컴퓨터에서 putty 나 Xshell 등의 ssh 클라이언트
를 이용하여 라즈베리 파이의 IP 주소로 접속을 하였다.
참고 : 최초 부팅후 별다른 설정을 하지 않았다면, iptables 가 올라가 있지 않은 상태.
6. SSH 데몬 자동 시작을 위한 chkconfig 패키지 설치
데비안 리눅스의 경우 기본적으로 패키지 관리자를 apt-get 을 사용 한다.
root@raspberrypi:/home/pi# apt-cache search chkconfig chkconfig - system tool to enable or disable system services
root@raspberrypi:/home/pi# apt-get install chkconfig
Reading package lists... Done Building dependency tree Reading state information... Done The following NEW packages will be installed: chkconfig 0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded. Need to get 9,182 B of archives. After this operation, 69.6 kB of additional disk space will be used. Get:1 http://ftp.uk.debian.org/debian/ squeeze/main chkconfig all 11.0-79.1-2 [9,182 B] Fetched 9,182 B in 1s (5,276 B/s) Selecting previously deselected package chkconfig. (Reading database ... 46441 files and directories currently installed.) Unpacking chkconfig (from .../chkconfig_11.0-79.1-2_all.deb) ... Processing triggers for man-db ... Setting up chkconfig (11.0-79.1-2) ... root@raspberrypi:/home/pi#