summaryrefslogtreecommitdiffstats
path: root/target/linux/realtek/files/drivers/serial/gpio.h
blob: 6029894dfe2bacf64401ab83858c6241d7e99205 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
* Copyright c                  Realtek Semiconductor Corporation, 2006  
* All rights reserved.
* 
* Program : GPIO Header File 
* Abstract : 
* Author :                
* 
*/

 
#ifndef __GPIO__
#define __GPIO__

#ifdef __UBOOT__
#include <config.h>
#endif
#ifndef __BOOTCODE__
#include <linux/config.h>
#endif
//#include "voip_types.h"
#include <net/rtl/rtl_types.h>

#ifdef CONFIG_RTK_VOIP_DRIVERS_PCM8186
#include "gpio_8186.h"
#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8651)
#include "gpio_8651bv.h"
#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8671)
#include "gpio_8972.h"
#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8672)
#include "gpio_8672.h"
#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM865xC)
#include "gpio_8952.h"
#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8972B_FAMILY)
#include "gpio_8972b.h"
#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM89xxD)
#include "gpio_8972d.h"
#else
#error "unknown gpio driver"
#endif

#define _GPIO_DEBUG_

#ifdef _GPIO_DEBUG_ 
#if defined(CONFIG_RTK_VOIP_DRIVERS_PCM8651)
#define GPIO_PRINT(level, fmt, args...) do { if (gpio_debug >= level) rtlglue_printf(fmt, ## args); } while (0)
#else
#define GPIO_PRINT(level, fmt, args...) do { if (gpio_debug >= level) printk(fmt, ## args); } while (0)
#endif
#else
#define GPIO_PRINT(fmt, args...)
#endif

/*
 * Every pin of GPIO port can be mapped to a unique ID. All the access to a GPIO pin must use the ID.
 * This macro is used to map the port and pin into the ID.
 */
#define GPIO_ID(port,pin) ((uint32)port<<16|(uint32)pin)

/* This is reversed macro. */
#define GPIO_PORT(id) (id>>16)
#define GPIO_PIN(id) (id&0xffff)

#ifdef CONFIG_RTK_VOIP_DRIVERS_PCM8186
#define RTK_GPIO_INIT(pid, dedicate, dir, interrupt) _rtl8186_initGpioPin(pid, dir, interrupt)
#define RTK_GPIO_GET(pid, pData) _rtl8186_getGpioDataBit(pid, pData) 
#define RTK_GPIO_SET(pid, data) _rtl8186_setGpioDataBit(pid, data)

#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8651)
#define RTK_GPIO_INIT(pid, dedicate, dir, interrupt)  _rtl865x_initGpioPin(pid, dedicate, dir, interrupt)
#define RTK_GPIO_GET(pid, pData) _rtl865x_getGpioDataBit(pid, pData) 
#define RTK_GPIO_SET(pid, data) _rtl865x_setGpioDataBit(pid, data)

#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8671)
#define RTK_GPIO_INIT(pid, dedicate, dir, interrupt)  _rtl867x_initGpioPin(pid, dir, interrupt)
#define RTK_GPIO_GET(pid, pData) _rtl867x_getGpioDataBit(pid, pData) 
#define RTK_GPIO_SET(pid, data) _rtl867x_setGpioDataBit(pid, data)

#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8672)
#define RTK_GPIO_INIT(pid, dedicate, dir, interrupt)  _rtl867x_initGpioPin(pid, dir)
#define RTK_GPIO_GET(pid, pData) _rtl867x_getGpioDataBit(pid, pData) 
#define RTK_GPIO_SET(pid, data) _rtl867x_setGpioDataBit(pid, data)

#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM865xC)
#define RTK_GPIO_INIT(pid, dedicate, dir, interrupt)  _rtl865xC_initGpioPin(pid, dedicate, dir, interrupt)
#define RTK_GPIO_GET(pid, pData) _rtl865xC_getGpioDataBit(pid, pData) 
#define RTK_GPIO_SET(pid, data) _rtl865xC_setGpioDataBit(pid, data)

#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM8972B_FAMILY)
#define RTK_GPIO_INIT(pid, dedicate, dir, interrupt)  _rtl8972B_initGpioPin(pid, dedicate, dir, interrupt)
#define RTK_GPIO_GET(pid, pData) _rtl8972B_getGpioDataBit(pid, pData) 
#define RTK_GPIO_SET(pid, data) _rtl8972B_setGpioDataBit(pid, data)

#elif defined(CONFIG_RTK_VOIP_DRIVERS_PCM89xxD)
#define RTK_GPIO_INIT(pid, dedicate, dir, interrupt)  _rtl8972D_initGpioPin(pid, dedicate, dir, interrupt)
#define RTK_GPIO_GET(pid, pData) _rtl8972D_getGpioDataBit(pid, pData) 
#define RTK_GPIO_SET(pid, data) _rtl8972D_setGpioDataBit(pid, data)
#else
#error "unknown gpio driver"
#endif

// define generic naming for kernel's driver 
#define _rtl_generic_initGpioPin(pid, dedicate, dir, interrupt)	RTK_GPIO_INIT(pid, dedicate, dir, interrupt)
#define _rtl_generic_getGpioDataBit(pid, pData)					RTK_GPIO_GET(pid, pData)
#define _rtl_generic_setGpioDataBit(pid, data)					RTK_GPIO_SET(pid, data)

extern int gpio_debug;

#endif/*__GPIO__*/