mirror of
https://github.com/google/pebble.git
synced 2025-05-31 23:43:11 +00:00
Import of the watch repository from Pebble
This commit is contained in:
commit
3b92768480
10334 changed files with 2564465 additions and 0 deletions
89
platform/robert/boot/src/drivers/gpio.h
Normal file
89
platform/robert/boot/src/drivers/gpio.h
Normal file
|
@ -0,0 +1,89 @@
|
|||
/*
|
||||
* Copyright 2024 Google LLC
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <stdbool.h>
|
||||
|
||||
#include "stm32f7xx.h"
|
||||
|
||||
#include "board/board.h"
|
||||
|
||||
void gpio_disable_all(void);
|
||||
|
||||
void gpio_use(GPIO_TypeDef* GPIOx);
|
||||
void gpio_release(GPIO_TypeDef* GPIOx);
|
||||
|
||||
//! Initialize a GPIO as an output.
|
||||
//!
|
||||
//! @param pin_config the BOARD_CONFIG pin configuration struct
|
||||
//! @param otype the output type of the pin (GPIO_OType_PP or GPIO_OType_OD)
|
||||
//! @param speed the output slew rate
|
||||
//! @note The slew rate should be set as low as possible for the
|
||||
//! pin function to minimize ringing and RF interference.
|
||||
void gpio_output_init(const OutputConfig *pin_config, GPIOOType_TypeDef otype,
|
||||
GPIOSpeed_TypeDef speed);
|
||||
|
||||
//! Assert or deassert the output pin.
|
||||
//!
|
||||
//! Asserting the output drives the pin high if pin_config.active_high
|
||||
//! is true, and drives it low if pin_config.active_high is false.
|
||||
void gpio_output_set(const OutputConfig *pin_config, bool asserted);
|
||||
|
||||
//! Configure a GPIO alternate function.
|
||||
//!
|
||||
//! @param pin_config the BOARD_CONFIG pin configuration struct
|
||||
//! @param otype the output type of the pin (GPIO_OType_PP or GPIO_OType_OD)
|
||||
//! @param speed the output slew rate
|
||||
//! @param pupd pull-up or pull-down configuration
|
||||
//! @note The slew rate should be set as low as possible for the
|
||||
//! pin function to minimize ringing and RF interference.
|
||||
void gpio_af_init(const AfConfig *af_config, GPIOOType_TypeDef otype,
|
||||
GPIOSpeed_TypeDef speed, GPIOPuPd_TypeDef pupd);
|
||||
|
||||
//! Configure a GPIO alternate function pin to minimize power consumption.
|
||||
//!
|
||||
//! Once a pin has been configured for low power, it is no longer
|
||||
//! connected to its alternate function. \ref gpio_af_init will need to
|
||||
//! be called again on the pin in order to configure it in alternate
|
||||
//! function mode again.
|
||||
void gpio_af_configure_low_power(const AfConfig *af_config);
|
||||
|
||||
//! Configure a GPIO alternate function pin to drive a constant output.
|
||||
//!
|
||||
//! Once a pin has been configured as a fixed output, it is no longer
|
||||
//! connected to its alternate function. \ref gpio_af_init will need to
|
||||
//! be called again on the pin in order to configure it in alternate
|
||||
//! function mode again.
|
||||
void gpio_af_configure_fixed_output(const AfConfig *af_config, bool asserted);
|
||||
|
||||
//! Configure all GPIOs in the system to optimize for power consumption.
|
||||
//! At poweron most GPIOs can be configured as analog inputs instead of the
|
||||
//! default digital input. This allows digital filtering logic to be shut down,
|
||||
//! saving quite a bit of power.
|
||||
void gpio_init_all(void);
|
||||
|
||||
//! Configure gpios as inputs (suitable for things like exti lines)
|
||||
void gpio_input_init(const InputConfig *input_cfg);
|
||||
|
||||
//! Configure gpio as an input with internal pull up/pull down configured.
|
||||
void gpio_input_init_pull_up_down(const InputConfig *input_cfg, GPIOPuPd_TypeDef pupd);
|
||||
|
||||
//! @return bool the current state of the GPIO pin
|
||||
bool gpio_input_read(const InputConfig *input_cfg);
|
||||
|
||||
//! Configure gpios as analog inputs. Useful for unused GPIOs as this is their lowest power state.
|
||||
void gpio_analog_init(const InputConfig *input_cfg);
|
Loading…
Add table
Add a link
Reference in a new issue