[완료]zd1211 무선랜을 arm 용 리눅스에 포팅 에러
보드는 S3C2440 이고 커널 2.6.30을 포팅하여
USB로 된 무선랜 zd1211을 사용하려고 합니다.
예전글을 참조하여 다음과 같은 작업하였습니다.
http://kldp.org/node/92230
1. busybox에 mdev 지원하도록 컴파일
2. mdev.conf 작성 (usbdev[0-9].[0-9] root:root 0660 */etc/mdev/firmware.sh)
firmware.sh를 적절하게 수정해야 할 것같은데 방법을 모르겠습니다.
"udev firmware loader misses sysfs directory"
이런 에러메시지만 계속 나오네요.
firmware.sh 수정 방법이나 펌웨어를 인식하게 할 방법 조언 바랍니다.
firmware.sh 내용
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
#!/bin/sh -e
FIRMWARE_DIRS="/lib/firmware/$(uname -r) /lib/firmware"
err() {
echo "$@" >&2
logger -t "${0##*/}[$$]" "$@" 2>/dev/null || true
}
if [ ! -e /sys$DEVPATH/loading ]; then
err "udev firmware loader misses sysfs directory"
exit 1
fi
for DIR in $FIRMWARE_DIRS; do
[ -e "$DIR/$FIRMWARE" ] || continue
echo 1 > /sys$DEVPATH/loading
cat "$DIR/$FIRMWARE" > /sys$DEVPATH/data
echo 0 > /sys$DEVPATH/loading
exit 0
done
echo -1 > /sys$DEVPATH/loading
err "Cannot find firmware file '$FIRMWARE'"
mkdir -p /dev/.udev/firmware-missing
file=$(echo "$FIRMWARE" | sed 's:/:\\x2f:g')
ln -s -f "$DEVPATH" /dev/.udev/firmware-missing/$file
exit 1
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
/sys 에 sysfs 를 mount
/sys 에 sysfs 를 mount 해야 합니다.
그리고,
busybox 1.14 이후의 mdev 에선 /lib/firmware/ 에 파일만 넣어두면 mdev 스스로 해결합니다.
(MDEV_LOAD_FIRMWARE 가 busybox config 에서 활성화되어 있다면 말이죠)
http://git.busybox.net/busybox/tree/util-linux/mdev.c?h=1_14_stable#n378
OTL
추가 조언 바랍니다~
busybox 1.15.2 이고 menuconfig에서 MDEV_LOAD_FIRMWARE를 비롯해 MDEV과련한 것들은
모두 체크하였습니다.
/sys에 sysfs mount하였습니다.
다만 mdev.conf를 어떻게 수정해야할 지 잘 모르겠고
쉘 스크립트 작성을 어떻게 해야할지 모르겠습니다.
1.mdev.conf
usbdev[0-9].[0-9] root:root 0660
0660 뒤에 뭔가 추가적으로 해야할듯 한데 잘 모르겠습니다.
2. 쉘 스크립트는 어떻게 해야 할지 모르겠습니다. 어떤 글에는 스크립트가 필요없다는 얘기도 있고...
3. 에러 메시지
usb 1-1: new full speed USB device using s3c2410-ohci and address 17
usb 1-1: configuration #1 chosen from 1 choice
usb 1-1: reset full speed USB device using s3c2410-ohci and address 17
usb 1-1: firmware: requesting ar9170-1.fw
usb 1-1: file with init values not found.
ar9170usb: probe of 1-1:1.0 failed with error -2
usb에 꼽으면 약 1분후에 펌웨어 파일 못 찾겠다고 나옵니다.
분명히 /lib/firmware에 있습니다.
알려주신 mdev.c 소프파일중
/* Hotplug:
* env ACTION=... DEVPATH=... SUBSYSTEM=... [SEQNUM=...] mdev
* ACTION can be "add" or "remove"
* DEVPATH is like "/block/sda" or "/class/input/mice"
*/
action = getenv("ACTION");
env_path = getenv("DEVPATH");
subsystem = getenv("SUBSYSTEM");
if (!action || !env_path /*|| !subsystem*/)
bb_show_usage();
fw = getenv("FIRMWARE");
ACTION, DEVPATH, SUBSYSTEM, FIRMWARE에 관하여 제가 작성한 부분이 전혀 없는데
그것때문에 환경변수를 못 가져와서 문제가 생기는 것으로 추측되는데... 조언 바랍니다.
해결은 했습니다...
혼자 질문하고 혼자 해결하네요...
정리 차원에서 글 남깁니다.
포기하는 심정으로 USB에 무선랜카드 꼽으니까 바로 펌웨어 인식하네요.
제가사용하는 보드(S3C2440)에 순간적으로 약간 문제가 있었나봅니다.
리셋후에 동작이 이상하길래 커널, 루트파일시스템 다시 로딩하고 무선랜카드
꼽으니까 정상동작합니다. 이후 리셋등 몇번이고 반복 테스트 해봤고...
심지어는 mdev.conf 파일을 지워도 펌웨어 잘 로딩합니다.
정말 mdev 스스로 잘 해결해주네요...
그런데 전 몇주간 뭐때문에 고민했었던 것인지 조금 허탈하네요 ㅎㅎ
댓글 달기