register 다루는법 < 소스코드 분석>
글쓴이: 삼구의신 / 작성시간: 화, 2017/12/05 - 4:12오후
아래 코드가 있는데 전혀 뭐하는건지 모르겠네요..ㅠㅠ
해석좀 도와주세요.
WF(SPILE, 1); // 이렇게 호출해서 쓰고 SPILE 값은 이렇게 정의 되어 있는데 저 enum 이 뭐에 쓰이는지를 모르겠는데 혹시 임베디드에서 저런식으로 코딩을 어떨때 하는지 아시나요? enum _register_bit { SPICLK, SPILE, SPISDIO, INRESET, INSEL0, INSEL1, SYNC, LDDEVICE, LDPLL2, SPISDIODIR }; //이건 함수 내용이에요 u16 lmk04828b_spi::WF(u16 field, u16 data) { u32 addr = DEV_BASE + DeviceIndex; u16 temp; temp = Read(addr); temp = (u32)(((~(1 << field)) & temp) | ((1 << field) & (data << field))); Write(addr, temp); return(temp); }
아래 코드처럼 define 해놨는데 LMK04828B 라는 칩에 register를 다루는건가요? 이런건 datasheet 봐도 안나오는데 뭘 의미 하는지 모르겠어요 도와주세요 #define LMK04828B_REGISTER148 0x148 #define LMK04828B_REGISTER148_TYP_VAL_V (0x014833 & 0xFF)
Forums:
enum은
enum은
#define SPICLK 0
#define SPILE 1
과 똑같아요. 대부분 어떤 시작 번지(base address)에서의 거리(offset)을 가리킬 때 씁니다.
datasheet에 148로 찾아보세요. 아니면 328(10진수)로요. 뭔가 나와도 나올 겁니다.
답변 감사드립니다.
답변 감사드립니다.
제가 잘 설명을 못한것 같네요 ㅠㅠ
enum은 저도 아는데 SPICLK SPILE 이 프로그래밍에서 자주 쓰이는건지 쓰인다면 어떤것을 의미하는건지 궁금했던것 입니다.
148로 겁색해보니
ADDRESS | DATA
[11:0] | 7 | 6 | 5 4 3 | 2 1 0
148 | 0 | 0 | CLKin_SEL0_MUX | CLKin_SEL0_TYPE
이런식으로 써있네요 ㅎㅎ
앞서 말씀드린대로 offset을 주기 위한 용도로
앞서 말씀드린대로 offset을 주기 위한 용도로 주로 사용됩니다.
예를 들어
(* addr) = (* addr) | (1 << SPICLK);
하면 특정 주소의 0번째 비트를 '1'로 세팅하는 것이죠.
친절한 답변 감사드립니다.
친절한 답변 감사드립니다.
더 공부하고 다시 물어봐야겠네요 ㅠㅠ
https://dojang.io/mod/page
https://dojang.io/mod/page/view.php?id=480
세벌 https://sebuls.blogspot.kr/
비트 연산자를 공부해 보셔요.https://www
비트 연산자를 공부해 보셔요.
https://www.arduino.cc/reference/ko/language/structure/bitwise-operators/bitwiseand/
https://www.arduino.cc/reference/ko/language/structure/bitwise-operators/bitwiseor/
https://www.arduino.cc/reference/ko/language/structure/bitwise-operators/bitwisenot/
https://www.arduino.cc/reference/ko/language/structure/bitwise-operators/bitshiftleft/
도움이 될 겁니다.
세벌 https://sebuls.blogspot.kr/
답변 감사드립니다. 공부해보겠습니다^^
답변 감사드립니다. 공부해보겠습니다^^
댓글 달기