1
0
mirror of https://github.com/physwizz/a155-U-u1.git synced 2025-09-16 03:59:21 +00:00
Files
physwizz 99537be4e2 first
2024-03-11 06:53:12 +11:00

44 lines
1.3 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2015 MediaTek Inc.
*/
#ifndef __SWTP_H__
#define __SWTP_H__
/* modify MAX_PIN_NUM/DTS to support more gpio,
* need to follow SOP for customization.
*/
#define MAX_PIN_NUM 5
#define SWTP_COMPATIBLE_DEVICE_ID "mediatek, swtp-eint"
#define SWTP1_COMPATIBLE_DEVICE_ID "mediatek, swtp1-eint"
#define SWTP2_COMPATIBLE_DEVICE_ID "mediatek, swtp2-eint"
#define SWTP3_COMPATIBLE_DEVICE_ID "mediatek, swtp3-eint"
#define SWTP4_COMPATIBLE_DEVICE_ID "mediatek, swtp4-eint"
#define SWTP_EINT_PIN_PLUG_IN (1)
#define SWTP_EINT_PIN_PLUG_OUT (0)
#define SWTP_DO_TX_POWER (0)
#define SWTP_NO_TX_POWER (1)
struct swtp_t {
unsigned int md_id;
unsigned int curr_mode;
unsigned int irq[MAX_PIN_NUM];
unsigned int gpiopin[MAX_PIN_NUM];
unsigned int setdebounce[MAX_PIN_NUM];
unsigned int eint_type[MAX_PIN_NUM];
unsigned int gpio_state[MAX_PIN_NUM];
int tx_power_mode;
spinlock_t spinlock;
struct delayed_work delayed_work;
struct delayed_work init_delayed_work;
};
/*****************************************************************************/
/* External API Region called by ccci_swtp object */
/*****************************************************************************/
extern int swtp_init(int md_id);
extern void inject_pin_status_event(int pin_value, const char pin_name[]);
#endif /* __SWTP_H__ */