도와주세요!!
좋은 강좌와 자료 덕분에 별 어려움 없이 공부하고 있습니다.
감사합니다. ^^;;
기존에 보드위에서 돌아가는 어플만을 개발 하다가
부트로더를 손대게 되었습니다.
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....가 찍히는 것을 확인 하지 못하였습니다.
혹시 초기화 하는 부분에서 잘 못된 부분이 있는지요??
바쁘신데 긴 글 읽어 주셔서 감사합니다. (- -) (_ _)