2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* boards/mips/pic32mx/ubw32/src/pic32_usbdev.c
|
2012-04-26 22:11:46 +02:00
|
|
|
*
|
2020-08-22 17:52:02 +02:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you 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
|
2012-04-26 22:11:46 +02:00
|
|
|
*
|
2020-08-22 17:52:02 +02:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2012-04-26 22:11:46 +02:00
|
|
|
*
|
2020-08-22 17:52:02 +02: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.
|
2012-04-26 22:11:46 +02:00
|
|
|
*
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
2012-04-26 22:11:46 +02:00
|
|
|
* Included Files
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <debug.h>
|
|
|
|
|
|
|
|
#include <nuttx/usb/usbdev.h>
|
|
|
|
|
2015-12-30 01:07:27 +01:00
|
|
|
#include "pic32mx.h"
|
2015-12-29 22:44:56 +01:00
|
|
|
#include "ubw32.h"
|
2012-04-26 22:11:46 +02:00
|
|
|
|
|
|
|
#if defined(CONFIG_PIC32MX_USBDEV)
|
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
2015-03-21 16:59:52 +01:00
|
|
|
* Pre-processor Definitions
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
2012-04-26 22:11:46 +02:00
|
|
|
* Private Functions
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
2012-04-26 22:11:46 +02:00
|
|
|
* Public Functions
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
2012-04-26 22:11:46 +02:00
|
|
|
* Name: pic32mx_usbdevinitialize
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Called to configure the mini-A/B J5 on the UBW32 for the
|
|
|
|
* USB device
|
|
|
|
*
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
|
|
|
void weak_function pic32mx_usbdevinitialize(void)
|
|
|
|
{
|
|
|
|
/* Notes from the Sure Electronics sample code:
|
|
|
|
*
|
2019-08-08 16:53:04 +02:00
|
|
|
* "The USB specifications require that USB peripheral devices must never
|
|
|
|
* source current onto the Vbus pin. Additionally, USB peripherals should
|
|
|
|
* not source current on D+ or D- when the host/hub is not actively
|
|
|
|
* powering the Vbus line.
|
2020-08-22 17:52:02 +02:00
|
|
|
* When designing a self powered (as opposed to bus powered) USB
|
|
|
|
* peripheral device, the firmware should make sure not to turn on the
|
|
|
|
* USB module and D+ or D- pull up resistor unless Vbus is actively
|
|
|
|
* powered. Therefore, the firmware needs some means to detect when Vbus
|
|
|
|
* is being powered by the host.
|
|
|
|
* A 5V tolerant I/O pin can be connected to Vbus (through a resistor),
|
|
|
|
* and can be used to detect when Vbus is high (host actively powering),
|
|
|
|
* or low (host is shut down or otherwise not supplying power). The USB
|
|
|
|
* firmware can then periodically poll this I/O pin to know when it is
|
|
|
|
* okay to turn on the USB module/D+/D- pull up resistor. When designing
|
|
|
|
* a purely bus powered peripheral device, it is not possible to source
|
|
|
|
* current on D+ or D- when the host is not actively providing power on
|
|
|
|
* Vbus. Therefore, implementing this bus sense feature is optional. ..."
|
2012-04-26 22:11:46 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef CONFIG_USBHOST
|
|
|
|
#endif
|
2014-04-14 00:22:22 +02:00
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/* "If the host PC sends a GetStatus (device) request, the firmware must
|
|
|
|
* respond and let the host know if the USB peripheral device is currently
|
|
|
|
* bus powered or self powered.
|
|
|
|
* See chapter 9 in the official USB specifications for details
|
|
|
|
* regarding this request.
|
|
|
|
* If the peripheral device is capable of being both self and bus powered,
|
|
|
|
* it should not return a hard coded value for this request.
|
|
|
|
* Instead, firmware should check if it is currently self or bus powered,
|
|
|
|
* and respond accordingly.
|
|
|
|
* If the hardware has been configured like demonstrated on the PICDEM FS
|
|
|
|
* USB Demo Board, an I/O pin can be polled to determine the
|
2012-04-26 22:11:46 +02:00
|
|
|
* currently selected power source. ..."
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef CONFIG_USB_PWRSENSE
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
2012-04-26 22:11:46 +02:00
|
|
|
* Name: pic32mx_usbpullup
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* If USB is supported and the board supports a pullup via GPIO (for USB
|
|
|
|
* software connect and disconnect), then the board software must provide
|
2020-08-22 17:52:02 +02:00
|
|
|
* pic32mx_usbpullup. See include/nuttx/usb/usbdev.h for additional
|
|
|
|
* description of this method. Alternatively, if no pull-up GPIO the
|
|
|
|
* following EXTERN can be redefined to be NULL.
|
2012-04-26 22:11:46 +02:00
|
|
|
*
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
2022-04-17 14:48:23 +02:00
|
|
|
int pic32mx_usbpullup(struct usbdev_s *dev, bool enable)
|
2012-04-26 22:11:46 +02:00
|
|
|
{
|
|
|
|
/* The UBW32 does not have a USB pull-up */
|
|
|
|
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
|
2019-08-08 16:53:04 +02:00
|
|
|
/****************************************************************************
|
2012-04-26 22:11:46 +02:00
|
|
|
* Name: pic32mx_usbsuspend
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Board logic must provide the stm32_usbsuspend logic if the USBDEV driver
|
|
|
|
* is used. This function is called whenever the USB enters or leaves
|
|
|
|
* suspend mode. This is an opportunity for the board logic to shutdown
|
|
|
|
* clocks, power, etc. while the USB is suspended.
|
|
|
|
*
|
2019-08-08 16:53:04 +02:00
|
|
|
****************************************************************************/
|
2012-04-26 22:11:46 +02:00
|
|
|
|
2022-04-17 14:48:23 +02:00
|
|
|
void pic32mx_usbsuspend(struct usbdev_s *dev, bool resume)
|
2012-04-26 22:11:46 +02:00
|
|
|
{
|
|
|
|
/* Do nothing */
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* CONFIG_PIC32MX_USBDEV */
|