RISC칩 중에 가장 널리 사용되고 있는 것의 하나인 ARM7에 대하여 다루어 보려고 합니다. 부족한 점이 많겠지만, 이 강좌를 통해 ARM7을 공부하시는 분들에게 조금이나마 도움이 되었으면 하고, 아울러 저 역시 어떤 보람을 얻을 수 있었으면 합니다.
● 강좌에서 다루고자 하는 내용들
- 개요
- 구조
- 레지스터
- Exception(1)
- Exception(2)
- Instruction Set(1)
- Instruction Set(2)
- Instruction Set(3)
- StrongARM
사실 ARM 아키텍처의 경우엔 관련 문서가 아주 잘 만들어져 있습니다. www.arm.com 사이트에 들어가면 해당 문서를 PDF형태로 받아 볼 수 있고 내용도 아주 잘 정리되어 있습니다. 강좌를 통해 어느 정도 기본을 익히고 해당 자료를 찾아 공부하신다면, 빠른 시일 내에 ARM을 익힐 수 있으리라 생각됩니다.
ARM의 가장 큰 특징은 전력을 조금만 소모한다는 것입니다. 일설에 의하면, ARM을 설계할 때, 요즘 CPU를 설계하는 방법처럼 VHDL등을 사용한 것이 아니라 일일이 회로를 그려가면서 했다는 설도 있습니다. 사실이야 어떻든, ARM의 저-전력 설계기술은 널리 알려진 사실입니다. 이런 이유 때문에, ARM CPU는 상대적으로 전력이 중요하게 여겨지는 휴대용 단말기에 많이 채택되고 있습니다.
이제 이런 일반적인 내용말고, 좀 구체적인 내용으로 들어가 보겠습니다. 다음은 ARM7의 특징들입니다.
1. 32 Bit RISC 프로세서
: ARM7은 내부적으로 32Bit의 데이터 버스와 32Bit의 어드레스 버스를 제공합니다. 내부적이란 말은, ARM7이 Core 형태로 여러 종류의 칩에 탑재되기 때문인데, 어떤 칩은 어드레스 라인을 내부적으로는 32비트를 사용하고 외부적으로는 메모리 매니지먼트 유닛을 통해 24비트를 사용하기도 합니다. 그리고 잘 알려져 있듯이 ARM은 대표적인 RISC 코어입니다.
2. Big/Little Endian 모드지원
: 엔디안이라는 것은, 흔히 역-워드 방식이라고 말하는 것과 관련이 있습니다. 인텔 계열의 CPU에서는 메모리에 여러 바이트의 내용을 저장 할 때, 하위 바이트가 먼저 오고 상위 바이트일 수록 뒤에 오는데, 이런 형태를 Little Endian이라고 합니다. 또 모토롤라 계열의 CPU처럼 가장 상위 바이트가 먼저 오는 방식이 Big Endian입니다. 해당 설정은 ARM7이 구현된 칩에 따라 틀리지만, 보통 칩 외부에서 핀 입력을 받아 결정됩니다.
3. High Performance RISC
: ARM7 의 경우 3V를 사용하고 25MHz의 Clock을 사용할 때 약 17MIPS가 나온다고 합니다.
4. Fast Interrupt Response
: 인터럽트 처리를 빠르게 해 줄 수 있는 FAST인터럽트 기능이 있습니다. 후에 레지스터 부분에서 자세히 다루겠지만, 레지스터 셋을 따로 제공해서, 인터럽트 처리루틴에서 레지스터를 저장, 복구하는 시간을 줄이는 방식입니다.
5. Excellent high level language support
: 인스트럭션 셋을 살피면, C나 다른 언어에서 일반적으로 사용하는 기능들을 바로 구현할 수 있는 명령어들이 제공됩니다. 예를 들어 변수의 앞, 뒤에 ++나 --를 붙이는 형식의 오퍼레이션을 제공합니다.
6. Simple & Powerful Instruction Set
: ARM의 명령어는 그 종류가 적으면서도, 다양하게 적용시킬 수 있는 특징이 있습니다. 이후에 다루게 되면 여러분들도 느끼시겠지만, 배우기 쉽고, 또 강력한 기능을 제공합니다.
오늘은 ARM7의 전반적인 내용에 대해 간단히 언급했습니다. 사실 ARM을 개인적으로 사용하기는 쉽지 않은 일입니다. 왜냐하면, ARM을 사용한 칩을 구하기가 쉽지 않기 때문인데요, 최근 CPU인 만큼, 나오더라도 SMD타입으로 나오는 것이 많고 소량으로 구매하기가 쉽지가 않습니다.
하지만, 여러분들이 회사에서 일을 하게 되면, 사정이 달라집니다. ARM은 비교적 저렴하면서도 가격에 비해 좋은 성능을 보이고, 게다가 저-전력 소모라는 강력한 장점을 가지고 있기 때문입니다. 국내 반도체 업계에서도 LG, 삼성, 현대 등, 모두 ARM 코어를 사용한 칩을 생산하고 있습니다. 그리고, ARM을 사용할 때의 장점중의 하나는, ARM사에서 개발환경과 도큐먼트 등을 제공한다는 것입니다.
내용은 되도록 쉽게 쓰려고 노력했는데, 어땠는지 모르겠군요. 그러면 다음 강좌에서 뵙겠습니다. 다음 강좌에서는 ARM7의 블록 구조에 대해서 살펴볼 생각입니다.
1. ATD or ATDT
Data call을 하고자 할 경우 사용. 보통 ATDT의 command를 사용하나 실제로는 ATD command를 사용해도 무방하다.
형식 : ATDT <dial string>
예 : ATDT 016
ATDT command를 수신하면 Qmodem은 통상 “CONNECT”로 응답한다. 단 현재 CDMA state가 No Service이거나 system 획득 과정이라면 2분간 system을 획득할 때까지 기다렸다가 “CONNECT”로 응답한다. 만일 2분내로 system을 획득하는데 실패하면 “NO DIALTONE”으로 응답한다.
또 ESN 또는 전화 번호가 잘못된 경우 “+CERROR: NO SERVICE”로 응답한다.
무선 망에 접속 중 상대에 의해 또는 system에 의해 call이 release되는 경우 “NO CARRIER”가 return된다.
ATDT command에 대한 응답 방식은 첫번째 : Qmodem이 packet service mode에 있을 경우는 ATDT command를 수신하더라도 Qmodem은 실제로 무선 망으로 아무 동작도 하지 않고 PPP packet이 수신될 때까지 기다린다. PPP packet을 수신하면 무선 망으로 origination을 시작한다; 와 두 번째 ATDT command를 수신 후 traffic을 열고 나서 “CONNECT”를 송신한다; 의 두 가지가 있다. 어느 방식을 사용할 지는 Qmodem을 사용 할 application의 요구에 따라 정해진다.
Qmodem이 packet service mode에 있을 경우는 ATDT command에 의해 voice call을 할 수 없다. 이 경우 voice call은 AT+CDV command를 사용한다.
2. ATH
통신 중 call release를 할 경우 사용. Call release를 위해서는 ATH command와 “+++” inband command string을 함께 사용할 수도 있다. 또 DTR signal을 drop하는 것도 권고된다.
3. AT+CDV
음성 호의 발신을 위해 사용.
형식 : AT+CDV <dial string>
예 : AT+CDV 027508755
Qmodem 180 series중 음성 호가 지원되는 model의 경우에만 유효하다
4. AT+CHV
AT+CDV command에 의해 음성 호를 발신한 후에 이 음성 호를 해제하고자 할 경우 사용.
5. AT$QCCAV
호가 착신되는 경우 Qmodem은 ring의 주기마다 RS-232 interface의 RING port를 50 ms 동안 ON한다. 이 RING port signal을 감지한 후 이 command에 의해 음성 호에 응답을 할 수 있다. 착신 호가 음성 호인 경우 “RING VOICE”를 송신하고, 단문 메시지가 도착한 경우 “RING SMS”라고 송신한다. “RING VOICE”는 매 3초마다 송신된다.
6. AT+GMI
제조자의 정보를 제공. "QMTEL, Incorporated“로 응답한다. Qmodem의 연결 상태를 확인하기 위해 사용할 수있다.
7. AT+GMM
Modem의 model 정보를 제공. “Qmodem-180”으로 응답한다. Qmodem의 연결 상태를 확인하기 위해 사용할 수있다.
8. AT+GMR
Modem의 S/W version 정보를 제공. “S/W VER: <version string>”으로 응답한다. Qmodem의 연결 상태를 확인하기 위해서 또는 modem의 S/W version을 확인하기 위해 사용할 수있다.
9. AT+GSN
Modem의 ESN 정보를 제공. 정보 보호를 위해 Qmodem은 ESN 정보를 보여주지 않는다.
10. AT+CAD
현재 service 상태 정보를 제공. No service 상태이면 0으로 응답, CDMA service가 가능하면 1로 응답한다. Dial을 하기 전 Qmodem의 상태 확인을 위해 사용할 수 있다. AT+CAD?의 형식을 사용.
11. AT+CSQ
현재 Qmodem의 수신 감도를 표시. 숫자가 작을 수록 감도가 좋으며, 감도를 측정할 수 없을 경우는 255로 응답한다.
AT+CSQ?의 형식을 사용하며, 응답 중 첫번째 숫자가 감도 값이다.
12. AT$QCDMG
Data mode에서 DM mode로 전환할 경우 사용. MDT 또는 MMSP 기능을 사용하고자 할 때나 PDA application에서 DM interface를 사용하고자 할 경우 DM mode로 전환한다.
13. AT$QMDT
현재 날짜와 시간 정보를 제공한다. 전원 ON후 약 5 ~ 6초 후 system을 획득하고 난 후부터 가능하다. 그 이전의 정보는 신뢰할 수 없다.
형식 : AT$QMDT
응답 : $QMDT: 2001-02-08,15:17:14
14. AT$QMPN Qmodem의 전화 번호의 확인과 변경을 위해 사용된다. 전화 번호를 변경할 경우는 자동으로 Qmodem이 reset된다.
전화 번호 확인
형식 : AT$QMPN?
응답 : $QMPN: 0167038757
전화 번호 변경
형식 : AT$QMPN=0167038757
응답 : OK
15. AT$QMTNS
공장에서 생산 시 시험 번호를 사용하여 최종 시험을 하고자 할 경우 사용된다. 시험 번호의 list는 Qmodem S/W가 release되기 전에 통보되어야 하며, 현재 최대 10개까지 저장이 가능하다. 시험 번호의 번지를 선택하면 시험 번호에 해당하는 ESN과 전화 번호로 변경되며 자동으로 reset된다. 모든 시험이 완료된 후는 AT$QMTNR command에 의해 원래의 ESN과 전화 번호로 변경할 수 있다.
설정된 시험 전화 번호 확인
형식 : AT$QMTNS?
응답 : $QMTNS: 1 : 0167038757 : 설정된 시험 번호가 있는 경우 index와 번호 표시
Error, Test Phone Number was not set! : 설정된 시험 번호가 없는 경우
설정 가능한 시험 전화 번호 확인
형식 : AT$QMTNS=?
응답 : $QMTNS:
[1] 0167030001
[2] 0167030002
[3] 0167030003
[4] 0167030004
[5] 0167030005
[6] 0167030006
[7] 0167030007
[8] 0167030008
[9] 0167030009
[10] 0167030010
시험 전화 번호 설정
형식 : AT$QMTNS=<test phone number index>
예 : AT$QMTNS=1
응답 : OK : 응답 후 자동으로 reset.
16. AT$QMTNR
공장에서 생산 시 시험 번호를 사용하여 최종 시험을 하고자 할 경우 사용된다. 모든 시험이 완료된 원래의 ESN과 전화 번호로 변경하기 위해 사용한다.
원래 전화 번호로 설정
형식 : AT$QMTNR
응답 : OK : 응답 후 자동으로 reset.
17. AT$QMDS Field test등의 목적으로 debug screen data를 제공한다.
형식 : AT$QMDS
응답 : $QMDS:
RxTxS02180N00016
S1R-067E-00P+005
P268C125T160BPR5
OK
Sleep Mode Control Sleep으로 들어가지 않고 계속 망 정보를 얻고자 할 경우 사용
형식 : AT$QMDS=0 ( or 1) : 1이면 sleep으로 들어 가지 않도록 설정, 0이면 정상적으로 sleep으로 들어가도록 설정.
응답 : OK
18. AT*ESMS
TE2에서 AT Command를 사용하여 SMS 송수신을 하기위해서는 ESMS를 SET해야만 사용 가능하다.
ESMS 설정 값은 NV에 저장되지 않으므로 Power on/off 시 자동으로 Reset(default값 : 0) 되므로 사용하기 전에 반드시 1로
설정을 해야만 사용 가능하다.
ESMS 설정 (해제 )
형식 : AT*ESMS=1 ( 0이면 ESMS기능 해제)
응답 : *SET*ESMS : 1 (*SET*ESMS : 0)
OK
ESMS 설정(해제 ) 확인
형식 : AT*ESMS?
응답 : *SET*ESMS : 1 (*SET*ESMS : 0) => 현재 설정되어 있는 값을 보여 줌.
OK
※ TE2 : 단말과 연결되어 단말의 통신을 제어하는 제어기
19. AT*MOREQ (ESMS가 Set 일 때만 사용가능)
TE2에서 AT Command를 사용하여 SMS 송신을 하고자 할 때 단말기에 주는 명령어로 <발신 메시지 번호>,
<착신번호(Called number)>, <회신번호(생략가능)>, <TI(Teleservice ID)>, <Data> 를 포함한다.
MO후에는 BS에서 받는 ACK로 발신 성공(실패)여부를 결정한다.
메시지 번호는 0 ~ 254의 값을 가지며, Data는 80byte로 제한된다.
사용 가능한 발신 TI는 4097(호출)과 4098(단문 메시지)의 두 가지이다. TI를 4097로 사용하는 경우에는 <Data> field는 의미가 없으며, 생략 가능하다.
20. AT*READMT (ESMS가 Set 일 때만 사용가능)
이 명령은 단말의 수신버퍼에 저장된 메시지를 읽기 위해 사용되며, 수신버퍼에는 0번부터 최근 수신된 메시지 순서로 저장
되어 있다. 응답에서 회신번호가 없을 경우 회신번호는 나타나지 않는다.
형식 : AT*READMT= <수신 메시지 번호>
응답 : *READMT : <수신 메시지 번호>, <수신 시간>, <회신 번호> ,<Data>
OK
- 수신된 메시지가 없을 경우
응답 : *READMT : NO Message
OK
- <수신 메시지 번호> 가 수신된 메시지의 총 갯수 보다 가 클 경우
응답 : *READMT : NOT Found
OK
21. AT*READTI (ESMS가 Set 일 때만 사용가능) 이 명령은 단말의 수신버퍼에 저장된 메시지 중 TI(Teleservice ID) 에 해당되는 메시지만을 읽기 위해 사용된다.
현재 TI는 4097(호출 메시지), 4098(문자 메시지) 두 가지를 지원한다.
형식 : AT*READTI= <TI> => TI : 4097(호출 메시지), 4098(문자 메시지)
응답 : *READTI : <수신 메시지 번호>, <수신 시간>, <회신 번호> <TI>,<Data>
*READTI : <수신 메시지 번호>, <수신 시간>, <회신 번호> <TI>,<Data>
*READTI : <수신 메시지 번호>, <수신 시간>, <회신 번호> <TI>,<Data>
OK
22. AT*READALLMT (ESMS가 Set 일 때만 사용가능)
이 명령은 단말의 수신버퍼에 저장된 모든 메시지(문자/호출 메시지)를 읽기 위해 사용되며, 수신버퍼에는 0번부터 최근 수신된 메시지 순서로 저장되어 있다.
형식 : AT*READALLMT
응답 : *READALLMT : <수신 메시지 번호>, <수신 시간>, <회신 번호> ,<Data>
*READALLMT : <수신 메시지 번호>, <수신 시간>, <회신 번호> ,<Data>
*READALLMT : <수신 메시지 번호>, <수신 시간>, <회신 번호> ,<Data>
*READALLMT : <수신 메시지 번호>, <수신 시간>, <회신 번호> ,<Data>
.
.
.
OK
23. AT*DELMT (ESMS가 Set 일 때만 사용가능) 단말에 저장된 메시지를 삭제하는데 사용되며. 사용자가 입력한 번호에 해당하는 메시지가 삭제된다.
형식 : AT*DELMT=<수신메시지번호>
예 : AT*DELMT=1
응답 : *DELMT: 1
OK
24. AT*DELALLMT (ESMS가 Set 일 때만 사용가능)
단말에 저장된 모든 메시지를 삭제하는데 사용된다.
형식 : AT*DELALLMT
응답 : *DELALLMT:
OK
25. AT*MTACK (ESMS가 Set 일 때만 사용가능)
단말에 새로운 단문 메시지가 도착하면 단말은 ESMS가 Set되어 있으면 즉시 이를 NEWMT명령어를 이용하여 TE2에
전달한다. TE2는 이에 대한 응답으로 MTACK을 송신한다. 단말은 3초 이내에 TE2로부터 응답이 없으면 수신 메시지를
2회 재전송 한다.
26. AT$QMVSO
이 명령은 voice service option을 선택하기 위해 사용된다.
설정된 voice service option 확인
형식 : AT$QMVSO?
응답 : $QMVSO: EVRC Vocoder : EVRC로 설정된 경우
$QMVSO: 13K QCELP Vocoder : 13K QCELP로 설정된 경우
Voice service option 설정
형식 : AT$QMVSO=<value> : 0 = EVRC, 1 = 13K QCELP
응답 : OK
27. AT$QMRV
이 명령은 벨 음량(Ring Volume)을 조절하기 위해 사용된다. 현재 설정 값을 확인하거나 새 값을 설정하면 해당 음량으로 벨 소리가 울리게 된다. 벨 소리를 멈추려면 AT$QMSDST 명령을 사용한다.
설정된 Ring Volume 확인
형식 : AT$QMRV?
응답 : $QMRV: 3 : 현재 설정된 Value ( 0 ~ 4 ) Display
설정 가능한 Value 확인
형식 : AT$QMRV=?
응답 : $QMRV: (0 ~ 4)
Ring Volume 설정
형식 : AT$QMRV =<value> : value 0 ? 무음, 1 - 작게, 2 - 보통, 3 - 조금 크게, 4 - 크게
응답 : OK
28. AT$QMEV 이 명령은 수신 음량(Ear Volume)을 조절하기 위해 사용된다.
설정된 Ear Volume 확인
형식 : AT$QMEV?
응답 : $QMEV: 3 : 현재 설정된 Value ( 1 ~ 4 ) Display
설정 가능한 Value 확인
형식 : AT$QMEV=?
응답 : $QMEV: (1 ~ 4)
Ear Volume 설정
형식 : AT$QMEV =<value> : value 1 - 작게, 2 - 보통, 3 - 조금 크게, 4 - 크게
응답 : OK
29. AT$QMMV
이 명령은 마이크 음량(Mic Volume)을 조정하기 위해 사용된다.
설정된 Mic Volume 확인
형식 : AT$QMMV?
응답 : $QMMV: 3 : 현재 설정된 Value ( 1 ~ 8 ) Display
설정 가능한 Value 확인
형식 : AT$QMMV=?
응답 : $QMMV: (1 ~ 8)
Mic Volume 설정
형식 : AT$QMMV =<value> : Value ( 1 ~ 8 )
응답 : OK
30. AT$QMRI
이 명령은 멜로디(Ring Pattern)을 선택하기 위해 사용된다. 현재 설정 값을 확인하거나 새 값을 설정하면 해당 음량으로 벨 소리가 울리게 된다. 벨 소리를 멈추려면 AT$QMSDST 명령을 사용한다.
설정된 Ring Pattern 확인
형식 : AT$QMRI?
응답 : $QMRI: 3 : 현재 설정된 Index ( 0 ~ 12 ) Display
설정 가능한 Index 확인
형식 : AT$QMRI=?
응답 : $QMRI: (0 ~ 12)
Ring Pattern Select
형식 : AT$QMRI =<Index>
응답 : OK
- Melody Index -
index 0 ~ 3 전화벨 1 ~ 전화벨 4
index 4 희망의 나라로
index 5 베토벤 심포니 9번 4악장 테마
index 6 닐리리야
index 7 축배의 노래
index 8 리자로 끝나는 말
index 9 에델바이스
index 10 라쿠카라차
index 11 Lamp
index 12 Vibrator
31. AT$QMSI
이 명령은 단문 벨 소리(SMS Ring Pattern)를 선택하기 위해 사용된다. 현재 설정 값을 확인하거나 새 값을 설정하면 해당 음량으로 벨 소리가 울리게 된다. 벨 소리를 멈추려면 AT$QMSDST 명령을 사용한다.
설정된 SMS Ring Pattern확인
형식 : AT$QMSI?
응답 : $QMSI: 3 : 현재 설정된 Index ( 0 ~ 7 ) Display
설정 가능한 Index 확인
형식 : AT$QMSI=?
응답 : $QMSI: (0 ~ 7)
SMS Ring Pattern Select
형식 : AT$QMSI =<Index> : Index 0 - 단문 벨 1,
응답 : OK Index 1 ~ Index 5 - 전화벨 2 ~ 6
Index 6: Lamp Index 7 : Vibrator
32. AT$QMAA
이 명령은 자동 응답기능(Auto Answer Feature)을 선택하기 위해 사용된다.
설정된 Auto Answer Feature 확인
형식 : AT$QMAA?
응답 : $QMAA: 3 : 현재 설정된 Index ( 0 ~ 3 ) Display
설정 가능한 Index 확인
형식 : AT$QMAA=?
응답 : $QMAA: (0 ~ 3) : Index 0 - Auto Answer Disable
Auto Answer Feature 설정 Index 1 - Auto Answer after 1Bell
형식 : AT$QMAA =<Index> Index 2 - Auto Answer after 3Bell
응답 : OK Index 3 - Auto Answer after 5Bell
33. AT$QMKEY
이 명령은 AT Command로 KEY를 입력할 때 사용. 여러 개의 키 값을 동시에 입력하는 것도 가능.
매직엔 서비스나 핸디 넷 서비스도 키의 조합으로 가능하다.
형식 : AT$QMKEY < KEY > : KEY - 0 ~ 9, #, *,
S (통화), E(종료), M(메시지), R(재발신), T(저장), N(메뉴), C(지움)
예 : AT$QMKEY 1 : 1 key Pressed
AT$QMKEY02114S : 02-114로 dialing
AT$QMKEYM7*016T : 매직엔으로 접속 시도
응답 : OK
34. AT$QMSDST 이 명령은 재생되고 있는 벨 소리를 멈추기 위해 사용.
형식 : AT$QMSDST
응답 : OK
35. EAR-MIC 키 기능 사용 방법
Qmodem을 이용하여 음성 통화를 할 때 ear-mic를 사용하는 경우 필요한 기능이다. 이 기능이 요구되는 model 에만 적용된다.
Ear-mic의 키를 누르는 경우 다음과 같이 동작.
대기 상태에서 누른 경우 : 재다이얼 번호가 없는 경우는 “ERROR”로 응답하고, 재다이얼이 가능한 경우는 “REDIAL<재다이얼 번호>”로 응답한다.
착신 벨이 울리는 동안 누른 경우 : 착신 호에 응답하고 “CONNECT”로 응답한다.
통화 중 누른 경우 : 현재 통화를 종료하고 “NO CARRIER”로 응답한다.
36. 통화 중 대기 기능 사용 방법
무선 사업자가 제공하는 각 종 부가 기능들을 사용하기 위해서는 통화 중에 “통화”키의 사용이 필요하다. 예를 들어 통화 중 대기 기능을 사용하는 경우 통화 중에 제 3자로부터 전화가 걸려 오면 통화 중 대기 음이 들리고, 이 때 제 3자와 통화를 하려면 “통화”키를 누르면 된다. Qmodem에게 “통화”키를 전달하려면 AT$QMKEY명령을 사용하면 된다. 즉 AT$QMKEYS명령을 송신한다.
37. 발신자 표시 기능 사용 방법
사용하고 있는 전화 번호가 발신자 표시 부가 기능에 가입되어 있는 경우 전화가 올 때마다 발신자 번호를 표시하게 된다. 이 기능을 AT 명령어로 제공하기 위해 Qmodem은 다음과 같이 동작한다.
발신자 표시 부가 기능에 가입되어 있고, 전화를 걸은 상대가 발신자 번호 표시 금지를 하지 않는 경우에 아래와 같은 응답을 송신한다.
CNIP:<발신자 번호>
그리고 전화를 걸은 상대가 발신자 번호 표시 금지를 한 경우에는 아래와 같은 응답을 송신한다. (발신 번호 표시 제한)
CNIR:****************
전화를 걸은 상대자의 발신자 번호 표시를 할 수 없는 경우에는 아래와 같은 응답을 송신한다. (발신자 미확인)
CNIP NOT AVAILABLE
38. 음성 사서함 확인 후 발신 기능에 대해
음성 사서함에 메시지가 있다고 단문이 수신된 경우 바로 “*88”로 다이얼하면 실제로는 다이얼이 되지 않는다. “*88”로 다이얼하기 전에 AT$QMKEY<key> 명령의 key를 ‘E’로 하여 송신함으로써 Qmodem을 일단 대기 상태로 만들고 “*88”로 다이얼 하도록 하는 방법이 권고된다. 즉 AT$QMKEYE를 송신하면 된다.
39. AT$QMMS
이 명령은 모뎀의 실제 화면 표시를 얻기 위해 사용된다.
형식 : AT$QMMS
예 : AT$QMMS
응답 :
$QMMS:
1:음량조절
2:화면표시
3:소리/경보
4:전화정보
5:비밀기능
6:기타기능 ▼
OK
? 이 명령과 AT$QMKEY 명령을 조합함으로써 모뎀의 모든 화면을 얻을 수 있고, 매직엔 & 핸디넷 서비스도 사용 가능하다.
41. AT$QMCCS 이 명령은 모뎀의 현재상태를 Check하기 위해 사용된다.
형식 : AT$QMCCS
예 : AT$QMCCS
응답 : $QMCCS : 2 (현재 모뎀상태)
OK
- 현재 모뎀상태
0 : No service
1 : Init state
2 : Idle state
3 : Conversation state
4 : Access state
5 : Paging state
6 : Ringing
7 : Etc (or error)
42. AT$QMRESET
이 명령은 모뎀을 RESET 하기 위해 사용된다.
형식 : AT$QMMRESET
예 : AT$QMRESET
응답 : $QMRESET
OK
o 프로젝트 관리자의 필수 유틸리티.
- 프로젝트 생성 시, Compile 할 파일들을 정리하고, Dependency들을 확인하여 빌드 하고,임시 파일들을 제거 할수 있는 유틸리티이다.
- 또한 이 make는 재 빌드시에 갱신된 파일들의 시간을 확인하여 (최종 파일보다 나중에 생성된 시간) 수정된 파일이 있을 경우, 그 파일이나 혹은 그 dependency를 확인하여 빌드 시간을 감소시킨다. ( 단 메인의 header file 수정시에는 전체 빌드한다. )
즉 .o (object) 보다 .c가 변경된 시간이 이전이라면 빌드를 하지 않고, 이후라면 빌드한다.
- 역방향 연결방법 (backward-chaining : 목적중심의 관리 방법) : 연결고리를 추적해 나간다.
1. 컴파일 / 실행 / 디버그
o $make project
Project 는 Target / Prerequisites (필요 항목) / Dependents (종속 항목) 이라는 파일들로 Build 된다.
build 하는 데 필요한 Obect와 관련된 .c or .h 파일이 Prerequisities 라고 한다.
o make의 모든 명령들은 Tab 문자로 시작한다. No Space!!!
확인 ) $cat -v - t -e project
-v 와 -t는 모든 탭들을 ^I로 표시하고, -e는 각행의 마지막에 $기호를 표시.
o 행이 길어질 경우 역슬래시(\)를 추가하여 계속이어 나갈수 있다. 여기서도 역슬래시(\)는 행이 바뀌는 문자 바로 앞에 위치!!
o 비어있는 행은 무시.
o #은 주석문
o 제각기 다른 명령은 세미콜론(;)으로 한 행에 기술 가능.
o 예제 적용
# This is a sample.
(^I)project : project1.o project2.o project3.o \
project4.o $
# This blank is ignored.
(^I)project_sub : project_sub.o ; project_sub_sub : project_sub_sub .o $
# End of Line
o $make clean (clean 명령 스크립트)
# clean Script
clean:
/bin/rm -f core *.o
#EoL
2. Macro
o Sample 1
ROOT_DRIVE=D:\
APPS_PATH=%ROOT_DRIVE%\%APPS_DIR%
or
$(ROOT_DRIVE)
or
${ROOT_DRIVE}
o Sample 2
LIBES = -1x11
objs = abc.o def.o dsd.o
CC=/usr/sample2/cc
23 = "This is the 23rd run"
OPT =
DEBUG_FLAG= #empty now, but assign -g for debuging
BINDIR=/usr/local/bin
- 문자열 치환의 또 다른 예제. 공백문자 바로 앞까지만 적용됨)
LETT = xyz xyzacb abcxyz
echo ${LETT:xyz=DEF}
==> DEF xyzabc abcDEF (공백문자 앞까지만 적용 그 이후는 다른 것으로 간주)
o Target용 내부 매크로
$@ 는 현재 Target을 말한다. ==> $$@ , $(@), ${@}로도 사용가능.
$? 는 최신인 Target의 필요항목 만 받는다. ==> 만약 처음 빌드 후 update 된 내용이 없을 경우는 skip 한다. (실제 현 target에 확인을 함으로써 소요시간을 더욱 줄이는 것이 가능하다는 이야기이다 )
ex) libops= inter.o sched.o gen.o
ar r $@ $?
$make libhops
ar r libhops inter.o sched.o gen.o
$cc -c sched.c
$make libhops
ar r libhops sched.o
3. 확장자 규칙.
o $<의 의미
.SUFFIXES:.o .c .s
.c.o:
$(CC) $(CFLAGS) -c $<
.s.o:
$(AS) $(ASFLAGS) -o $<
$<의 의미는 소스(.c or .s)와 .o 파일이 생성시간을 확인하여, .c와 .o의 compile 방법을 제공해 주는 것이다. 즉 이는 확장자 규칙에서만 사용될수 있다는 것을 제외하고는 <? 와 유사하다.
o 명령옵션
$make program CFLAGS=-g
$make program "CFLAGS=-g -DTRACE"
$make program CFLAGS=-l
$make program CFLAGS=-p