78 lines
2.1 KiB
C
78 lines
2.1 KiB
C
|
/*
|
||
|
* Copyright (c) 2016 Open-RnD Sp. z o.o.
|
||
|
* Copyright (c) 2016 BayLibre, SAS
|
||
|
*
|
||
|
* 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
|
||
|
*
|
||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||
|
*
|
||
|
* 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.
|
||
|
*/
|
||
|
|
||
|
#include <errno.h>
|
||
|
|
||
|
#include "soc.h"
|
||
|
#include "soc_pinmux.h"
|
||
|
#include <device.h>
|
||
|
#include <misc/util.h>
|
||
|
#include <pinmux/stm32/pinmux_stm32.h>
|
||
|
#include <drivers/clock_control/stm32_clock_control.h>
|
||
|
|
||
|
/**
|
||
|
* @brief pin configuration
|
||
|
*/
|
||
|
static const struct stm32_pinmux_conf pins[] = {
|
||
|
};
|
||
|
|
||
|
int stm32_get_pin_config(int pin, int func)
|
||
|
{
|
||
|
/* GPIO function is always available, to save space it is not
|
||
|
* listed in alternate functions array
|
||
|
*/
|
||
|
if (func == STM32_PINMUX_FUNC_GPIO) {
|
||
|
return STM32L4X_PIN_CONFIG_BIAS_HIGH_IMPEDANCE;
|
||
|
}
|
||
|
|
||
|
/* analog function is another 'known' setting */
|
||
|
if (func == STM32_PINMUX_FUNC_ANALOG) {
|
||
|
return STM32L4X_PIN_CONFIG_ANALOG;
|
||
|
}
|
||
|
|
||
|
for (int i = 0; i < ARRAY_SIZE(pins); i++) {
|
||
|
if (pins[i].pin == pin) {
|
||
|
if ((func - 1) >= pins[i].nfuncs) {
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|
||
|
return pins[i].funcs[func - 1];
|
||
|
}
|
||
|
}
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|
||
|
clock_control_subsys_t stm32_get_port_clock(int port)
|
||
|
{
|
||
|
const clock_control_subsys_t ports_to_clock[STM32_PORTS_MAX] = {
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOA),
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOB),
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOC),
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOD),
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOE),
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOF),
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOG),
|
||
|
UINT_TO_POINTER(STM32L4X_CLOCK_SUBSYS_GPIOH),
|
||
|
};
|
||
|
|
||
|
if (port > STM32_PORTH) {
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
return ports_to_clock[port];
|
||
|
}
|