2015-09-25 01:57:06 +08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2015 Intel Corporation
|
|
|
|
*
|
2015-10-07 00:00:37 +08:00
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
2015-09-25 01:57:06 +08:00
|
|
|
*
|
2015-10-07 00:00:37 +08:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2015-09-25 01:57:06 +08:00
|
|
|
*
|
2015-10-07 00:00:37 +08:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
2015-09-25 01:57:06 +08:00
|
|
|
*/
|
2016-02-08 03:34:13 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* Public APIs for Pinmux drivers
|
|
|
|
*/
|
|
|
|
|
2015-09-25 01:57:06 +08:00
|
|
|
#ifndef __INCLUDE_PINMUX_H
|
|
|
|
#define __INCLUDE_PINMUX_H
|
|
|
|
|
2015-10-26 18:18:44 +08:00
|
|
|
/**
|
|
|
|
* @brief Pinmux Interface
|
|
|
|
* @defgroup pinmux_interface Pinmux Interface
|
|
|
|
* @ingroup io_interfaces
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2015-09-25 01:57:06 +08:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <device.h>
|
|
|
|
|
2016-01-23 01:38:49 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-09-25 01:57:06 +08:00
|
|
|
#define PINMUX_FUNC_A 0
|
|
|
|
#define PINMUX_FUNC_B 1
|
|
|
|
#define PINMUX_FUNC_C 2
|
|
|
|
#define PINMUX_FUNC_D 3
|
|
|
|
|
2015-12-05 07:05:23 +08:00
|
|
|
#define PINMUX_PULLUP_ENABLE (0x1)
|
|
|
|
#define PINMUX_PULLUP_DISABLE (0x0)
|
|
|
|
|
|
|
|
#define PINMUX_INPUT_ENABLED (0x1)
|
|
|
|
#define PINMUX_OUTPUT_ENABLED (0x0)
|
|
|
|
|
2016-06-16 05:18:38 +08:00
|
|
|
/**
|
|
|
|
* @typedef pmux_set
|
|
|
|
* @brief Callback API upon setting a PIN's function
|
|
|
|
* See pinmux_pin_set() for argument description
|
|
|
|
*/
|
2016-03-16 03:53:39 +08:00
|
|
|
typedef int (*pmux_set)(struct device *dev, uint32_t pin, uint32_t func);
|
2016-06-16 05:18:38 +08:00
|
|
|
/**
|
|
|
|
* @typedef pmux_get
|
|
|
|
* @brief Callback API upon getting a PIN's function
|
|
|
|
* See pinmux_pin_get() for argument description
|
|
|
|
*/
|
2016-03-16 03:53:39 +08:00
|
|
|
typedef int (*pmux_get)(struct device *dev, uint32_t pin, uint32_t *func);
|
2016-06-16 05:18:38 +08:00
|
|
|
/**
|
|
|
|
* @typedef pmux_pullup
|
|
|
|
* @brief Callback API upon setting a PIN's pullup
|
|
|
|
* See pinmix_pin_pullup() for argument description
|
|
|
|
*/
|
2016-03-16 03:53:39 +08:00
|
|
|
typedef int (*pmux_pullup)(struct device *dev, uint32_t pin, uint8_t func);
|
2016-06-16 05:18:38 +08:00
|
|
|
/**
|
|
|
|
* @typedef pmux_input
|
|
|
|
* @brief Callback API upon setting a PIN's input function
|
|
|
|
* See pinmux_input() for argument description
|
|
|
|
*/
|
2016-03-16 03:53:39 +08:00
|
|
|
typedef int (*pmux_input)(struct device *dev, uint32_t pin, uint8_t func);
|
2015-09-25 01:57:06 +08:00
|
|
|
|
|
|
|
struct pinmux_driver_api {
|
|
|
|
pmux_set set;
|
|
|
|
pmux_get get;
|
2015-12-05 07:05:23 +08:00
|
|
|
pmux_pullup pullup;
|
|
|
|
pmux_input input;
|
2015-09-25 01:57:06 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-03-16 03:53:39 +08:00
|
|
|
static inline int pinmux_pin_set(struct device *dev,
|
2015-09-25 01:57:06 +08:00
|
|
|
uint32_t pin,
|
2015-11-21 02:17:55 +08:00
|
|
|
uint32_t func)
|
2015-09-25 01:57:06 +08:00
|
|
|
{
|
2016-10-22 17:02:12 +08:00
|
|
|
const struct pinmux_driver_api *api = dev->driver_api;
|
2015-09-25 01:57:06 +08:00
|
|
|
|
|
|
|
return api->set(dev, pin, func);
|
|
|
|
}
|
|
|
|
|
2016-03-16 03:53:39 +08:00
|
|
|
static inline int pinmux_pin_get(struct device *dev,
|
2015-09-25 01:57:06 +08:00
|
|
|
uint32_t pin,
|
2015-11-21 02:17:55 +08:00
|
|
|
uint32_t *func)
|
2015-09-25 01:57:06 +08:00
|
|
|
{
|
2016-10-22 17:02:12 +08:00
|
|
|
const struct pinmux_driver_api *api = dev->driver_api;
|
2015-09-25 01:57:06 +08:00
|
|
|
|
|
|
|
return api->get(dev, pin, func);
|
|
|
|
}
|
|
|
|
|
2016-03-16 03:53:39 +08:00
|
|
|
static inline int pinmux_pin_pullup(struct device *dev,
|
2015-12-05 07:05:23 +08:00
|
|
|
uint32_t pin,
|
|
|
|
uint8_t func)
|
|
|
|
{
|
2016-10-22 17:02:12 +08:00
|
|
|
const struct pinmux_driver_api *api = dev->driver_api;
|
2015-12-05 07:05:23 +08:00
|
|
|
|
|
|
|
return api->pullup(dev, pin, func);
|
|
|
|
}
|
|
|
|
|
2016-03-16 03:53:39 +08:00
|
|
|
static inline int pinmux_pin_input_enable(struct device *dev,
|
2015-12-05 07:05:23 +08:00
|
|
|
uint32_t pin,
|
|
|
|
uint8_t func)
|
|
|
|
{
|
2016-10-22 17:02:12 +08:00
|
|
|
const struct pinmux_driver_api *api = dev->driver_api;
|
2015-12-05 07:05:23 +08:00
|
|
|
|
|
|
|
return api->input(dev, pin, func);
|
|
|
|
}
|
|
|
|
|
2016-01-23 01:38:49 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-10-26 18:18:44 +08:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
2016-01-23 01:38:49 +08:00
|
|
|
|
2015-09-25 01:57:06 +08:00
|
|
|
#endif /* __INCLUDE_PINMUX_H */
|