Forum: Mikrocontroller und Digitale Elektronik externer NOR Flash mit ARM9


von Tim (Gast)


Lesenswert?

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

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.