mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-11-09 13:12:37 -05:00
Samsung YP-R0/YP-R1 refactoring
This patch includes some refactoring: - renaming according to Rockbox guidelines - GPIO code merging, still with target defines - some simplification in firmware/SOURCES Change-Id: I7fd95aece53f40efdf8caac22348376615795431
This commit is contained in:
parent
e32ace831a
commit
f005d841f2
11 changed files with 231 additions and 413 deletions
|
|
@ -23,7 +23,7 @@
|
|||
#include <stdio.h>
|
||||
#include <unistd.h>
|
||||
#include <fcntl.h>
|
||||
#include <gpio-target.h> /* includes common ioctl device definitions */
|
||||
#include <gpio-ypr.h> /* includes common ioctl device definitions */
|
||||
#include <sys/ioctl.h>
|
||||
|
||||
static int gpio_dev = 0;
|
||||
201
firmware/target/hosted/samsungypr/gpio-ypr.h
Normal file
201
firmware/target/hosted/samsungypr/gpio-ypr.h
Normal file
|
|
@ -0,0 +1,201 @@
|
|||
/***************************************************************************
|
||||
* __________ __ ___.
|
||||
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
||||
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
||||
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
||||
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
||||
* \/ \/ \/ \/ \/
|
||||
*
|
||||
* Copyright (C) 2013 Lorenzo Miori
|
||||
*
|
||||
* 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.
|
||||
*
|
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||
* KIND, either express or implied.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __DEV_GPIO_IOCTL_H__
|
||||
#define __DEV_GPIO_IOCTL_H__
|
||||
|
||||
/* Specifies device name and ioctl magic */
|
||||
#include "gpio-target.h"
|
||||
#include "sys/ioctl.h"
|
||||
|
||||
struct gpio_info {
|
||||
int num;
|
||||
int mode;
|
||||
int val;
|
||||
} __attribute__((packed));
|
||||
|
||||
#define E_IOCTL_GPIO_SET_MUX 0
|
||||
#define E_IOCTL_GPIO_UNSET_MUX 1
|
||||
#define E_IOCTL_GPIO_SET_TYPE 2
|
||||
#define E_IOCTL_GPIO_SET_OUTPUT 3
|
||||
#define E_IOCTL_GPIO_SET_INPUT 4
|
||||
#define E_IOCTL_GPIO_SET_HIGH 5
|
||||
#define E_IOCTL_GPIO_SET_LOW 6
|
||||
#define E_IOCTL_GPIO_GET_VAL 7
|
||||
#define E_IOCTL_GPIO_IS_HIGH 8
|
||||
#define E_IOCTL_GPIO_MAX_NR 9
|
||||
|
||||
#define DEV_CTRL_GPIO_SET_MUX _IOW(GPIO_IOCTL_MAGIC, 0, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_UNSET_MUX _IOW(GPIO_IOCTL_MAGIC, 1, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_TYPE _IOW(GPIO_IOCTL_MAGIC, 2, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_OUTPUT _IOW(GPIO_IOCTL_MAGIC, 3, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_INPUT _IOW(GPIO_IOCTL_MAGIC, 4, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_HIGH _IOW(GPIO_IOCTL_MAGIC, 5, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_LOW _IOW(GPIO_IOCTL_MAGIC, 6, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_GET_VAL _IOW(GPIO_IOCTL_MAGIC, 7, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_IS_HIGH _IOW(GPIO_IOCTL_MAGIC, 8, struct gpio_info)
|
||||
|
||||
enum
|
||||
{
|
||||
GPIO1_0 = 0, /* GPIO group 1 start */
|
||||
GPIO1_1,
|
||||
GPIO1_2,
|
||||
GPIO1_3,
|
||||
GPIO1_4,
|
||||
GPIO1_5,
|
||||
GPIO1_6,
|
||||
GPIO1_7,
|
||||
GPIO1_8,
|
||||
GPIO1_9,
|
||||
GPIO1_10,
|
||||
GPIO1_11,
|
||||
GPIO1_12,
|
||||
GPIO1_13,
|
||||
GPIO1_14,
|
||||
GPIO1_15,
|
||||
GPIO1_16,
|
||||
GPIO1_17,
|
||||
GPIO1_18,
|
||||
GPIO1_19,
|
||||
GPIO1_20,
|
||||
GPIO1_21,
|
||||
GPIO1_22,
|
||||
GPIO1_23,
|
||||
GPIO1_24,
|
||||
GPIO1_25,
|
||||
GPIO1_26,
|
||||
GPIO1_27,
|
||||
GPIO1_28,
|
||||
GPIO1_29,
|
||||
GPIO1_30,
|
||||
GPIO1_31,
|
||||
GPIO2_0, /* GPIO group 2 start */
|
||||
GPIO2_1,
|
||||
GPIO2_2,
|
||||
GPIO2_3,
|
||||
GPIO2_4,
|
||||
GPIO2_5,
|
||||
GPIO2_6,
|
||||
GPIO2_7,
|
||||
GPIO2_8,
|
||||
GPIO2_9,
|
||||
GPIO2_10,
|
||||
GPIO2_11,
|
||||
GPIO2_12,
|
||||
GPIO2_13,
|
||||
GPIO2_14,
|
||||
GPIO2_15,
|
||||
GPIO2_16,
|
||||
GPIO2_17,
|
||||
GPIO2_18,
|
||||
GPIO2_19,
|
||||
GPIO2_20,
|
||||
GPIO2_21,
|
||||
GPIO2_22,
|
||||
GPIO2_23,
|
||||
GPIO2_24,
|
||||
GPIO2_25,
|
||||
GPIO2_26,
|
||||
GPIO2_27,
|
||||
GPIO2_28,
|
||||
GPIO2_29,
|
||||
GPIO2_30,
|
||||
GPIO2_31,
|
||||
GPIO3_0, /* GPIO group 3 start */
|
||||
GPIO3_1,
|
||||
GPIO3_2,
|
||||
GPIO3_3,
|
||||
GPIO3_4,
|
||||
GPIO3_5,
|
||||
GPIO3_6,
|
||||
GPIO3_7,
|
||||
GPIO3_8,
|
||||
GPIO3_9,
|
||||
GPIO3_10,
|
||||
GPIO3_11,
|
||||
GPIO3_12,
|
||||
GPIO3_13,
|
||||
GPIO3_14,
|
||||
GPIO3_15,
|
||||
GPIO3_16,
|
||||
GPIO3_17,
|
||||
GPIO3_18,
|
||||
GPIO3_19,
|
||||
GPIO3_20,
|
||||
GPIO3_21,
|
||||
GPIO3_22,
|
||||
GPIO3_23,
|
||||
GPIO3_24,
|
||||
GPIO3_25,
|
||||
GPIO3_26,
|
||||
GPIO3_27,
|
||||
GPIO3_28,
|
||||
GPIO3_29,
|
||||
GPIO3_30,
|
||||
GPIO3_31,
|
||||
};
|
||||
|
||||
enum
|
||||
{
|
||||
CONFIG_ALT0,
|
||||
CONFIG_ALT1,
|
||||
CONFIG_ALT2,
|
||||
CONFIG_ALT3,
|
||||
CONFIG_ALT4,
|
||||
CONFIG_ALT5,
|
||||
CONFIG_ALT6,
|
||||
CONFIG_ALT7,
|
||||
CONFIG_GPIO,
|
||||
CONFIG_SION = 0x01 << 4,
|
||||
CONFIG_DEFAULT
|
||||
};
|
||||
|
||||
enum
|
||||
{
|
||||
PAD_CTL_SRE_SLOW = 0x0 << 0,
|
||||
PAD_CTL_SRE_FAST = 0x1 << 0,
|
||||
PAD_CTL_DRV_LOW = 0x0 << 1,
|
||||
PAD_CTL_DRV_MEDIUM = 0x1 << 1,
|
||||
PAD_CTL_DRV_HIGH = 0x2 << 1,
|
||||
PAD_CTL_DRV_MAX = 0x3 << 1,
|
||||
PAD_CTL_ODE_OPENDRAIN_NONE = 0x0 << 3,
|
||||
PAD_CTL_ODE_OPENDRAIN_ENABLE = 0x1 << 3,
|
||||
PAD_CTL_100K_PD = 0x0 << 4,
|
||||
PAD_CTL_47K_PU = 0x1 << 4,
|
||||
PAD_CTL_100K_PU = 0x2 << 4,
|
||||
PAD_CTL_22K_PU = 0x3 << 4,
|
||||
PAD_CTL_PUE_KEEPER = 0x0 << 6,
|
||||
PAD_CTL_PUE_PULL = 0x1 << 6,
|
||||
PAD_CTL_PKE_NONE = 0x0 << 7,
|
||||
PAD_CTL_PKE_ENABLE = 0x1 << 7,
|
||||
PAD_CTL_HYS_NONE = 0x0 << 8,
|
||||
PAD_CTL_HYS_ENABLE = 0x1 << 8,
|
||||
PAD_CTL_DDR_INPUT_CMOS = 0x0 << 9,
|
||||
PAD_CTL_DDR_INPUT_DDR = 0x1 << 9,
|
||||
PAD_CTL_DRV_VOT_LOW = 0x0 << 13,
|
||||
PAD_CTL_DRV_VOT_HIGH = 0x1 << 13,
|
||||
};
|
||||
|
||||
void gpio_init(void);
|
||||
void gpio_close(void);
|
||||
int gpio_control_struct(int request, struct gpio_info pin);
|
||||
int gpio_control(int request, int num, int mode, int val);
|
||||
|
||||
#endif
|
||||
|
|
@ -24,7 +24,7 @@
|
|||
#include "kernel.h"
|
||||
#include "system.h"
|
||||
#include "button-target.h"
|
||||
#include <gpio-target.h> /* For headphones sense and buttons */
|
||||
#include "gpio-ypr.h" /* For headphones sense and buttons */
|
||||
|
||||
int button_read_device(void)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -23,8 +23,6 @@
|
|||
#ifndef GPIO_YPR0_H
|
||||
#define GPIO_YPR0_H
|
||||
|
||||
#include "r0GPIOIoctl.h"
|
||||
|
||||
/* Some meaningful pins used in the R0 */
|
||||
|
||||
#define GPIO_HEADPHONE_SENSE GPIO1_5
|
||||
|
|
@ -54,9 +52,6 @@
|
|||
#define GPIO_RIGHT_KEY GPIO3_7
|
||||
|
||||
#define GPIO_DEVICE "/dev/r0GPIO"
|
||||
|
||||
void gpio_init(void);
|
||||
void gpio_close(void);
|
||||
int gpio_control(int request, int num, int mode, int val);
|
||||
#define GPIO_IOCTL_MAGIC 'G'
|
||||
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -1,185 +0,0 @@
|
|||
/* This file originates from the linux kernel provided in Samsung's YP-R0 Open
|
||||
* Source package (second release, which includes some driver modules sources).
|
||||
*/
|
||||
|
||||
#ifndef __IOCTL_GPIO_H__
|
||||
#define __IOCTL_GPIO_H__
|
||||
|
||||
#include <sys/ioctl.h>
|
||||
//#include "iomux.h"
|
||||
|
||||
struct gpio_info {
|
||||
int num;
|
||||
int mode;
|
||||
int val;
|
||||
} __attribute__((packed));
|
||||
|
||||
|
||||
#define IOCTL_GPIO_MAGIC 'G'
|
||||
|
||||
#define E_IOCTL_GPIO_SET_MUX 0
|
||||
#define E_IOCTL_GPIO_UNSET_MUX 1
|
||||
#define E_IOCTL_GPIO_SET_TYPE 2
|
||||
#define E_IOCTL_GPIO_SET_OUTPUT 3
|
||||
#define E_IOCTL_GPIO_SET_INPUT 4
|
||||
#define E_IOCTL_GPIO_SET_HIGH 5
|
||||
#define E_IOCTL_GPIO_SET_LOW 6
|
||||
#define E_IOCTL_GPIO_GET_VAL 7
|
||||
#define E_IOCTL_GPIO_IS_HIGH 8
|
||||
#define E_IOCTL_GPIO_MAX_NR 9
|
||||
|
||||
#define DEV_CTRL_GPIO_SET_MUX _IOW(IOCTL_GPIO_MAGIC, 0, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_UNSET_MUX _IOW(IOCTL_GPIO_MAGIC, 1, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_TYPE _IOW(IOCTL_GPIO_MAGIC, 2, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_OUTPUT _IOW(IOCTL_GPIO_MAGIC, 3, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_INPUT _IOW(IOCTL_GPIO_MAGIC, 4, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_HIGH _IOW(IOCTL_GPIO_MAGIC, 5, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_LOW _IOW(IOCTL_GPIO_MAGIC, 6, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_GET_VAL _IOW(IOCTL_GPIO_MAGIC, 7, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_IS_HIGH _IOW(IOCTL_GPIO_MAGIC, 8, struct gpio_info)
|
||||
|
||||
|
||||
typedef enum
|
||||
{
|
||||
GPIO1_0 = 0, /* GPIO group 1 start */
|
||||
GPIO1_1,
|
||||
GPIO1_2,
|
||||
GPIO1_3,
|
||||
GPIO1_4,
|
||||
GPIO1_5,
|
||||
GPIO1_6,
|
||||
GPIO1_7,
|
||||
GPIO1_8,
|
||||
GPIO1_9,
|
||||
GPIO1_10,
|
||||
GPIO1_11,
|
||||
GPIO1_12,
|
||||
GPIO1_13,
|
||||
GPIO1_14,
|
||||
GPIO1_15,
|
||||
GPIO1_16,
|
||||
GPIO1_17,
|
||||
GPIO1_18,
|
||||
GPIO1_19,
|
||||
GPIO1_20,
|
||||
GPIO1_21,
|
||||
GPIO1_22,
|
||||
GPIO1_23,
|
||||
GPIO1_24,
|
||||
GPIO1_25,
|
||||
GPIO1_26,
|
||||
GPIO1_27,
|
||||
GPIO1_28,
|
||||
GPIO1_29,
|
||||
GPIO1_30,
|
||||
GPIO1_31,
|
||||
GPIO2_0, /* GPIO group 2 start */
|
||||
GPIO2_1,
|
||||
GPIO2_2,
|
||||
GPIO2_3,
|
||||
GPIO2_4,
|
||||
GPIO2_5,
|
||||
GPIO2_6,
|
||||
GPIO2_7,
|
||||
GPIO2_8,
|
||||
GPIO2_9,
|
||||
GPIO2_10,
|
||||
GPIO2_11,
|
||||
GPIO2_12,
|
||||
GPIO2_13,
|
||||
GPIO2_14,
|
||||
GPIO2_15,
|
||||
GPIO2_16,
|
||||
GPIO2_17,
|
||||
GPIO2_18,
|
||||
GPIO2_19,
|
||||
GPIO2_20,
|
||||
GPIO2_21,
|
||||
GPIO2_22,
|
||||
GPIO2_23,
|
||||
GPIO2_24,
|
||||
GPIO2_25,
|
||||
GPIO2_26,
|
||||
GPIO2_27,
|
||||
GPIO2_28,
|
||||
GPIO2_29,
|
||||
GPIO2_30,
|
||||
GPIO2_31,
|
||||
GPIO3_0, /* GPIO group 3 start */
|
||||
GPIO3_1,
|
||||
GPIO3_2,
|
||||
GPIO3_3,
|
||||
GPIO3_4,
|
||||
GPIO3_5,
|
||||
GPIO3_6,
|
||||
GPIO3_7,
|
||||
GPIO3_8,
|
||||
GPIO3_9,
|
||||
GPIO3_10,
|
||||
GPIO3_11,
|
||||
GPIO3_12,
|
||||
GPIO3_13,
|
||||
GPIO3_14,
|
||||
GPIO3_15,
|
||||
GPIO3_16,
|
||||
GPIO3_17,
|
||||
GPIO3_18,
|
||||
GPIO3_19,
|
||||
GPIO3_20,
|
||||
GPIO3_21,
|
||||
GPIO3_22,
|
||||
GPIO3_23,
|
||||
GPIO3_24,
|
||||
GPIO3_25,
|
||||
GPIO3_26,
|
||||
GPIO3_27,
|
||||
GPIO3_28,
|
||||
GPIO3_29,
|
||||
GPIO3_30,
|
||||
GPIO3_31,
|
||||
}R0_MX37_GPIO;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
CONFIG_ALT0,
|
||||
CONFIG_ALT1,
|
||||
CONFIG_ALT2,
|
||||
CONFIG_ALT3,
|
||||
CONFIG_ALT4,
|
||||
CONFIG_ALT5,
|
||||
CONFIG_ALT6,
|
||||
CONFIG_ALT7,
|
||||
CONFIG_GPIO,
|
||||
CONFIG_SION = 0x01 << 4,
|
||||
CONFIG_DEFAULT
|
||||
} R0_MX37_PIN_CONFIG;
|
||||
|
||||
#ifndef __MACH_MX37_IOMUX_H__
|
||||
typedef enum
|
||||
{
|
||||
PAD_CTL_SRE_SLOW = 0x0 << 0,
|
||||
PAD_CTL_SRE_FAST = 0x1 << 0,
|
||||
PAD_CTL_DRV_LOW = 0x0 << 1,
|
||||
PAD_CTL_DRV_MEDIUM = 0x1 << 1,
|
||||
PAD_CTL_DRV_HIGH = 0x2 << 1,
|
||||
PAD_CTL_DRV_MAX = 0x3 << 1,
|
||||
PAD_CTL_ODE_OPENDRAIN_NONE = 0x0 << 3,
|
||||
PAD_CTL_ODE_OPENDRAIN_ENABLE = 0x1 << 3,
|
||||
PAD_CTL_100K_PD = 0x0 << 4,
|
||||
PAD_CTL_47K_PU = 0x1 << 4,
|
||||
PAD_CTL_100K_PU = 0x2 << 4,
|
||||
PAD_CTL_22K_PU = 0x3 << 4,
|
||||
PAD_CTL_PUE_KEEPER = 0x0 << 6,
|
||||
PAD_CTL_PUE_PULL = 0x1 << 6,
|
||||
PAD_CTL_PKE_NONE = 0x0 << 7,
|
||||
PAD_CTL_PKE_ENABLE = 0x1 << 7,
|
||||
PAD_CTL_HYS_NONE = 0x0 << 8,
|
||||
PAD_CTL_HYS_ENABLE = 0x1 << 8,
|
||||
PAD_CTL_DDR_INPUT_CMOS = 0x0 << 9,
|
||||
PAD_CTL_DDR_INPUT_DDR = 0x1 << 9,
|
||||
PAD_CTL_DRV_VOT_LOW = 0x0 << 13,
|
||||
PAD_CTL_DRV_VOT_HIGH = 0x1 << 13,
|
||||
} R0_MX37_PAD_CONFIG;
|
||||
#endif
|
||||
|
||||
#endif /* __IOCTL_GPIO__H__ */
|
||||
|
|
@ -30,7 +30,7 @@
|
|||
#endif
|
||||
|
||||
#include "ascodec.h"
|
||||
#include "gpio-target.h"
|
||||
#include "gpio-ypr.h"
|
||||
|
||||
void power_off(void)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -25,9 +25,8 @@
|
|||
#include "system.h"
|
||||
#include "button-target.h"
|
||||
|
||||
#include <gpio-target.h> /* For headphones sense and buttons */
|
||||
#include "gpio-ypr.h" /* For headphones sense and buttons */
|
||||
#include "mcs5000.h" /* Touchscreen controller */
|
||||
#include "ioctl-ypr1.h"
|
||||
|
||||
enum {
|
||||
STATE_UNKNOWN,
|
||||
|
|
|
|||
|
|
@ -23,8 +23,6 @@
|
|||
#ifndef GPIO_TARGET_H
|
||||
#define GPIO_TARGET_H
|
||||
|
||||
#include "ioctl-ypr1.h"
|
||||
|
||||
/* Some meaningful pins used in the YP-R1 */
|
||||
|
||||
#define GPIO_HEADPHONE_SENSE GPIO1_31
|
||||
|
|
@ -58,10 +56,7 @@
|
|||
#define GPIO_POWER_KEY GPIO2_16
|
||||
|
||||
#define GPIO_DEVICE "/dev/r1Gpio"
|
||||
|
||||
void gpio_init(void);
|
||||
void gpio_close(void);
|
||||
int gpio_control_struct(int request, struct gpio_info pin);
|
||||
int gpio_control(int request, int num, int mode, int val);
|
||||
/* Strangely for whatever reason magic differs from R0 (A vs. G) */
|
||||
#define GPIO_IOCTL_MAGIC 'A'
|
||||
|
||||
#endif /* GPIO_TARGET_H */
|
||||
|
|
|
|||
|
|
@ -47,184 +47,4 @@ void max17040_init(void);
|
|||
void max17040_close(void);
|
||||
int max17040_ioctl(int request, int *data);
|
||||
|
||||
/**
|
||||
* This is the wrapper to r1Gpio.ko module with the possible
|
||||
* ioctl calls
|
||||
* TODO move this into a more generic file for ypr platform
|
||||
*/
|
||||
|
||||
struct gpio_info {
|
||||
int num;
|
||||
int mode;
|
||||
int val;
|
||||
} __attribute__((packed));
|
||||
|
||||
/* Strangely for whatever reason magic differs from R0 (A vs. G) */
|
||||
#define IOCTL_GPIO_MAGIC 'A'
|
||||
|
||||
#define E_IOCTL_GPIO_SET_MUX 0
|
||||
#define E_IOCTL_GPIO_UNSET_MUX 1
|
||||
#define E_IOCTL_GPIO_SET_TYPE 2
|
||||
#define E_IOCTL_GPIO_SET_OUTPUT 3
|
||||
#define E_IOCTL_GPIO_SET_INPUT 4
|
||||
#define E_IOCTL_GPIO_SET_HIGH 5
|
||||
#define E_IOCTL_GPIO_SET_LOW 6
|
||||
#define E_IOCTL_GPIO_GET_VAL 7
|
||||
#define E_IOCTL_GPIO_IS_HIGH 8
|
||||
#define E_IOCTL_GPIO_MAX_NR 9
|
||||
|
||||
#define DEV_CTRL_GPIO_SET_MUX _IOW(IOCTL_GPIO_MAGIC, 0, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_UNSET_MUX _IOW(IOCTL_GPIO_MAGIC, 1, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_TYPE _IOW(IOCTL_GPIO_MAGIC, 2, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_OUTPUT _IOW(IOCTL_GPIO_MAGIC, 3, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_INPUT _IOW(IOCTL_GPIO_MAGIC, 4, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_HIGH _IOW(IOCTL_GPIO_MAGIC, 5, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_SET_LOW _IOW(IOCTL_GPIO_MAGIC, 6, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_GET_VAL _IOW(IOCTL_GPIO_MAGIC, 7, struct gpio_info)
|
||||
#define DEV_CTRL_GPIO_IS_HIGH _IOW(IOCTL_GPIO_MAGIC, 8, struct gpio_info)
|
||||
|
||||
|
||||
typedef enum
|
||||
{
|
||||
GPIO1_0 = 0, /* GPIO group 1 start */
|
||||
GPIO1_1,
|
||||
GPIO1_2,
|
||||
GPIO1_3,
|
||||
GPIO1_4,
|
||||
GPIO1_5,
|
||||
GPIO1_6,
|
||||
GPIO1_7,
|
||||
GPIO1_8,
|
||||
GPIO1_9,
|
||||
GPIO1_10,
|
||||
GPIO1_11,
|
||||
GPIO1_12,
|
||||
GPIO1_13,
|
||||
GPIO1_14,
|
||||
GPIO1_15,
|
||||
GPIO1_16,
|
||||
GPIO1_17,
|
||||
GPIO1_18,
|
||||
GPIO1_19,
|
||||
GPIO1_20,
|
||||
GPIO1_21,
|
||||
GPIO1_22,
|
||||
GPIO1_23,
|
||||
GPIO1_24,
|
||||
GPIO1_25,
|
||||
GPIO1_26,
|
||||
GPIO1_27,
|
||||
GPIO1_28,
|
||||
GPIO1_29,
|
||||
GPIO1_30,
|
||||
GPIO1_31,
|
||||
GPIO2_0, /* GPIO group 2 start */
|
||||
GPIO2_1,
|
||||
GPIO2_2,
|
||||
GPIO2_3,
|
||||
GPIO2_4,
|
||||
GPIO2_5,
|
||||
GPIO2_6,
|
||||
GPIO2_7,
|
||||
GPIO2_8,
|
||||
GPIO2_9,
|
||||
GPIO2_10,
|
||||
GPIO2_11,
|
||||
GPIO2_12,
|
||||
GPIO2_13,
|
||||
GPIO2_14,
|
||||
GPIO2_15,
|
||||
GPIO2_16,
|
||||
GPIO2_17,
|
||||
GPIO2_18,
|
||||
GPIO2_19,
|
||||
GPIO2_20,
|
||||
GPIO2_21,
|
||||
GPIO2_22,
|
||||
GPIO2_23,
|
||||
GPIO2_24,
|
||||
GPIO2_25,
|
||||
GPIO2_26,
|
||||
GPIO2_27,
|
||||
GPIO2_28,
|
||||
GPIO2_29,
|
||||
GPIO2_30,
|
||||
GPIO2_31,
|
||||
GPIO3_0, /* GPIO group 3 start */
|
||||
GPIO3_1,
|
||||
GPIO3_2,
|
||||
GPIO3_3,
|
||||
GPIO3_4,
|
||||
GPIO3_5,
|
||||
GPIO3_6,
|
||||
GPIO3_7,
|
||||
GPIO3_8,
|
||||
GPIO3_9,
|
||||
GPIO3_10,
|
||||
GPIO3_11,
|
||||
GPIO3_12,
|
||||
GPIO3_13,
|
||||
GPIO3_14,
|
||||
GPIO3_15,
|
||||
GPIO3_16,
|
||||
GPIO3_17,
|
||||
GPIO3_18,
|
||||
GPIO3_19,
|
||||
GPIO3_20,
|
||||
GPIO3_21,
|
||||
GPIO3_22,
|
||||
GPIO3_23,
|
||||
GPIO3_24,
|
||||
GPIO3_25,
|
||||
GPIO3_26,
|
||||
GPIO3_27,
|
||||
GPIO3_28,
|
||||
GPIO3_29,
|
||||
GPIO3_30,
|
||||
GPIO3_31,
|
||||
}R0_MX37_GPIO;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
CONFIG_ALT0,
|
||||
CONFIG_ALT1,
|
||||
CONFIG_ALT2,
|
||||
CONFIG_ALT3,
|
||||
CONFIG_ALT4,
|
||||
CONFIG_ALT5,
|
||||
CONFIG_ALT6,
|
||||
CONFIG_ALT7,
|
||||
CONFIG_GPIO,
|
||||
CONFIG_SION = 0x01 << 4,
|
||||
CONFIG_DEFAULT
|
||||
} R0_MX37_PIN_CONFIG;
|
||||
|
||||
#ifndef __MACH_MX37_IOMUX_H__
|
||||
typedef enum
|
||||
{
|
||||
PAD_CTL_SRE_SLOW = 0x0 << 0,
|
||||
PAD_CTL_SRE_FAST = 0x1 << 0,
|
||||
PAD_CTL_DRV_LOW = 0x0 << 1,
|
||||
PAD_CTL_DRV_MEDIUM = 0x1 << 1,
|
||||
PAD_CTL_DRV_HIGH = 0x2 << 1,
|
||||
PAD_CTL_DRV_MAX = 0x3 << 1,
|
||||
PAD_CTL_ODE_OPENDRAIN_NONE = 0x0 << 3,
|
||||
PAD_CTL_ODE_OPENDRAIN_ENABLE = 0x1 << 3,
|
||||
PAD_CTL_100K_PD = 0x0 << 4,
|
||||
PAD_CTL_47K_PU = 0x1 << 4,
|
||||
PAD_CTL_100K_PU = 0x2 << 4,
|
||||
PAD_CTL_22K_PU = 0x3 << 4,
|
||||
PAD_CTL_PUE_KEEPER = 0x0 << 6,
|
||||
PAD_CTL_PUE_PULL = 0x1 << 6,
|
||||
PAD_CTL_PKE_NONE = 0x0 << 7,
|
||||
PAD_CTL_PKE_ENABLE = 0x1 << 7,
|
||||
PAD_CTL_HYS_NONE = 0x0 << 8,
|
||||
PAD_CTL_HYS_ENABLE = 0x1 << 8,
|
||||
PAD_CTL_DDR_INPUT_CMOS = 0x0 << 9,
|
||||
PAD_CTL_DDR_INPUT_DDR = 0x1 << 9,
|
||||
PAD_CTL_DRV_VOT_LOW = 0x0 << 13,
|
||||
PAD_CTL_DRV_VOT_HIGH = 0x1 << 13,
|
||||
} R0_MX37_PAD_CONFIG;
|
||||
#endif
|
||||
|
||||
#endif /* __DEV_IOCTL_YPR0_H__ */
|
||||
|
|
|
|||
|
|
@ -25,7 +25,7 @@
|
|||
#include "panic.h"
|
||||
#include "debug.h"
|
||||
|
||||
#include "gpio-target.h"
|
||||
#include "gpio-ypr.h"
|
||||
#include "pmu-ypr1.h"
|
||||
#include "ioctl-ypr1.h"
|
||||
#include "audiohw.h"
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue