mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
usb_board_reset: Split headers into public and private
The private parts need USB definitions (and are thus preferably used from USB_H_USER_IS_RIOT_INTERNAL compilation units). Functions like usb_board_reset_in_bootloader do not depend on USB headers for their definitions and are fair game throughout the application even for generic RIOT USB devices.
This commit is contained in:
parent
33ef4f2902
commit
a787875cf8
@ -21,6 +21,7 @@
|
|||||||
|
|
||||||
#define USB_H_USER_IS_RIOT_INTERNAL
|
#define USB_H_USER_IS_RIOT_INTERNAL
|
||||||
|
|
||||||
|
#include "cpu.h"
|
||||||
#include "usb_board_reset.h"
|
#include "usb_board_reset.h"
|
||||||
|
|
||||||
/* Set the value used by the bootloader to select between boot in
|
/* Set the value used by the bootloader to select between boot in
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
|
|
||||||
#define USB_H_USER_IS_RIOT_INTERNAL
|
#define USB_H_USER_IS_RIOT_INTERNAL
|
||||||
|
|
||||||
|
#include "cpu.h"
|
||||||
#include "usb_board_reset.h"
|
#include "usb_board_reset.h"
|
||||||
|
|
||||||
/* Set the value used by the bootloader to select between boot in
|
/* Set the value used by the bootloader to select between boot in
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
#define USB_H_USER_IS_RIOT_INTERNAL
|
#define USB_H_USER_IS_RIOT_INTERNAL
|
||||||
|
|
||||||
|
#include "cpu.h"
|
||||||
#include "usb_board_reset.h"
|
#include "usb_board_reset.h"
|
||||||
|
|
||||||
#ifdef HMCRAMC0_ADDR
|
#ifdef HMCRAMC0_ADDR
|
||||||
|
@ -24,25 +24,6 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <inttypes.h>
|
|
||||||
|
|
||||||
#include "usb/usbus/cdc/acm.h"
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief USB coding callback used to trigger the board reset
|
|
||||||
*
|
|
||||||
* @param[in] cdcacm Pointer to the cdcacm device
|
|
||||||
* @param[in] baud Baudrate used by the client. Only 1200 baud is taken into account
|
|
||||||
* @param[in] bits Number of bit mode used by the client
|
|
||||||
* @param[in] parity Parity mode used by the client
|
|
||||||
* @param[in] stop Stop bit mode used by the client
|
|
||||||
*
|
|
||||||
* @return Always return 0
|
|
||||||
*/
|
|
||||||
int usb_board_reset_coding_cb(usbus_cdcacm_device_t *cdcacm,
|
|
||||||
uint32_t baud, uint8_t bits,
|
|
||||||
uint8_t parity, uint8_t stop);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Trigger a simple reset, back to the application
|
* @brief Trigger a simple reset, back to the application
|
||||||
*/
|
*/
|
||||||
|
51
sys/include/usb_board_reset_internal.h
Normal file
51
sys/include/usb_board_reset_internal.h
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 Inria
|
||||||
|
*
|
||||||
|
* This file is subject to the terms and conditions of the GNU Lesser
|
||||||
|
* General Public License v2.1. See the file LICENSE in the top level
|
||||||
|
* directory for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup sys_usb_board_reset_internal Board reset via USB CDC ACM internals
|
||||||
|
* @ingroup sys_usb_board_reset
|
||||||
|
* @brief Callbacks provided by the USB_BOARD_RESET to the ACM subsystem
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file
|
||||||
|
* @author Alexandre Abadie <alexandre.abadie@inria.fr>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef USB_BOARD_RESET_INTERNAL_H
|
||||||
|
#define USB_BOARD_RESET_INTERNAL_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <inttypes.h>
|
||||||
|
|
||||||
|
#include "usb/usbus/cdc/acm.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB coding callback used to trigger the board reset
|
||||||
|
*
|
||||||
|
* @param[in] cdcacm Pointer to the cdcacm device
|
||||||
|
* @param[in] baud Baudrate used by the client. Only 1200 baud is taken into account
|
||||||
|
* @param[in] bits Number of bit mode used by the client
|
||||||
|
* @param[in] parity Parity mode used by the client
|
||||||
|
* @param[in] stop Stop bit mode used by the client
|
||||||
|
*
|
||||||
|
* @return Always return 0
|
||||||
|
*/
|
||||||
|
int usb_board_reset_coding_cb(usbus_cdcacm_device_t *cdcacm,
|
||||||
|
uint32_t baud, uint8_t bits,
|
||||||
|
uint8_t parity, uint8_t stop);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* USB_BOARD_RESET_INTERNAL_H */
|
||||||
|
/** @} */
|
@ -23,7 +23,6 @@
|
|||||||
#include "periph/pm.h"
|
#include "periph/pm.h"
|
||||||
|
|
||||||
#ifdef MODULE_USB_BOARD_RESET
|
#ifdef MODULE_USB_BOARD_RESET
|
||||||
#define USB_H_USER_IS_RIOT_INTERNAL
|
|
||||||
#include "usb_board_reset.h"
|
#include "usb_board_reset.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef MODULE_USB_BOARD_RESET
|
#ifdef MODULE_USB_BOARD_RESET
|
||||||
#include "usb_board_reset.h"
|
#include "usb_board_reset_internal.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static usbus_cdcacm_device_t cdcacm;
|
static usbus_cdcacm_device_t cdcacm;
|
||||||
|
Loading…
Reference in New Issue
Block a user