kernel_samsung_a34x-permissive/drivers/misc/mediatek/include/mt-plat/mtk_gpt.h
2024-04-28 15:49:01 +02:00

72 lines
1.9 KiB
C
Executable file

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2019 MediaTek Inc.
*/
#ifndef _MTK_GPT_H_
#define _MTK_GPT_H_
#include <linux/types.h>
#define GPT1 0x0
#define GPT2 0x1
#define GPT3 0x2
#define GPT4 0x3
#define GPT5 0x4
#define GPT6 0x5
#define NR_GPTS 0x6
#define GPT_ONE_SHOT 0x0
#define GPT_REPEAT 0x1
#define GPT_KEEP_GO 0x2
#define GPT_FREE_RUN 0x3
#define GPT_CLK_DIV_1 0x0000
#define GPT_CLK_DIV_2 0x0001
#define GPT_CLK_DIV_3 0x0002
#define GPT_CLK_DIV_4 0x0003
#define GPT_CLK_DIV_5 0x0004
#define GPT_CLK_DIV_6 0x0005
#define GPT_CLK_DIV_7 0x0006
#define GPT_CLK_DIV_8 0x0007
#define GPT_CLK_DIV_9 0x0008
#define GPT_CLK_DIV_10 0x0009
#define GPT_CLK_DIV_11 0x000a
#define GPT_CLK_DIV_12 0x000b
#define GPT_CLK_DIV_13 0x000c
#define GPT_CLK_DIV_16 0x000d
#define GPT_CLK_DIV_32 0x000e
#define GPT_CLK_DIV_64 0x000f
#define GPT_CLK_SRC_SYS 0x0
#define GPT_CLK_SRC_RTC 0x1
#define GPT_NOAUTOEN 0x0001
#define GPT_NOIRQEN 0x0002
extern int request_gpt(unsigned int id, unsigned int mode, unsigned int clksrc,
unsigned int clkdiv, unsigned int cmp,
void (*func)(unsigned long), unsigned int flags);
extern int free_gpt(unsigned int id);
extern int start_gpt(unsigned int id);
extern int stop_gpt(unsigned int id);
extern int restart_gpt(unsigned int id);
extern int gpt_is_counting(unsigned int id);
extern int gpt_set_cmp(unsigned int id, unsigned int val);
extern int gpt_get_cmp(unsigned int id, unsigned int *ptr);
extern int gpt_get_cnt(unsigned int id, unsigned int *ptr);
extern int gpt_check_irq(unsigned int id);
extern int gpt_check_and_ack_irq(unsigned int id);
extern int gpt_set_clk(unsigned int id, unsigned int clksrc,
unsigned int clkdiv);
extern void mt_gpt_clkevt_aee_dump(void);
extern u64 mtk_timer_get_cnt(u8 timer);
#endif /* _MTK_GPT_H_ */