[an error occurred while processing this directive]
|
//XTAL frequency in Hz
#define XTALFREQ 14745600//pclk must always be XTALFREQ/4 after reset and no set PLL
#define PCLKFREQ (XTALFREQ/4)#define BAUDRATE 9600
#define BAUDRATEDIVISOR (PCLKFREQ/(BAUDRATE*16))
//---
int GetProcessorClockFreq(void)
{
if((PLLCON & 0x3) == 0x3) // если PLL подключён (PLLC & PLLE = 1), то множитель = MSEL + 1
return (((PLLCFG & 0x1F) + 1) * XTALFREQ );
return XTALFREQ;
}int GetPeripheralClockFreq(void)
{
unsigned char c;
do { // Для кремния ревизии А, эррата VPBDIV.1 от 2005 May 2
c = VPBDIV & 0x03;
} while((VPBDIV & 0x03) != c);switch (c) {
case 1:
c = 1;
break;
case 2:
c = 2;
break;
default:
c = 4;
}
return GetProcessorClockFreq() / c;
}.... бла бла
PINSEL0_bit.P0_0=0x01; // Установка функции пина TxD (UART0)
PINSEL0_bit.P0_1=0x01; // Установка функции пина RxD (UART0)// FIFO исльзуем
U0FCR_bit.FCRFE = 1;//Установка скорости передачи
U0LCR_bit.DLAB = 1; // Разрешить доступ к делителю частоты для установки скорости передачиU0DLL = (GetPeripheralClockFreq()/(BAUDRATE*16)) & 0x00ff;
U0DLM = ((GetPeripheralClockFreq()/(BAUDRATE*16)) >> 8) & 0x00ff;
U0LCR_bit.DLAB = 0; // Запретили нах//Режим передачи
U0LCR_bit.WLS = 0x3; //8 бит
U0LCR_bit.SBS = 0x0; //1 стоп бит
U0LCR_bit.PE = 0x0; //Чётности нет//Разрешение прерываний UART0
U0IER_bit.RDAIE = 1; //Разрешить прерывания по приёму байта
U0IER_bit.THREIE = 1; //Разрешить прерывание по пустому буферу передачи.... бла бла
E-mail: info@telesys.ru