좋은 강좌와 자료 덕분에 별 어려움 없이 공부하고 있습니다.

감사합니다. ^^;;

 

기존에 보드위에서 돌아가는 어플만을 개발 하다가

부트로더를 손대게 되었습니다.

 

ezboot를 보니 디버깅용으로 세번째 시리얼 포트 ttySAC2를 사용하던데요.

console.c에서 초기화를 담당하던데요.

관련 부분은

 

//******************************************************************************
// 전역 변수 정의
//******************************************************************************
static volatile u32 *UART = (volatile u32 *) &(S3C2440_REG_UART2_BASE); // UART 베이스 어드레스


#define UART_LCR  ((volatile u32) UART[ 0])    //  UART line control register
#define UART_UCR  ((volatile u32) UART[ 1])    //  UART control register
#define UART_FCR  ((volatile u32) UART[ 2])    //  UART FIFO control register
#define UART_MCR  ((volatile u32) UART[ 3])    //  UART modem control register
#define UART_TRxSTAT ((volatile u32) UART[ 4])    //  UART Tx/Rx status register
#define UART_ERRSTAT ((volatile u32) UART[ 5])    //  UART Rx error status register
#define UART_FSR  ((volatile u32) UART[ 6])    //  UART FIFO status register
#define UART_MSR  ((volatile u32) UART[ 7])    //  UART modem status register
#define UART_TXD  ((volatile  u8) UART[ 8])    //  UART transmit buffer register
#define UART_RXD  ((volatile  u8) UART[ 9])    //  UART receive buffer register
#define UART_BAUD  ((volatile u32) UART[10])    //  Baud rate divisor register

 

//******************************************************************************
//------------------------------------------------------------------------------
// 설명 : S3C2440의 콘솔용 시리얼 디바이스를 초기화 한다.
// 매계 : 없음
// 반환 : 없음
// 주의 : 없음
//------------------------------------------------------------------------------
void console_init( u32 baudrate)
{
    int  dummy;
                                                                 
    // 포트를 선택한다.
 UART = (volatile u32 *) &(S3C2440_REG_UART2_BASE);
 


    UART_LCR  = ULCON_VALUE;     // Normal mode, No parity, 1-stop bit, 8-bits
    UART_MCR  = UMCON_AFC;            // 모뎀 콘트롤 Disable
    UART_FCR  = UFCON_TX_FIFO_TRG_LEVEL |  // FIFO RESET and Enable
     UFCON_RX_FIFO_TRG_LEVEL |
     UFCON_TX_FIFO_RESET    |
     UFCON_RX_FIFO_RESET  |
     UFCON_FIFO_EN;

    UART_FCR  = UFCON_TX_FIFO_TRG_LEVEL |  // FIFO Enable
     UFCON_RX_FIFO_TRG_LEVEL |
     UFCON_FIFO_EN;

    UART_UCR    =  UCON_VALUE;      // UART Control Register   

    UART_BAUD  = ( (u32)(PCLK/(16*baudrate)) -1 ); // UART BAUD Rate Divisor Register   

    dummy = UART_ERRSTAT;
}

 

 

 

이 부분들이 아닐까 생각합니다.

저는 기존 ttySAC2는 콘솔용으로 그대로 사용 할 생각이라서,, 저 부분은 가만히 놔둬도 된다고 생각을 하고

이렇게

 

static volatile u32 *UART_1 = (volatile u32 *) &(S3C2440_REG_UART0_BASE);

 

새로 변수를 하나 선언을 하고

 

위의 초기화를 따라 아래와 같이 소스를 추가 하였습니다.

#define UART1_LCR  ((volatile u32) UART_1[ 0])    //  UART line control register
#define UART1_UCR  ((volatile u32) UART_1[ 1])    //  UART control register
#define UART1_FCR  ((volatile u32) UART_1[ 2])    //  UART FIFO control register
#define UART1_MCR  ((volatile u32) UART_1[ 3])    //  UART modem control register
#define UART1_TRxSTAT ((volatile u32) UART_1[ 4])    //  UART Tx/Rx status register
#define UART1_ERRSTAT ((volatile u32) UART_1[ 5])    //  UART Rx error status register
#define UART1_FSR  ((volatile u32) UART_1[ 6])    //  UART FIFO status register
#define UART1_MSR  ((volatile u32) UART_1[ 7])    //  UART modem status register
#define UART1_TXD  ((volatile  u8) UART_1[ 8])    //  UART transmit buffer register
#define UART1_RXD  ((volatile  u8) UART_1[ 9])    //  UART receive buffer register
#define UART1_BAUD  ((volatile u32) UART_1[10])    //  Baud rate divisor register

 

void console_init1( u32 baudrate)
{
 int  dummy;

 // 포트를 선택한다.
 UART_1 = (volatile u32 *) &(S3C2440_REG_UART0_BASE);

 UART1_LCR  = ULCON_VALUE;     // Normal mode, No parity, 1-stop bit, 8-bits
 UART1_MCR  = UMCON_AFC;            // 모뎀 콘트롤 Disable
 UART1_FCR  = UFCON_TX_FIFO_TRG_LEVEL |  // FIFO RESET and Enable
  UFCON_RX_FIFO_TRG_LEVEL |
  UFCON_TX_FIFO_RESET    |
  UFCON_RX_FIFO_RESET  |
  UFCON_FIFO_EN;

 UART1_FCR  = UFCON_TX_FIFO_TRG_LEVEL |  // FIFO Enable
  UFCON_RX_FIFO_TRG_LEVEL |
  UFCON_FIFO_EN;

 UART1_UCR    =  UCON_VALUE;      // UART Control Register   

 UART1_BAUD  = ( (u32)(PCLK/(16*baudrate)) -1 ); // UART BAUD Rate Divisor Register   

 dummy = UART1_ERRSTAT;
 
}

 

그리고 main.c에서 해당 함수를 호출 하는 부분을 추가 시켰는데요.

 

이렇게 작성을 하고 시리얼 포트가 초기화가 되서 제대로 통신이 되는지 확인을 해 보고 싶어서

 

void console_putc2()
{
 //
 int i = 0;
 while(!(UART1_TRxSTAT & UTRxSTAT_TX_EMPTY)) ;  // 전송 가능할때까지 기다린다.
 for(i=0;i<100;i++)
 {
  UART1_TXD = 'a';         // 시리얼에 데이타를 출력한다.  ttySAC0
 }
 while(!(UART_TRxSTAT & UTRxSTAT_TX_EMPTY)) ;  // 전송 가능할때까지 기다린다.
 for(i=0;i<100;i++)
 {
  UART_TXD = 'b';         // 시리얼에 데이타를 출력한다.  ttySAC2
 }
}

 

이와 console_putc함수를 참고하여 작성해 보았습니다.

이렇게 작성하고 확인 해 본 결과

콘솔용(ttySAC2)으로는 bbbbbbbb...가 잘 찍히는데,,

ttySAC0에서는 의도한 aaaaaa....가 찍히는 것을 확인 하지 못하였습니다.

 

혹시 초기화 하는 부분에서 잘 못된 부분이 있는지요??

 

바쁘신데 긴 글 읽어 주셔서 감사합니다. (- -) (_ _)