Pārlūkot izejas kodu

add reset PFD3

teensy4-core
Frank pirms 6 gadiem
vecāks
revīzija
da35bc16c7
Revīzijas autora e-pasta adrese nav piesaistīta nevienam kontam
1 mainītis faili ar 15 papildinājumiem un 4 dzēšanām
  1. +15
    -4
      teensy4/startup.c

+ 15
- 4
teensy4/startup.c Parādīt failu

static void memory_copy(uint32_t *dest, const uint32_t *src, uint32_t *dest_end); static void memory_copy(uint32_t *dest, const uint32_t *src, uint32_t *dest_end);
static void memory_clear(uint32_t *dest, uint32_t *dest_end); static void memory_clear(uint32_t *dest, uint32_t *dest_end);
static void configure_systick(void); static void configure_systick(void);
static void reset_PFD();
extern void systick_isr(void); extern void systick_isr(void);
extern void pendablesrvreq_isr(void); extern void pendablesrvreq_isr(void);
void configure_cache(void); void configure_cache(void);
for (i=0; i < NVIC_NUM_INTERRUPTS; i++) NVIC_SET_PRIORITY(i, 128); for (i=0; i < NVIC_NUM_INTERRUPTS; i++) NVIC_SET_PRIORITY(i, 128);
SCB_VTOR = (uint32_t)_VectorsRam; SCB_VTOR = (uint32_t)_VectorsRam;


reset_PFD();
// Configure clocks // Configure clocks
// TODO: make sure all affected peripherals are turned off! // TODO: make sure all affected peripherals are turned off!
// PIT & GPT timers to run from 24 MHz clock (independent of CPU speed) // PIT & GPT timers to run from 24 MHz clock (independent of CPU speed)


configure_cache(); configure_cache();
configure_systick(); configure_systick();
usb_pll_start();

CCM_ANALOG_PFD_528_SET = (1 << 31) | (1 << 23) | (1 << 15) | (1 << 7);
CCM_ANALOG_PFD_528 = 0x2018101B; // PFD0:352, PFD1:594, PFD2:396, PFD3:297 MHz
usb_pll_start();
reset_PFD(); //TODO: is this really needed?
set_arm_clock(600000000); set_arm_clock(600000000);
//set_arm_clock(984000000); Ludicrous Speed //set_arm_clock(984000000); Ludicrous Speed
} }
} }


__attribute__((section(".progmem")))
void reset_PFD()
{
//Reset PLL2 PFDs, set default frequencies:
CCM_ANALOG_PFD_528_SET = (1 << 31) | (1 << 23) | (1 << 15) | (1 << 7);
CCM_ANALOG_PFD_528 = 0x2018101B; // PFD0:352, PFD1:594, PFD2:396, PFD3:297 MHz
//PLL3:
CCM_ANALOG_PFD_480_SET = (1 << 31) | (1 << 23) | (1 << 15) | (1 << 7);
CCM_ANALOG_PFD_480 = 0x13110D0C; // PFD0:720, PFD1:664, PFD2:508, PFD3:454 MHz
}


// Stack frame // Stack frame
// xPSR // xPSR

Notiek ielāde…
Atcelt
Saglabāt