회원가입 ID/PW 찾기

1) 지식 창고는 본인이 작성한 콘텐츠(팁/노하우/리소스/강좌 등)을 무료 혹은 가상화폐인 납포인트를 통해 공유하는 공간입니다.
2) 본인이 작성한 콘텐츠에 대해서만 지식 창고에 등록할 수 있으며, 저작권에 위배되는 콘텐츠는 사전경고 없이 삭제될 수 있습니다.
3) 콘텐츠 구매 및 첨부파일 다운로드는 회원그룹 '연구원' 이상 가능하오니, 경험치를 쌓아 진급한 후에 이용 부탁드립니다.
4) 무료 콘텐츠의 본문은 구매절차 없이 즉시 이용할 수 있으며, 판매 납포인트가 있는 콘텐츠는 구매 후 이용할 수 있습니다.
5) 콘텐츠 판매에 따른 납포인트 수익은 지정한 비율(50%)에 따라 판매자에게 지급하며, 납포인트 수익을 통해 진급을 빨리할 수 있습니다.
6) 구매 후 평가를 하면 구매 납포인트의 20%를 돌려 드립니다.

콘텐츠 수 63

Software I2C

마이크로프로세서 구매수 0 2010.02.09 14:50:33
판매자 lion 판매 납포인트 무료 평점 0점 / 총 0명 참여

1. Software I2C

대부분의 MCU등 메인 CHIP CUP에는 전용 I2C포트가 내장되어 있어
, 해당 핀을 H/W적으로 연결하는 것만으로도I2C동작을 수행할 수 있다.
그러나, I2C로 컨트롤 해야 하는 주변장치가 많거나
, 혹은 I2C 포트가 추가로 필요할 경우 상황에 따라
, 일반 GPIO포트를 사용하여 I2C컨트롤을 해야 한다.
즉 S/W I2C컨트롤이 가능해야 한다. 매번 필요한 상황은 아니지만
, 해당 소스코드를 모듈형태로 작성하여 프로그래머는 간단한 Define만으로
해당 기능을 사용할 수 있도록 모듈화 시켜 사용의 편리성을 증대시키고
, 불필요한 코딩 시간을 줄이는 것을 목적으로 한다.

 

2. s/w i2c module

함수에 대한 설명은 생략 하였음. 소스코드의 기본 동작은 Standard I2C Format과 호환되도록 작성함

 

1) 함수 선언

#define SCL_PORT   GPIO_PORT x          //클럭 라인으로 사용할 포트 지정

#define SDA_PORT   GPIO_PORT y          //데이터 라인으로 사용할 포트 지정

 

#define SET_SCL(x)   SCL_PORT=x         //클럭 포트의 High / Low 변경

#define SET_SDA(x)   SDA_PORT=x         //데이터 포트의 High/Low 변경


BOOL GET_SDA()
{
    return SETUP_SDA;
}

void I2C_START(void)    
{
    SET_SDA( HIGH );
    SET_SCL( HIGH );
    DelayUs(5);
    SET_SDA( LOW );
    DelayUs(5);
    SET_SCL( LOW );
}

void I2C_STOP( void )    
{
    SET_SDA( LOW );
    SET_SCL( HIGH );
    DelayUs(5);
    SET_SDA( HIGH );
}

BOOL I2C_WAIT_ACK( void )        //Acknowledge
{
    BOOL ack_bit_value;
    unsigned int count;
 
    SET_SDA( HIGH );
    SDA_DIR = SET_INPUT;       //set input port
    SET_SCL( HIGH );
    ack_bit_value = SDA_PORT;
    while(ack_bit_value);          //waiting ack.
    count = 0;
    while(ack_bit_value);          //waiting ack.
    SET_SCL( LOW );
    SDA_DIR =SET_OUTPUT;    //set output port
    return ack_bit_value;
}

void I2C_SEND_ACK( BOOL bit_value )
{
    SET_SDA( bit_value );
    SET_SCL( HIGH );
    SET_SCL( LOW );
    SET_SDA( HIGH );
}

BYTE I2C_READ( void )
{
    BYTE bit_cnt, byte_data;
    BOOL bit_value;
 
    byte_data = 0;
    SDA_DIR = SET_INPUT;       //set input port
    for(bit_cnt=0; bit_cnt<8; bit_cnt++)
    {
                  SET_SCL( HIGH );
                  DelayUs(2);
                  bit_value = SDA_PORT;
                  SET_SCL( LOW );
                  DelayUs(2);
                  byte_data |=  (bit_value<<(7-bit_cnt));
                  DelayUs(2);
    }
    SDA_DIR = SET_OUTPUT;                              //set output port
    return byte_data;
}

