AT91SAM7S.zip
오타가 있으면 말씀해 주세요 !!
압축파일만 덩그러니 횡해서 spec 페이지 정리한거 몇자 올려봅니다.
실행결과는 Timer Count 에 의해 1초에 한번 LED가 점멸합니다.
날씨가 개가있는데 개가 덥습니다... 그래도 퐈이팅하시길 !!
==================================================================================
★ Timer Count ( TC )
data:image/s3,"s3://crabby-images/734a8/734a8eac00b0256ea9b86e6e1fe37a3dd290b801" alt=""
※ spec :: 389p
ㆍ3개의 체널에 구별되는 타이머 카운터를 가지고 있다. ( 16Bit)
ㆍ계산할수 있는 한계는 64K 이다.
ㆍATmega는 8bit ~ 16bit 사이이다.
ㆍ외부 PLL 에 의해 48M 로 증가 된다.
ㆍ즉 48M 에 1초이다.
ㆍ계산이 편하기 위해 묶어서 계산하는 것을 프리스케일러(분주비)라 한다.
data:image/s3,"s3://crabby-images/6cb06/6cb067f1600ab22ae42babf7b9667626ff8b63d9" alt=""
ㆍ위 표의 나누기 2 ~1024 는 분주비 이다.
ㆍ즉 5가지의 분주비를 지원한다.
data:image/s3,"s3://crabby-images/fbd4f/fbd4f8a5faab8584b1f62e1ea445e57f2803bb5a" alt=""
※ spec :: 390p
ㆍPMC, AIC, PIO가 관련되어 있다.
[ 레지스터 base address ]
data:image/s3,"s3://crabby-images/b50bc/b50bcd38be26c5cea1843dac85b96f2fa4bd87db" alt=""
※ spec :: 20p
[ 메모리 맵 ]
data:image/s3,"s3://crabby-images/7f8cc/7f8cc4b3ceb86587a0eb41436d36146c55680de5" alt=""
※ spec :: 405p
Ex) Init_timer(void) 함수 구성
[ 타이머 카운터 0을 사용을 위한 PMC활성화 ]
data:image/s3,"s3://crabby-images/2dbef/2dbef3838a5b92f938762d99cdb25f048324ed88" alt=""
[ 타이머 클럭 비활성화 (TC_CCR설정) ]
data:image/s3,"s3://crabby-images/ce021/ce021954f24f67b7b5e4a816b90068f9dae51829" alt=""
※ spec :: 408p
data:image/s3,"s3://crabby-images/afee6/afee65bf6567f9a0ec08876896f4d53a00adf180" alt=""
[ 타이머 인터럽트 비활성화 (TC_IDR 설정) ]
data:image/s3,"s3://crabby-images/dc98c/dc98cb2e1381056de56b59d0a6f6df82e6a0fa2e" alt=""
data:image/s3,"s3://crabby-images/dc2ef/dc2efb33204c76ce81e14b44464df50c577d3814" alt=""
※ spec :: 421p
data:image/s3,"s3://crabby-images/0dc10/0dc105b9bcb0dcc90f465f3d4e359636a9348ed8" alt=""
[ 인터럽트 상태 정보 초기화 (TC_SR읽기) ]
data:image/s3,"s3://crabby-images/df08e/df08eb398566e2f19ccf3cc301cdab2ca2c5f2d5" alt=""
※ spec :: 418p
ㆍ읽으면 사용후 지워진다.
data:image/s3,"s3://crabby-images/03870/03870c3402ed7dc48a087e658999a6623bec0f46" alt=""
[ 분주비 1024, 비교 방식 레지스터 설정 ]
( TC_CMR, TIMER_CLOCK5, TC_CPCTRG )
data:image/s3,"s3://crabby-images/d112b/d112bb42e7894b6637888e6acf4eb474f6dcc7e3" alt=""
data:image/s3,"s3://crabby-images/6e435/6e435464a16d126170edecf8acf25db691de7f0f" alt=""
data:image/s3,"s3://crabby-images/607e3/607e3e91ba6877fc2f4fffd70d33da18622721a0" alt=""
※ spec :: 409p
data:image/s3,"s3://crabby-images/0e160/0e1609d0aa735d5144d12f430501109cfab5d756" alt=""
[ TC_RC 를 1초로 설정 ]
data:image/s3,"s3://crabby-images/cfa54/cfa545953b3cbfc9b0d3206a4c26fe16e4e95a9d" alt=""
※ spec :: 417p
ㆍ48kHz / 1024 = 49.152 :: 1ms
ㆍ 49.152/4 = 12.288 :: 0.25ms
data:image/s3,"s3://crabby-images/c1109/c1109c62e47e289206710dd2d9a891b2d3227225" alt=""
[ 타이머 카운터 0 인터럽트 비활성화 ( AIC_IDCR, TC0 ) ]
data:image/s3,"s3://crabby-images/11c60/11c60da9058615cc51df1f783f124ee8665b43dc" alt=""
[ 타이머 카운터 0 인터럽트 핸들러 등록 ]
(AIC_SVR :: TC0, timer_handler)
data:image/s3,"s3://crabby-images/fc72e/fc72ee49487b0fa928d5f0179f1892f79ec859c8" alt=""
ㆍ위와 같은 세련된 방식
data:image/s3,"s3://crabby-images/755d1/755d19d1dcda8f5bd73730b16984f5c1cbd6af60" alt=""
data:image/s3,"s3://crabby-images/07770/077704c347c5fe49d7aceeb8b2c1cd8ce585fea6" alt=""
[ 타이머 카운터 0 인터럽트 모드 설정 ]
(AIC_SMR :: TC0, AIC_SRCTYPE :: HIGH LEVEL, AIC_PRIOR :: LOWEST)
data:image/s3,"s3://crabby-images/3db73/3db734e72f8e1a8900e52f2d02ac48e5449ea479" alt=""
ㆍ위와 같은 세련된 방식
data:image/s3,"s3://crabby-images/806e5/806e561fd20f724e52f58c7fa02c9bf3667c3066" alt=""
data:image/s3,"s3://crabby-images/03d3e/03d3eec3e5e81257b94f65ff5427b5f20a87a4a1" alt=""
ㆍ최종 수정
data:image/s3,"s3://crabby-images/5578d/5578dffaded317d10eb9945a0d241ec78ac2eca6" alt=""
data:image/s3,"s3://crabby-images/dd02c/dd02c87f7e5a526397b286291303033a097bb99a" alt=""
[ 타이머 카운터 0 인터럽트 클리어 ]
(AIC_ICCR, TC0)
data:image/s3,"s3://crabby-images/51b40/51b403166114bf333bd5f86f0c65f9f0e8df0598" alt=""
※ spec :: 204p
data:image/s3,"s3://crabby-images/74d91/74d91f343bd5bfa04cbe1010c3f69210e4c7bdf1" alt=""
[ TC_RC 값 비교 타이머 인터럽트 활성화 ]
(AIC_IER, TC_CPCS)
data:image/s3,"s3://crabby-images/6f0c1/6f0c1dba8b1c7741344558eb8b894d5dccf74d85" alt=""
data:image/s3,"s3://crabby-images/1afd9/1afd9032c4966dd830e590ca8b550080dce4614a" alt=""
※ spec :: 420p
ㆍwaveform 을 사용할 경우 A, B를 설정하고 사용하지 않을경우 C로 설정한다.
data:image/s3,"s3://crabby-images/6f478/6f4780820bf9add297864ac45572470b1a1f9d76" alt=""
[ 타이머 카운터 0 인터럽트 활성화 ]
(AIC_IECR, TC0)
data:image/s3,"s3://crabby-images/bd6a3/bd6a3c1a6f1c034dd9f70ae00825dfc63976ab9f" alt=""
※ spec :: 203p
data:image/s3,"s3://crabby-images/44885/44885dc8528e9e590bc429ca6edac6065177858f" alt=""
[ 타이머 클럭 활성화 ]
(TC_CCR, TC_CLKEN)
data:image/s3,"s3://crabby-images/c7f7e/c7f7e3601fff824dbbd3e052aa080b6d5bea9319" alt=""
※ spec :: 203p
data:image/s3,"s3://crabby-images/e7877/e78779f900944a72d233680bda70db6a9a25d53e" alt=""
[ 타이머 시작 ]
(TC_CCR, TC_SWTRG)
data:image/s3,"s3://crabby-images/831c9/831c9222e05fc2b022221f23f0083a400f6fe462" alt=""
Ex) void timer_handler(void) 함수 구성
[ 인터럽트 상태 정보 초기화 ]
( TC_SR 읽기 )
data:image/s3,"s3://crabby-images/9cbc5/9cbc5b8889cf4ec5095def4183c6a42974463567" alt=""
[ LED 토글 프로그래밍 ]
data:image/s3,"s3://crabby-images/e39fb/e39fbf3d3bf3224095b4314344934b4914f00a77" alt=""
[ 인터럽트 상태 정보 초기화 ]
( TC_SR 읽기 )
data:image/s3,"s3://crabby-images/eca50/eca509516638e4b558941d31024e8b20628db3fc" alt=""
Ex) 전 AIC포스팅의 헤더파일에 Timer/Counter 추가 |
/*======================================================================== [ Timer/Counter (TC) : SPEC :: P.405 ]==================================== ========================================================================*/ #define TC_CCR (*((volatile unsigned int *)0xFFFA0000)) #define TC_CMR (*((volatile unsigned int *)0xFFFA0004)) //<Reserved>================================================== //<Reserved>================================================== #define TC_CV (*((volatile unsigned int *)0xFFFA0010)) #define TC_RA (*((volatile unsigned int *)0xFFFA0014)) #define TC_RB (*((volatile unsigned int *)0xFFFA0018)) #define TC_RC (*((volatile unsigned int *)0xFFFA001C)) #define TC_SR (*((volatile unsigned int *)0xFFFA0020)) #define TC_IER (*((volatile unsigned int *)0xFFFA0024)) #define TC_IDR (*((volatile unsigned int *)0xFFFA0028)) #define TC_IMR (*((volatile unsigned int *)0xFFFA002C)) //<Reserved>================================================== //[ TC_CCR ]============================================================ #define CLKEN 0 #define CLKDIS 1 #define SWTRG 2 //[ TC_IDR ]============================================================= #define COVFS 0 #define LOVRS 1 #define CPAS 2 #define CPBS 3 #define CPCS 4 #define LDRAS 5 #define LDRBS 6 #define ETRGS 7 //[ TC_SR ]=============================================================== #define CLSKSTA 16 #define MTIOA 17 #define MTIOB 18 //[ TC_CMR ]============================================================== #define TCCLKS 0 #define CLKI 3 #define BURST 4 #define LDBSTOP 6 #define LDBDIS 7 #define ETRGEDG 8 #define ABETRG 10 #define CPCTRG 14 #define WAVE 15 #define LDRA 16
#define TIMER_CLOCK5 4 |
Ex) timer 헤더 파일 |
#ifndef __TIMER_H__ #define __TIMER_H__
void Init_timer(void); void timer_handler(void);
#endif // __TIME_H__ |
Ex) 위 과정대로 함수 구성 |
#include "timer.h" #include "arm.h" #include "led.h"
void Init_timer(void) { PMC_PCER = 1 << TC0; TC_CCR = 1 << CLKDIS; // 타이머 클럭 비활성화
TC_IDR = 1 << COVFS| 1<<LOVRS| 1<<CPAS| 1<<CPBS| 1<<CPCS| 1<<LDRAS| 1<< LDRBS | 1<<ETRGS; TC_SR; TC_CMR = (TIMER_CLOCK5 << TCCLKS) | (1 << CPCTRG);
TC_RC = 49152;
AIC_IDCR = 1 << TC0;
AIC_SVR[TC0] = (unsigned int)timer_handler; AIC_SMR[TC0] = (AIC_SRCTYPE_INT_HIGH_LEVEL << SRCTYPE) | (AIC_PRIOR_LOWEST <<PRIOR); AIC_ICCR = 1 << TC0;
TC_IER = 1 << CPCS; AIC_IECR = 1 << TC0; TC_CCR = 1 << CLKEN; TC_CCR = 1 << SWTRG; return ; }
void timer_handler(void) { TC_SR; LED_toggle(); TC_SR; return ; } |
Ex) main 함수 |
#include "arm.h" #include "led.h" #include "aic.h" #define delay(x) for(dly = 0;100000 > dly; dly++) //[ 함수 선언부 ]==================== void Init(void); // 함수 호출 함수
int main() {
Init();
while(1); return 0; }
void Init(void) { Init_LED(); Init_AIC(); Init_timer(); return ; } |
< 실행 결과 동영상 참고 >