- 현재 디렉토리의 .bachrc 파일을 분석.
- bash prompt 변경.
- 현재 디렉토리에 속한 파일명을 화면에 출력하는 프로그램(DirScan.c)을 작성한다.
- hidden 파일 (파일명이 dot(.)로 시작하는 파일)은 제외.
- 현재 디렉토리의 하부 디렉토리(sub-directory)도 재귀적으로 탐색. tab문자를 통해 하부 디렉토리 구분.
- Low-level 파일함수를 사용하여 파일복사 프로그램(LowCopy.c)을 작성한다.
- 파일을 복사하는 동안 화면에 dot(.)를 일정시간 간격으로 출력하여 파일 복사중임을 표시한다.
- 복사할 파일명은 프로그램 파라미터로 지정
- High-level 파일함수를 사용하여 파일복사 프로그램(HighCopy.c)을 작성한다.
- 파일을 복사하는 동안 low-level과 같은 방식으로 asterisk(*)를 출력한다.
- “time” 명령어를 사용하여 실행한다.
- Low-level과 High-level의 차이점을 time명령어 결과를 바탕으로 분석.
- getenv(), 함수를 사용하여 $HOME, $PS1, $PATH, $LD_LIBRARY_PATH 환경변수에설정된 값을 화면에 표시.
- setenv() 함수를 사용하여 $TEST_ENV 라는 환경변수를 정의한 뒤 그 값을 1234 로설정하고, 설정된 값을 bash에서 확인.
- 샘플 소스 파일 mtest.c foo.c boo.c bar.c를 만든다.
- foo.c : InFoo() 함수를 정의한다.
- boo.c : InBoo() 함수를 정의한다.
- bar.c : InBar() 함수를 정의한다.
- mtest.c : InFoo(), InBoo(), InBar() 함수를 호출한다.
- mtest.c를 컴파일하여, mtest 라는 실행파일을 생성하는 makefile을 작성한다.
- make 유틸리티를 사용하여 mtest를 생성하고, 쉘에서 실행한다.
- 컴파일시 –g 옵션을 추가하여 디버그 정보를 생성한다.
- gdb를 사용하여 mtest 파일에서 Infoo, InBoo, InBar 함수를 호출하는 과정을 trace한다.
- 아래와 같은 ptest 프로그램을 작성한다.
- ptest : 시스템의 local time 을 2초 간격으로 터미널에 표시한다.
- 아래와 같은 pmon 프로그램을 작성한다. pmon 프로그램은 ptest 실행여부를 화면에표시하고, 사용자의 명령어 입력에 따라 해당 동작을 수행한다.
- pmon : 5초간격으로 ptest 프로그램의 실행여부를 표시한다. ptest 프로세스의 존재여부를확인하여 “running”(실행중인 경우), “not existed”(프로세스가 없는 경우) 로표시한다.
- pmon 프로그램이 지원해야 하는 사용자 명령어. 명령어 prompt 는 “>>”.
- Q (quit) : pmon 프로그램 종료
- K (kill) : ptest 프로그램의 강제 종료
- S (start) : ptest 프로그램 실행, 이미 실행중이면, “already running” 메시지 출력.
- R (restart) : 실행중인 ptest를 종료후 재실행. ptest가 없는 경우, “newly started” 메시지 출력.
- pmon, ptest 2개의 프로그램을 별도의 터미널에서 실행한다.
- 아래와 같은 subproc 프로그램을 작성한다.
- “test_funct()” 함수를 반복적으로 호출한다.
- test_funct() 함수에서는 현재 프로세스의 PID, 현재시간, 함수가 호출된 횟수를 카운트하여 출력한다.
- test_funct함수의 호출간격은 1~10초 사이의 랜덤시간으로 한다.
- test_funct함수가 20번 호출되면 프로세스를 종료한다.
- 아래와 같은 mproc1 프로그램을 작성한다.
- fork(), exec() 함수를 사용하여 10개의 subproc 프로세스를 실행한다.
- 모든 프로세스가 종료되면 “Finished (process)”를 출력한다.
- 아래와 같은 mproc2 프로그램을 작성한다.
- pthread 라이브러리를 사용하여 Lab-7의 subproc을 10개의 thread로 실행시킨다.
- 10개의 쓰레드가 모두 종료되면 “Finished (thread)”를 출력한다.
- 아래와 같은 mproc3 프로그램을 작성한다.
- 10개의 subproc을 process 또는 thread로 실행시킨다.
- 각 프로세스 또는 쓰레드에서 출력하는 함수 호출 카운트 값이 monotonically increased 하도록 프로세스들을 semaphore나 mutex를 사용하여 동기화시킨다. 예를 들면, 현재출력된 카운트 값이 ‘3’ 이라면 다음에 출력되는 카운트 값은 반드시 ‘3’이상이 되어야한다. 즉, 10개의 프로세스 또는 쓰레드가 호출되는 횟수는 항상 동일해야 한다.
- 10개의 쓰레드가 모두 종료되면 “Finished Successfully”를 출력한다.
- 아래와 같은 ipc_producer, ipc_consumer 프로그램을 작성한다.
- ipc_producer 프로그램은 ‘start’라는 키입력을 받으면 자신의 주소와 PID를 ipc_consumer에 보낸다.
- ipc_consumer 프로그램은 주소를 받으면 화면에 주소와 ipc_producer의 PID를 화면에 출력하고, 자신의 이름과 자신의 PID를 ipc_producer에 보낸다.
- 자신의 이름과 ipc_consumer의 PID를 받은 ipc_producer는 화면에 자신의 PID와 ipc_consumer의 PID, 이름과 주소를 화면에 출력한다.
- ipc_producer와 ipc_consumer의 IPC 방법을 pipe를 사용하여 구현한다.
- Lab-10의 ipc_producer, ipc_consumer 프로그램이 사용하는 IPC 수단으로 sharedmemory를 사용하여 구현하여 ipc_producer2, ipc_consumer2를 작성한다.
- Lab-10의 ipc_producer, ipc_consumer 프로그램이 사용하는 IPC 수단으로 messagequeue를 사용하여 구현하여 ipc_producer3, ipc_consumer3을 작성한다.
- Lab-10의 ipc_producer, ipc_consumer 프로그램이 사용하는 IPC 수단으로 socket을 사용하여 구현하여 ipc_producer4, ipc_consumer4를 작성한다
-
ELF 파일을 분석하여 ELF header, Program header table, Section header table내용을 화면에 표시한다. 프로그램명은 elfreader, 분석할 ELF파일을 파라미터로주어지며, 옵션은 e(ELF header), p(program header table), s(section headertable)이며, 동시에 사용가능하다.
$ elfreader xxx.elf // ELF header만 표시 $ elfreader –e xxx.elf // ELF header만 표시 $ elfreader –ep xxx.elf // ELF header + program header table 표시 $ elfreader –eps xxx.elf // ELF header + program header table + section header table 표시
기타 다른 옵션 조합도 가능.