회원가입 ID/PW 찾기

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

콘텐츠 수 63
판매자 어부 판매 납포인트 무료 평점 0점 / 총 0명 참여

 

 

atmega128에 시리얼통신칩 16c550 연결하기

 

첨부파일은 회로도 입니다.

저는 128에 16c550 을 6개 연결해서 사용 했습니다.

 

설정값은 9600,n,8,1  STX= 2(HEX),  ETX=3(HEX)

처음에  x16c550A()실행하고

송신할때 TxPd1_data(포인트)에 문자열 data 저장하고 Pd1start() 호출하면 전송됩니다.

수신은 STX부터 ETX까지 수신하고 Pd1end_data=1완료 바이트저장

 

tx start

void Pd1start_tx(void)
{
unsigned char xCmdb;
static cha;


 PORTA=0x00;DDRA=0x00;
 CLR_BIT(Dsd14,cs1);
 SET_BIT(addr,A0);CLR_BIT(addr,A1);SET_BIT(addr,A2);
 CLR_BIT(CTRL,rd);non();
 xCmdb=PINA;SET_BIT(CTRL,rd);
 SET_BIT(Dsd14,cs1);
  
 cha=*TxPd1_data++;
 if (cha !=0x00)
  { 
  DDRA=0xff;CLR_BIT(Dsd14,cs1);
  PORTA=cha;
  CLR_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
  CLR_BIT(CTRL,wr);SET_BIT(CTRL,wr);SET_BIT(Dsd14,cs1);
  Txpd1On=1;
  } 
}

 

 

16c550 설정

void x16c550A_init(void)
{
 unsigned char xCmd;
 unsigned char m_ina;
 DDRA=0xff;
 CLR_BIT(Dsd14,cs1);PORTA=0x80;
 SET_BIT(addr,A0);SET_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,wr);SET_BIT(CTRL,wr);SET_BIT(Dsd14,cs1);
 
 CLR_BIT(Dsd14,cs1);PORTA=0x06;  
 CLR_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,wr);SET_BIT(CTRL,wr);SET_BIT(Dsd14,cs1);
 
 CLR_BIT(Dsd14,cs1);PORTA=0x00;
 SET_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,wr);SET_BIT(CTRL,wr);SET_BIT(Dsd14,cs1);
 
 CLR_BIT(Dsd14,cs1);PORTA=0x03;
 SET_BIT(addr,A0);SET_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,wr);SET_BIT(CTRL,wr);SET_BIT(Dsd14,cs1); 

 CLR_BIT(Dsd14,cs1);PORTA=0x03;    //rx/tx interrupt enable
 SET_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,wr);SET_BIT(CTRL,wr);SET_BIT(Dsd14,cs1);


 CLR_BIT(Dsd14,cs1);PORTA=0x01;
 CLR_BIT(addr,A0);SET_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,wr);SET_BIT(CTRL,wr);SET_BIT(Dsd14,cs1);


 PORTA=0x00;DDRA=0x00;
 CLR_BIT(Dsd14,cs1);
 CLR_BIT(addr,A0);SET_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,rd);non();
 m_ina=PINA;SET_BIT(CTRL,rd);
 SET_BIT(Dsd14,cs1);

 DDRA=0x00;CLR_BIT(Dsd14,cs1);
 CLR_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,rd);non();xCmd=PINA;SET_BIT(CTRL,rd);
 SET_BIT(Dsd14,cs1); 
 
uastbyA:;
 PORTA=0x0;CLR_BIT(Dsd14,cs1);
 SET_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,rd);non();xCmd=PINA;SET_BIT(CTRL,rd);
 SET_BIT(Dsd14,cs1);
 if ((xCmd & 0x01) !=0x01) {goto uastbyA;}
 icont=xCmd;
}

 

tx, rx 인터럽터사용

ISR(INT0_vect)
{
unsigned char lsr; 
 
 // PD1
 PORTA=0x00;
 DDRA=0x00;
 SET_BIT(addr,A0);CLR_BIT(addr,A1);SET_BIT(addr,A2);
 CLR_BIT(Dsd14,cs1);
 //SET_BIT(addr,A0);CLR_BIT(addr,A1);SET_BIT(addr,A2);
 CLR_BIT(CTRL,rd);
 non();lsr=PINA;
 SET_BIT(CTRL,rd);
 SET_BIT(Dsd14,cs1); 
 if ((lsr & 0x20)==0x20) {Pd1tx();}
 if ((lsr & 0x01)==0x01) {Pd1rx();}   
}

 

tx

void Pd1tx(void)
{
unsigned char xCmdb;
unsigned char cha;

 if (Txpd1On==1)
  {
uastbyB:;
  PORTA=0x00;
  DDRA=0x00;
  CLR_BIT(Dsd14,cs1);
  SET_BIT(addr,A0);CLR_BIT(addr,A1);SET_BIT(addr,A2);
  CLR_BIT(CTRL,rd);
  xCmdb=PINA;
  SET_BIT(CTRL,rd);
  SET_BIT(Dsd14,cs1);
  if ((xCmdb & 0x20) !=0x20){goto uastbyB;} 
 
  cha=*TxPd1_data++;
  if (cha !=0x00)
   { 
   DDRA=0xff;
   CLR_BIT(Dsd14,cs1);
   PORTA=cha;
   CLR_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
   CLR_BIT(CTRL,wr);
   SET_BIT(CTRL,wr); 
   SET_BIT(Dsd14,cs1);
   }
   else {Txpd1On=0;
     PORTA=0x00;DDRA=0x00;
     CLR_BIT(Dsd14,cs1);
     CLR_BIT(addr,A0);SET_BIT(addr,A1);CLR_BIT(addr,A2);
     CLR_BIT(CTRL,rd);non();
     xCmdb=PINA;SET_BIT(CTRL,rd);
     SET_BIT(Dsd14,cs1);
     }
  } 
}

rx
void Pd1rx(void)
{
unsigned char xCmdb;
unsigned char cha;
 
 DDRA=0x00;CLR_BIT(Dsd14,cs1);
 CLR_BIT(addr,A0);CLR_BIT(addr,A1);CLR_BIT(addr,A2);
 CLR_BIT(CTRL,rd);non();xCmdb=PINA;SET_BIT(CTRL,rd);  //rx data read
 SET_BIT(Dsd14,cs1);  
 if (xCmdb ==STX) 
  {
  Pd1buff_init();        //rx buff clr
  RxPd1_buf[Pd1cnt]=xCmdb;     //RX buff write
  Pd1cnt++;
  } 
  else
   {if (xCmdb==ETX)
    {Pd1end_data=1;}
    RxPd1_buf[Pd1cnt]=xCmdb;   //data write
    Pd1cnt++;       //address +1
    if (Pd1cnt>120) {Pd1buff_init();} //over buff 
   }  
}


profile
om 2016.06.08 06:23

16c550은 오래된 IC인데,지금도 사용하고 있나보네요?

 

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 3955
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.