blob: 897043ac179bed455bdb21f334c45398c1f621b8 [file] [log] [blame]
Joonwoo Park451dca32014-04-02 11:47:03 -07001/*
2 * Copyright (c) 2013-2014, The Linux Foundation. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are met:
6 * * Redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer.
8 * * Redistributions in binary form must reproduce the above copyright
9 * notice, this list of conditions and the following disclaimer in the
10 * documentation and/or other materials provided with the distribution.
11 * * Neither the name of Linux Foundation nor
12 * the names of its contributors may be used to endorse or promote
13 * products derived from this software without specific prior written
14 * permission.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19 * NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
20 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
21 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
22 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
23 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
25 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
26 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
anisha agarwaldd04af62014-11-17 10:57:49 -080029#ifndef __PLATFORM_MDM9640_GPIO_H
30#define __PLATFORM_MDM9640_GPIO_H
Joonwoo Park451dca32014-04-02 11:47:03 -070031
32#include <bits.h>
33#include <gpio.h>
34
35/* GPIO TLMM: Direction */
36#define GPIO_INPUT 0
37#define GPIO_OUTPUT 1
38
39/* GPIO TLMM: Pullup/Pulldown */
40#define GPIO_NO_PULL 0
41#define GPIO_PULL_DOWN 1
42#define GPIO_KEEPER 2
43#define GPIO_PULL_UP 3
44
45/* GPIO TLMM: Drive Strength */
46#define GPIO_2MA 0
47#define GPIO_4MA 1
48#define GPIO_6MA 2
49#define GPIO_8MA 3
50#define GPIO_10MA 4
51#define GPIO_12MA 5
52#define GPIO_14MA 6
53#define GPIO_16MA 7
54
55/* GPIO TLMM: Status */
56#define GPIO_ENABLE 0
57#define GPIO_DISABLE 1
58
59void gpio_tlmm_config(uint32_t gpio,
60 uint8_t func,
61 uint8_t dir,
62 uint8_t pull,
63 uint8_t drvstr,
64 uint32_t enable);
65uint32_t gpio_get_state(uint32_t gpio);
66void gpio_set(uint32_t gpio, uint32_t dir);
67void gpio_config_uart_dm(uint8_t id);
68
69#endif