Hallo,
bei meinem aktuellen Projekt arbeite ich mit einem ARM9 (AT91SAM9261)
und dem externen NOR Flash (Spansion S29GL128P) als Startmedium
(Programm startet im externen NOR Flash).
Momentan habe ich das Problem, wenn ich in der Startup Phase
(LowLevelInit) die PLL als MasterClock konfiguriere, bleibt mein
Programm hängen.
1 | /*-------------------------------------------------------------------------*/
|
2 | /* Haupt-Oscillator einschalten
|
3 | * Start-Up Time: 8 * 8 Slow Clock Cycles
|
4 | */
|
5 | AT91C_BASE_PMC->PMC_MOR = (AT91C_CKGR_OSCOUNT & (8 << 8)) + AT91C_CKGR_MOSCEN;
|
6 | while (!(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_MOSCS));
|
7 | /*-------------------------------------------------------------------------*/
|
8 | /* PLL-A aktivieren (18.432 MHz * 217 / 20 = 199.987 MHz)
|
9 | */
|
10 | AT91C_BASE_PMC->PMC_PLLAR = (0x14 << 0) | (0x3E << 8) | (0 << 14) | (0x0D8 << 16) | (1 << 29);
|
11 | while (!(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_LOCKA));
|
12 | /*-------------------------------------------------------------------------*/
|
13 | /* PLL-B aktivieren (18.432 MHz * 138 / 53 = 47.993 MHz)
|
14 | */
|
15 | AT91C_BASE_PMC->PMC_PLLBR = (0x35 << 0) | (0x3E << 8) | (0 << 14) | (0x089 << 16) | (0 << 28);
|
16 | while (!(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_LOCKB));
|
17 | /*-------------------------------------------------------------------------*/
|
18 | /* Master clock prescaler (prescaler zero)
|
19 | */
|
20 | AT91C_BASE_PMC->PMC_MCKR = AT91C_PMC_PRES_CLK;
|
21 | while (!(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_MCKRDY));
|
22 | /*-------------------------------------------------------------------------*/
|
23 | /* PLL-B als Master Clock
|
24 | */
|
25 | AT91C_BASE_PMC->PMC_MCKR |= AT91C_PMC_CSS_PLLB_CLK; <-- an der Stelle hängt er sich auf
|
26 | while (!(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_MCKRDY));
|
27 | /*-------------------------------------------------------------------------*/
|
Ich weiß momentan leider nicht warum. Muss ich im Vorfeld noch andere
Initialisierungsschritte beachten? Wenn ich in den Examples gucke,
fangen sie dort bei der LowLevel-Initialisierung auch mit dem Clock an.
Tim