89 lines
2.4 KiB
C
Executable File
89 lines
2.4 KiB
C
Executable File
/*
|
|
*********************************************************************************************************
|
|
* LINUX-KERNEL
|
|
* AllWinner Linux Platform Develop Kits
|
|
* Kernel Module
|
|
*
|
|
* (c) Copyright 2011-2015, gq.yang China
|
|
* All Rights Reserved
|
|
*
|
|
* File : mem_tmr.h
|
|
* By : gq.yang
|
|
* Version : v1.0
|
|
* Date : 2012-11-31 15:23
|
|
* Descript:
|
|
* Update : date auther ver notes
|
|
*********************************************************************************************************
|
|
*/
|
|
#ifndef __MEM_TMR_H__
|
|
#define __MEM_TMR_H__
|
|
|
|
typedef struct __MEM_TMR_REG
|
|
{
|
|
// offset:0x00
|
|
volatile __u32 IntCtl;
|
|
volatile __u32 IntSta;
|
|
volatile __u32 reserved0[2];
|
|
// offset:0x10
|
|
volatile __u32 Tmr0Ctl;
|
|
volatile __u32 Tmr0IntVal;
|
|
volatile __u32 Tmr0CntVal;
|
|
volatile __u32 reserved1;
|
|
// offset:0x20
|
|
volatile __u32 Tmr1Ctl;
|
|
volatile __u32 Tmr1IntVal;
|
|
volatile __u32 Tmr1CntVal;
|
|
volatile __u32 reserved2;
|
|
// offset:0x30
|
|
volatile __u32 Tmr2Ctl;
|
|
volatile __u32 Tmr2IntVal;
|
|
volatile __u32 Tmr2CntVal;
|
|
volatile __u32 reserved3;
|
|
// offset:0x40
|
|
volatile __u32 Tmr3Ctl;
|
|
volatile __u32 Tmr3IntVal;
|
|
volatile __u32 reserved4[2];
|
|
// offset:0x50
|
|
volatile __u32 Tmr4Ctl;
|
|
volatile __u32 Tmr4IntVal;
|
|
volatile __u32 Tmr4CntVal;
|
|
volatile __u32 reserved5;
|
|
// offset:0x60
|
|
volatile __u32 Tmr5Ctl;
|
|
volatile __u32 Tmr5IntVal;
|
|
volatile __u32 Tmr5CntVal;
|
|
volatile __u32 reserved6[5];
|
|
// offset:0x80
|
|
volatile __u32 AvsCtl;
|
|
volatile __u32 Avs0Cnt;
|
|
volatile __u32 Avs1Cnt;
|
|
volatile __u32 AvsDiv;
|
|
|
|
// offset:0x90: reserved
|
|
volatile __u32 reserved7[4];
|
|
|
|
// offset:0xa0
|
|
volatile __u32 WDog1_Irq_En;
|
|
volatile __u32 WDog1_Irq_Sta;
|
|
volatile __u32 reserved8[2];
|
|
|
|
// offset:0xb0
|
|
volatile __u32 WDog1_Ctrl_Reg;
|
|
volatile __u32 WDog1_Cfg_Reg;
|
|
volatile __u32 WDog1_Mode_Reg;
|
|
|
|
} __mem_tmr_reg_t;
|
|
|
|
//for super standby;
|
|
__s32 mem_tmr_save(__mem_tmr_reg_t *ptmr_state);
|
|
__s32 mem_tmr_restore(__mem_tmr_reg_t *ptmr_state);
|
|
//for normal standby;
|
|
__s32 mem_tmr_init(void);
|
|
__s32 mem_tmr_exit(void);
|
|
void mem_tmr_enable_watchdog(void);
|
|
void mem_tmr_disable_watchdog(void);
|
|
__s32 mem_tmr_set(__u32 second);
|
|
|
|
#endif //__MEM_TMR_H__
|
|
|