lpc1768でUARTのボーレートを変更する方法に問題があります。
uartを初期化して構成するには、次のコードを使用します。これは、9600ボーまたは38400で正常に機能します。
/* RxD0 is P0.3 and TxD0 is P0.2 */
LPC_PINCON->PINSEL0 &= ~(0x03<<4); // Reset P0.2 = GPIO
LPC_PINCON->PINSEL0 |= (0x01<<4); // Config P0.2 = TxD0
LPC_PINCON->PINSEL0 &= ~(0x03<<6); // Reset P0.3 = GPIO
LPC_PINCON->PINSEL0 |= (0x01<<6); // Config P0.3 = RxD0
LPC_UART0->LCR = 0x87; //8bits, no parity, 2 stop bits
switch (baudrate)
{
default :
case 9600 :
LPC_UART0->DLM = 0x00; //calculated with datasheet
LPC_UART0->DLL = 0x4E;
LPC_UART0->FDR = 0x21;
break;
case 38400 :
LPC_UART0->DLM = 0x00; //calculated with datasheet
LPC_UART0->DLL = 0x14;
LPC_UART0->FDR = 0xF7;
}
LPC_UART0->LCR = 0x07;//0x03; /* DLAB = 0 */
LPC_UART0->FCR = 0x07; /* Enable and reset TX and RX FIFO. */
NVIC_EnableIRQ(UART0_IRQn);
LPC_UART0->IER = IER_RBR | IER_THRE | IER_RLS; /* Enable UART0 interrupt */
しかし、ボーレートを9600から38400に変更するには、DLM / DLLおよびFDRレジスタを適切な値に変更しようとします(上記のコードと同じ)。しかし、それは機能しません...(ボーレートは定義されていません)。
私のpclkは18MHzです
これらの3つのレジスタだけを変更するだけでは不十分ですか?私が間違っている ?