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