2016-08-29 11:29:07 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core module: clock
|
|
|
|
//
|
2017-03-26 18:38:32 +02:00
|
|
|
// This module interfaces with the MPU clocks and is used to measure the
|
|
|
|
// clock frequencies at the beginning of execution. At this stage, it
|
|
|
|
// assumes that clock mode 3 is used on SH7305 (as does FTune), because
|
|
|
|
// there doesn't seem to be a way of getting this information.
|
|
|
|
//
|
|
|
|
// It also provides some sleep and time conversion functions, and access
|
|
|
|
// to how the clocks are configured. In the future, it would be the module
|
|
|
|
// that supports overclock.
|
2016-08-29 11:29:07 +02:00
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
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()
|
2017-03-26 18:38:32 +02:00
|
|
|
Puts the processor to sleep until an interrupt request is accepted.
|
|
|
|
This function should be called every time the program because idle
|
|
|
|
because it doesn't have anything to do -- between two game frames or
|
|
|
|
while waiting for a keyboard event.
|
|
|
|
This function is called by getkey_opt(), getkey(), waitevent(), this
|
|
|
|
module's sleep functions among others.
|
2017-02-25 19:02:07 +01:00
|
|
|
*/
|
|
|
|
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
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
/*
|
|
|
|
clock_unit_t
|
|
|
|
Enumerated type used by the time conversion functions. It indicates the
|
|
|
|
type (delay or frequency) of a parameter.
|
|
|
|
*/
|
|
|
|
typedef enum
|
2016-08-29 11:29:07 +02:00
|
|
|
{
|
2017-03-26 18:38:32 +02:00
|
|
|
clock_us = 0,
|
|
|
|
clock_ms = 1,
|
|
|
|
clock_s = 2,
|
2016-08-29 11:29:07 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
clock_Hz = 10,
|
|
|
|
clock_kHz = 11,
|
|
|
|
clock_MHz = 12,
|
2016-08-29 11:29:07 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
} clock_unit_t;
|
|
|
|
|
|
|
|
/*
|
|
|
|
clock_config_t
|
|
|
|
A copy of the Clock Pulse Generator (CPG) configuration. Be sure to
|
|
|
|
check which MPU the program is running on (using <mpu.h>) to access the
|
|
|
|
right fields.
|
|
|
|
*/
|
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
|
|
|
|
};
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
int Bphi_f; // Bus clock frequency
|
|
|
|
int Iphi_f; // Processor clock frequency
|
|
|
|
int Pphi_f; // Peripheral clock frequency
|
2016-08-29 11:29:07 +02:00
|
|
|
|
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-03-26 18:38:32 +02:00
|
|
|
uint32_t clock_setting(int duration, clock_unit_t 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
|