[해결]device를 app에서 open 하는데 error 이유 아는방법
// 해결 방법
#mknod /dev/virtual_device c 254 0 노드를 추가하고
cat /proc/devices 를 해보면 254 virtual_device 라는 것이 있어야하는데
이미 254에는 다른 장치가 들어있어서 init 실패한 것이다.
254말고 다른 빈 번호로 node 추가하면 정상 작동한다.
// issue
linux app에서 /dev/virtual_device 라는 device를 open 하려고하는데
-1 값을 리턴합니다. 왜 그런지 알 수 있는 방법 알 수 있을까요?
아래처럼 모듈이 등록되어 있고, /dev 밑에 노드도 잘 추가되어있습니다.
# sudo ls -al /dev | grep 250
crw-r--r-- 1 root root 250, 0 11월 20 17:26 virtual_device
# sudo lsmod | grep virtual_device
virtual_device 16384 0
앱 코드는
dev = open("/dev/virtual_device", O_RDWR); printf("dev = %d\n", dev);
이렇게 되어있으며
app을 실행했을 때
# ./test
dev = -1
이렇게 결과가 나옵니다. 조언 부탁드립니다.
추가 //
리눅스에서
# cat > /dev/virtual_device
bash: /dev/virtual_device: No such device or address
이렇게 나오는것도 file을 못 여는것과 관련이 있을거 같은데..ㅠㅠ
추가 //
인터넷 찾아보니 /proc/devices 에 등록되어 있는지 보라는데
cat /proc/devices 로 보니
250 device가 나오지 않았습니다.
proc/devices 에 등록하는 방법이 따로 있나요
추가 //
#dmesg | tail -1
하면 module을 등록 또는 삭제할때 함수에 printk 해논것은 볼수 있습니다.
권한 문제..
root 외에는 write 권한이 없네요.. 근데 R/W 열어서 권한 문제가 발생한것 같습니다.
답변감사합니다.!
답변감사합니다.!
실행을 root권한으로 실행했고, 님 말씀처럼 권한줘도 안되네요 ㅠㅠ
댓글 달기