[완료] 임베디드 리눅스 시작 프로그램 작성 시점에 대한 질문
글쓴이: wputer / 작성시간: 수, 2010/02/10 - 3:11오후
제가 현재 ARM계열 보드에
Linux 커널 2.6.22을 포팅하여 사용하고있고
init프로그램은 busybox로 사용합니다.
부팅시 자동으로 어떤 프로그램을 실행하여
그 프로그램을 메인 동작으로 사용하려 합니다
그런데
이 프로그램을
콘솔상에서 수동으로 실행시키면
정상적으로 동작이 되는데
/etc/init.d/rcS
코드 안에
그 프로그램을 실행하게 두면
시스템 동작이 굉장히 느리고, 조금 밀려서 나와 비정상 적으로 동작합니다.
그래서 /etc/inittab/의 가장 아랫 부분에도 넣어봤는데
역시 같은 현상이었습니다.
1. 고수님들은 보통 이런 프로그램을 어느부분에서 실행하시는지
2. 제가 한 부분에서 문제는 없는지
3. 왜 이런 비정상 적인 동작(콘솔에서 직접 실행할땐 빠른데, init에서 할땐 느린 문제)이 나오는지
알고싶습니다
염치불구하고 질문 드립니다
감사합니다
Forums:
정상상
>>1. 고수님들은 보통 이런 프로그램을 어느부분에서 실행하시는지
inittab이 /etc/init.d/rcS 를 부를테고... 보통 거기에 많이 넣습니다.
>>2. 제가 한 부분에서 문제는 없는지
그닥 문제 없어보이는군요.
>>3. 왜 이런 비정상 적인 동작(콘솔에서 직접 실행할땐 빠른데, init에서 할땐 느린 문제)이 나오는지
님의 환경을 잘 모르겠지만,
init script 돌때, 올라가는 deamon이나.. 뭐 그런것들이
아직 한참 돌고 있지 않을까요? 당연히 덩달아 실행되는 놈 입장에서 느려질 수 있습니다.
console에서 실행할 때야... 이미 그 시점이 지난 상태이니까 빠를거고요.
ㅇㅇ
보통 데몬 초기화 하거나 부팅 후 한번만 실행 시킬경우 rcS에 작성하시고
로긴시 실행되는 것들은 /etc/profile 에 작성하시기 바랍니다.
답변 감사합니다
바로 적용해 보겠습니다
해결하였습니다
아마 위 상황의 예상 원인은
/etc/inittab에서
rcS 이후에
#tty1::respawn:/sbin/getty 38400 tty1
를
#ttyS0::respawn:/sbin/getty -L ttyS0 115200 vt100
로 리스폰 해주는 과정이 들어가므로
그 전에
동작하여 그랬던것 같습니다
먼저 inittab가장 아랫부분에 넣었다가
mogin1님 조언대로
/etc/profile
부분으로 옮겼더니 수월하군요
정말 감사합니다
...
<전략>
...
# now run any rc scripts
::sysinit:/etc/init.d/rcS
null::sysinit:/bin/mount -a
null::sysinit:/sbin/mdev -s
# Set up a couple of getty's
#tty1::respawn:/sbin/getty 38400 tty1
#tty2::respawn:/sbin/getty 38400 tty2
# Put a getty on the serial port
#ttyS0::respawn:/sbin/getty -L ttyS0 115200 vt100
# Logging junk
null::sysinit:/bin/touch /var/log/messages
#null::respawn:/sbin/syslogd -n -m 0
#null::respawn:/sbin/klogd -n
#tty3::respawn:/usr/bin/tail -f /var/log/messages
# Stuff to do for the 3-finger salute
::ctrlaltdel:/sbin/reboot
# Stuff to do before rebooting
null::shutdown:/usr/bin/killall klogd
null::shutdown:/usr/bin/killall syslogd
null::shutdown:/bin/umount -a -r
null::shutdown:/sbin/swapoff -a
댓글 달기