разбирался с делителями таймеров, начал копать LowLevelInit на предмет определения MCK, PLL работает на 96-ти мегагорцах, делитель на MCK был двойка:
pPMC->PMC_PLLR = ((AT91C_CKGR_DIV & 14 ) |
(AT91C_CKGR_PLLCOUNT & (28<<8)) |
(AT91C_CKGR_MUL & (72<<16)));
// Wait the startup time
while(!(pPMC->PMC_SR & AT91C_PMC_LOCK));
while(!(pPMC->PMC_SR & AT91C_PMC_MCKRDY));
// 4. Selection of Master Clock and Processor Clock
// select the PLL clock divided by 2
pPMC->PMC_MCKR = AT91C_PMC_PRES_CLK_2 ;
ради хохмы поменял последнюю строку на
pPMC->PMC_MCKR = AT91C_PMC_PRES_CLK;
все работает, таймера стали работать в два раза быстрее, проверил все делители, замерил осциллографом частоту на выходе таймера, получается, что MCK действительно равно 96 мегов.
Попробовал на другой плате, работает пять секунд и зависает. Я так понимаю, что это просто один удачный кристалл, или я все-таки не правильно считаю? Возможна ли работа данного контроллера на такой частоте? По даташиту максимум 55 мегов...