2016-08-29 11:29:07 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core module: clock
|
|
|
|
//
|
|
|
|
// Measures the frequency of the MPU clocks. This module assumes that the
|
|
|
|
// clock mode is 3 on SH7305 (as does FTune).
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
2016-09-04 11:35:41 +02:00
|
|
|
#ifndef _CLOCK_H
|
|
|
|
#define _CLOCK_H
|
|
|
|
|
2017-03-01 11:07:28 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2016-08-29 11:29:07 +02:00
|
|
|
//---
|
2017-02-25 19:02:07 +01:00
|
|
|
// Sleep functions.
|
2016-08-29 11:29:07 +02:00
|
|
|
//---
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
/*
|
|
|
|
sleep()
|
|
|
|
Puts the processor to sleep until an interrupt request is issued.
|
|
|
|
*/
|
|
|
|
void sleep(void);
|
|
|
|
|
|
|
|
/*
|
2017-03-01 11:07:28 +01:00
|
|
|
sleep_ms()
|
|
|
|
Sleeps for the given number of milliseconds using a virtual timer.
|
2017-02-25 19:02:07 +01:00
|
|
|
*/
|
|
|
|
void sleep_ms(int ms_delay);
|
2017-03-01 11:07:28 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
sleep_us()
|
|
|
|
Sleeps for the given number of microseconds using the hardware timer
|
|
|
|
timer_user.
|
|
|
|
*/
|
2017-02-25 19:02:07 +01:00
|
|
|
void sleep_us(int us_delay);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Clock management.
|
|
|
|
//---
|
2016-08-29 11:29:07 +02:00
|
|
|
|
|
|
|
enum ClockUnit
|
|
|
|
{
|
|
|
|
Clock_us = 0,
|
|
|
|
Clock_ms = 1,
|
|
|
|
Clock_s = 2,
|
|
|
|
|
|
|
|
Clock_Hz = 10,
|
|
|
|
Clock_kHz = 11,
|
|
|
|
Clock_MHz = 12,
|
|
|
|
};
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
typedef struct
|
2016-08-29 11:29:07 +02:00
|
|
|
{
|
|
|
|
union
|
|
|
|
{
|
|
|
|
int PLL1; // SH7705
|
|
|
|
int FLL; // SH7305
|
|
|
|
};
|
|
|
|
union
|
|
|
|
{
|
|
|
|
int PLL2; // SH7705
|
|
|
|
int PLL; // SH7305
|
|
|
|
};
|
|
|
|
|
|
|
|
int Bphi_div1;
|
|
|
|
int Iphi_div1;
|
|
|
|
int Pphi_div1;
|
|
|
|
|
|
|
|
union
|
|
|
|
{
|
|
|
|
int CKIO_f; // SH7705
|
|
|
|
int RTCCLK_f; // SH7305
|
|
|
|
};
|
|
|
|
|
|
|
|
int Bphi_f;
|
|
|
|
int Iphi_f;
|
|
|
|
int Pphi_f;
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
} clock_config_t;
|
2016-08-29 11:29:07 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
clock_setting()
|
|
|
|
Returns the P_phi / 4 timer setting that will last for the given time.
|
|
|
|
Several units can be used. Be aware that the result is approximate, and
|
|
|
|
very high frequencies or very short delays will yield important errors.
|
2017-02-25 19:02:07 +01:00
|
|
|
Normally you need not use this function when setting up timers because
|
|
|
|
timer_start() handles this conversion for you.
|
2016-08-29 11:29:07 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
uint32_t clock_setting(int duration, enum ClockUnit unit);
|
2016-08-29 11:29:07 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
clock_config()
|
2017-02-25 19:02:07 +01:00
|
|
|
Returns a copy of what the library knows about the clocks.
|
2016-08-29 11:29:07 +02:00
|
|
|
*/
|
2017-02-25 19:02:07 +01:00
|
|
|
clock_config_t clock_config(void);
|
2016-09-04 11:35:41 +02:00
|
|
|
|
|
|
|
#endif // _CLOCK_H
|