디바이스 드라이버 open EPERM 문제...
직접 작성한 디바이스 드라이버를 오픈하려고 합니다
우선 그냥 일반 테스트 유저프로그램에서는 정상적으로 동작하는것을 확인했습니다.
그다음 QEMU소스에서 오픈을 해보려고 합니다.
QEMU block/raw-posix.c에 보면 pwrite를 하는 부분이 있는데 그 직전에 오픈을 하려고 하는데
open의 리턴값이 계속 -1이 뜹니다.
확인해보니 errno가 1번이 뜨는데 opeartion not permitted로 확인이 되었습니다.
근데 이해가 되지 않는게 /dev에 있는 urandom을 오픈해보니(이 드라이버 파일의 디폴트권한은 0666)
이건 오픈이 잘됩니다. 그래서 제 디바이스드라이버파일도 그렇게 바꿔보니 역시 오픈이 안되는건 똑같은데
어디가 문제인지 알고 싶습니다...
while (offset < aiocb->aio_nbytes) {
if (aiocb->aio_type & QEMU_AIO_WRITE)
{
devfd1 = open("/dev/urandom", O_RDWR | O_NDELAY);
devfd = open("dev/mydev", O_RDWR | O_NDELAY);
//devfd = qemu_open(namedev, O_RDWR | O_NDELAY);
printf("devfd1 : %d devfd : %d error : %d %d\n",devfd1,devfd,errno,getpid());
len = pwrite(aiocb->aio_fildes, (const char *)buf + offset, aiocb->aio_nbytes - offset, aiocb->aio_offset + offset);
프로세스 확인
root 2842 1 1 80 0 - 1398172 poll_s 12:45 ? 00:00:12 qemu-system-x86_64 -enable-kvm
이걸 확인하는게 맞는진 모르겠지만 가상머신의 프로세스를 확인해보면 역시 root권한으로 되어있고 mydev또한 역시 root인데 퍼미션에 문제라고 봐야할까요?
댓글 달기