void I2C_WRITE( BYTE byte_data )
{
    BYTE bit_cnt, tmp;
    BOOL bit_value;
 
    for(bit_cnt=0; bit_cnt<8; bit_cnt++)
    {
                  tmp = (byte_data << bit_cnt) & 0x80;
                  bit_value = (tmp >> 7)&0x01;
                  SET_SDA( bit_value );
                  DelayUs(2);
                  SET_SCL( HIGH );
                  DelayUs(2);
                  SET_SCL( LOW );
                  DelayUs(2);
    }

}

초보라 잘은 모르지만 검색해서 모아둔 자료 공유해 봅니다.


profile
사운드웨어 2010.02.19 13:53
오 감솨~
profile
살흰애 2010.03.24 01:32
Micro second 단위 delay 와 I2C 라인 두놈 셋/리셋 하는 것만 구현하면 그냥 되겠네요. 코드가 이렇게 짧고 간단하게 나올 줄이야~ 정말 감사합니다. ^^
profile
백미르 2010.06.01 17:48

감사합니다.

profile
시나브로69 2016.07.16 17:38

좋은 자료 감사합니다.

search
List of Articles
번호 분류 제목 평점 포인트 판매자 등록일 구매수 조회 수
공지 공공의 목적으로 공유하고자 하는 소프트웨어는 '소프트웨어 자료실'에 업로드를 요청드립니다.
공지 구매후 평점 댓글을 남겨주시면 구매포인트의 20%를 돌려드립니다.
63 Digital 회로 설계 데이터 전송 인터페이스 LVDS Application and Data Handbook [2] 무료 아크마 2018-02-18 0 195
62 Digital 회로 설계 LVDS 의 이해 (National Semicon) [10] 무료 2014-08-18 0 618
61 Digital 회로 설계 I2C-BUS의 이해 (Philips Semicon) [13] 무료 2014-08-18 0 378
60 Digital 회로 설계 회로도 좀 부탁 드립니다. [2] 무료 Binic 2013-07-16 0 1046
59 Digital 회로 설계 cds를 이용한 LED제어에 관하여~ [2] 무료 후리후리 2012-11-23 0 2413
58 Digital 회로 설계 회로도 부탁 드립니다.fishing Bot 회로도 [1] 무료 용탄왕자 2011-09-29 0 3954
57 Digital 회로 설계 Interfacing PECL to LVDS [5] 무료 아크마 2011-04-14 0 2817
56 Digital 회로 설계 TMDS[DVI & HDMI]입력 LVDS 출력 회로도 혹 구성은 ? [4] 무료 정상까지 가보자! 2011-04-08 0 6875
55 Digital 회로 설계 verilog 기초에 관해 중요한 정보들 정리되어있어요~ [9] 무료 나는야한다 2010-09-07 0 2837
54 Digital 회로 설계 Verilog 문법입니다. [12] 무료 연구연구 2010-08-09 0 4285
53 Digital 회로 설계 TTL과 CMOS 관련 자료입니다. [5] 무료 풩님 2010-07-20 0 2466
52 Digital 회로 설계 74시리즈에 대한 이해 [5] 무료 s나이키 2010-07-01 0 2096
51 Digital 회로 설계 표준로직 IC나 PLD도 구사하는 로직 디바이스의 기초 [5] 무료 샤스케 2010-06-24 0 1774
50 Digital 회로 설계 바이패스 콘덴서란! [18] 무료 김사장 2010-04-06 0 2619
49 Digital 회로 설계 분주회로 [9] 무료 김사장 2010-04-06 0 5622
48 Digital 회로 설계 d2audio라는 class-d amplifier자료입니다 [2] 무료 퀴아쿠 2010-02-19 0 2218
47 Digital 회로 설계 Karnaugh map Minimizer [5] 무료 티케 2009-12-22 0 2439
46 Digital 회로 설계 디지털 아나로그 ZIC 활용입문 [5] 무료 하이에나 2009-12-15 0 2148
45 Digital 회로 설계 순차회로설계~! [21] 무료 roruca 2009-11-19 0 2971
44 Digital 회로 설계 555 timer R,C 계산 PROGRAM [7] 무료 엘시알 2009-10-28 0 3861
  • 전쟁에선 어느 편이 스스로를 승자라고 부를지라도 승리자는 없고 모두 피해자뿐이다.
    - 챔벌린
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.