guo ecf2d82159
sync branch rt-smart. (#6641)
* Synchronize the code of the rt mart branch to the master branch.
  * TTY device
  * Add lwP code from rt-smart
  * Add vnode in DFS, but DFS will be re-write for rt-smart
  * There are three libcpu for rt-smart:
    * arm/cortex-a, arm/aarch64
    * riscv64

Co-authored-by: Rbb666 <zhangbingru@rt-thread.com>
Co-authored-by: zhkag <zhkag@foxmail.com>
2022-12-03 12:07:44 +08:00

106 lines
2.2 KiB
C

/*
* drivers/input/sensor/sunxi_gpadc.h
*
* Copyright (C) 2016 Allwinner.
* fuzhaoke <fuzhaoke@allwinnertech.com>
*
* SUNXI GPADC Controller Driver Header
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License, or (at your option) any later version.
*/
#ifndef HAL_GPADC_H
#define HAL_GPADC_H
#include "hal_clk.h"
#include "sunxi_hal_common.h"
#include <hal_log.h>
#include <interrupt.h>
#include <gpadc/platform_gpadc.h>
#include <gpadc/common_gpadc.h>
#ifdef __cplusplus
extern "C" {
#endif
#define CONFIG_DRIVERS_GPADC_DEBUG
#ifdef CONFIG_DRIVERS_GPADC_DEBUG
#define GPADC_INFO(fmt, arg...) hal_log_info(fmt, ##arg)
#else
#define GPADC_INFO(fmt, arg...) do {}while(0)
#endif
#define GPADC_ERR(fmt, arg...) hal_log_err(fmt, ##arg)
enum
{
GPADC_DOWN,
GPADC_UP
};
typedef enum
{
GP_CH_0 = 0,
GP_CH_1,
GP_CH_2,
GP_CH_3,
GP_CH_4,
GP_CH_5,
GP_CH_6,
GP_CH_7,
GP_CH_MAX
} hal_gpadc_channel_t;
typedef enum
{
GPADC_IRQ_ERROR = -4,
GPADC_CHANNEL_ERROR = -3,
GPADC_CLK_ERROR = -2,
GPADC_ERROR = -1,
GPADC_OK = 0,
} hal_gpadc_status_t;
typedef enum gp_select_mode
{
GP_SINGLE_MODE = 0,
GP_SINGLE_CYCLE_MODE,
GP_CONTINUOUS_MODE,
GP_BURST_MODE,
} hal_gpadc_mode_t;
typedef int (*gpadc_callback_t)(uint32_t data_type, uint32_t data);
typedef struct
{
uint32_t reg_base;
uint32_t channel_num;
uint32_t irq_num;
uint32_t sample_rate;
#if defined(CONFIG_SOC_SUN20IW1)
hal_clk_id_t bus_clk;
hal_clk_id_t rst_clk;
hal_clk_t mbus_clk;
#else
hal_clk_id_t mclk;
hal_clk_id_t pclk;
#endif
hal_gpadc_mode_t mode;
gpadc_callback_t callback[CHANNEL_MAX_NUM];
} hal_gpadc_t;
int hal_gpadc_init(void);
hal_gpadc_status_t hal_gpadc_deinit(void);
hal_gpadc_status_t hal_gpadc_channel_init(hal_gpadc_channel_t channal);
hal_gpadc_status_t hal_gpadc_channel_exit(hal_gpadc_channel_t channal);
hal_gpadc_status_t hal_gpadc_register_callback(hal_gpadc_channel_t channal,
gpadc_callback_t user_callback);
#ifdef __cplusplus
}
#endif
#endif