2022-11-10 22:22:48 +08:00
|
|
|
|
/*
|
2023-05-11 10:25:21 +08:00
|
|
|
|
* Copyright : (C) 2023 Phytium Information Technology, Inc.
|
2022-11-10 22:22:48 +08:00
|
|
|
|
* All Rights Reserved.
|
|
|
|
|
*
|
|
|
|
|
* This program is OPEN SOURCE software: you can redistribute it and/or modify it
|
|
|
|
|
* under the terms of the Phytium Public License as published by the Phytium Technology Co.,Ltd,
|
|
|
|
|
* either version 1.0 of the License, or (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY;
|
|
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
* See the Phytium Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
*
|
2023-05-11 10:25:21 +08:00
|
|
|
|
* FilePath: fgeneric_timer.h
|
|
|
|
|
* Date: 2022-02-10 14:53:41
|
|
|
|
|
* LastEditTime: 2022-02-17 17:36:17
|
|
|
|
|
* Description: This file is for generic timer function port for driver
|
2022-11-10 22:22:48 +08:00
|
|
|
|
*
|
|
|
|
|
* Modify History:
|
|
|
|
|
* Ver Who Date Changes
|
|
|
|
|
* ----- ------ -------- --------------------------------------
|
2023-05-11 10:25:21 +08:00
|
|
|
|
* 1.0 zhugengyu 2023/2/28 first release
|
2022-11-10 22:22:48 +08:00
|
|
|
|
*/
|
2023-05-11 10:25:21 +08:00
|
|
|
|
#ifndef FDRV_GENERIC_TIMER_AARCH32_H
|
|
|
|
|
#define FDRV_GENERIC_TIMER_AARCH32_H
|
2022-11-10 22:22:48 +08:00
|
|
|
|
|
|
|
|
|
/***************************** Include Files *********************************/
|
2023-05-11 10:25:21 +08:00
|
|
|
|
#include <stddef.h>
|
|
|
|
|
#include "ftypes.h"
|
2022-11-10 22:22:48 +08:00
|
|
|
|
|
2023-05-11 10:25:21 +08:00
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C"
|
|
|
|
|
{
|
|
|
|
|
#endif
|
2022-11-10 22:22:48 +08:00
|
|
|
|
|
|
|
|
|
/************************** Constant Definitions *****************************/
|
|
|
|
|
|
2023-05-11 10:25:21 +08:00
|
|
|
|
/**************************** Type Definitions *******************************/
|
|
|
|
|
|
2022-11-10 22:22:48 +08:00
|
|
|
|
/************************** Variable Definitions *****************************/
|
|
|
|
|
|
|
|
|
|
/***************** Macros (Inline Functions) Definitions *********************/
|
|
|
|
|
|
2023-05-11 10:25:21 +08:00
|
|
|
|
/************************** Function Prototypes ******************************/
|
2022-11-10 22:22:48 +08:00
|
|
|
|
|
2023-05-11 10:25:21 +08:00
|
|
|
|
/************************** Function *****************************************/
|
2023-08-02 13:27:09 +08:00
|
|
|
|
/* Set generic timer CompareValue */
|
|
|
|
|
void GenericTimerSetTimerCompareValue(u32 id, u32 interval);
|
|
|
|
|
|
|
|
|
|
/* Set generic timer TimerValue */
|
|
|
|
|
void GenericTimerSetTimerValue(u32 id, u32 timeout);
|
|
|
|
|
|
|
|
|
|
/* Unmask generic timer interrupt */
|
|
|
|
|
void GenericTimerInterruptEnable(u32 id);
|
|
|
|
|
|
|
|
|
|
/* Mask generic timer interrupt */
|
|
|
|
|
void GenericTimerInterruptDisable(u32 id);
|
|
|
|
|
|
|
|
|
|
/* Enable generic timer */
|
|
|
|
|
void GenericTimerStart(u32 id);
|
|
|
|
|
|
|
|
|
|
/* Get generic timer physical count value */
|
|
|
|
|
u64 GenericTimerRead(u32 id);
|
|
|
|
|
|
|
|
|
|
/* Get generic timer frequency of the system counter */
|
2023-05-11 10:25:21 +08:00
|
|
|
|
u32 GenericTimerFrequecy(void);
|
2023-08-02 13:27:09 +08:00
|
|
|
|
|
|
|
|
|
/* Disable generic timer */
|
|
|
|
|
void GenericTimerStop(u32 id);
|
2022-11-10 22:22:48 +08:00
|
|
|
|
|
2023-05-11 10:25:21 +08:00
|
|
|
|
#ifdef __cplusplus
|
2022-11-10 22:22:48 +08:00
|
|
|
|
}
|
2023-05-11 10:25:21 +08:00
|
|
|
|
#endif
|
2022-11-10 22:22:48 +08:00
|
|
|
|
|
2023-05-11 10:25:21 +08:00
|
|
|
|
#endif
|