2011-03-14 18:12:46 +00:00
|
|
|
/*
|
|
|
|
* This file is part of the libopencm3 project.
|
|
|
|
*
|
2011-11-10 20:40:29 +00:00
|
|
|
* Copyright (C) 2011 Gareth McMullin <gareth@blacksphere.co.nz>
|
2011-03-14 18:12:46 +00:00
|
|
|
*
|
2012-03-02 10:23:11 +00:00
|
|
|
* This library is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
2011-03-14 18:12:46 +00:00
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
2012-03-02 10:23:11 +00:00
|
|
|
* This library is distributed in the hope that it will be useful,
|
2011-03-14 18:12:46 +00:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2012-03-02 10:23:11 +00:00
|
|
|
* GNU Lesser General Public License for more details.
|
2011-03-14 18:12:46 +00:00
|
|
|
*
|
2012-03-02 10:23:11 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with this library. If not, see <http://www.gnu.org/licenses/>.
|
2011-03-14 18:12:46 +00:00
|
|
|
*/
|
|
|
|
|
2011-10-13 03:58:27 +00:00
|
|
|
#include <libopencm3/stm32/f1/rcc.h>
|
|
|
|
#include <libopencm3/stm32/f1/gpio.h>
|
2011-03-14 18:12:46 +00:00
|
|
|
#include <libopencm3/usb/usbd.h>
|
|
|
|
|
|
|
|
const struct usb_device_descriptor dev = {
|
2011-11-13 16:07:21 +00:00
|
|
|
.bLength = USB_DT_DEVICE_SIZE,
|
|
|
|
.bDescriptorType = USB_DT_DEVICE,
|
|
|
|
.bcdUSB = 0x0200,
|
|
|
|
.bDeviceClass = 0xFF,
|
|
|
|
.bDeviceSubClass = 0,
|
|
|
|
.bDeviceProtocol = 0,
|
|
|
|
.bMaxPacketSize0 = 64,
|
|
|
|
.idVendor = 0xCAFE,
|
|
|
|
.idProduct = 0xCAFE,
|
|
|
|
.bcdDevice = 0x0200,
|
|
|
|
.iManufacturer = 1,
|
|
|
|
.iProduct = 2,
|
|
|
|
.iSerialNumber = 3,
|
|
|
|
.bNumConfigurations = 1,
|
2011-03-14 18:12:46 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const struct usb_interface_descriptor iface = {
|
|
|
|
.bLength = USB_DT_INTERFACE_SIZE,
|
|
|
|
.bDescriptorType = USB_DT_INTERFACE,
|
|
|
|
.bInterfaceNumber = 0,
|
|
|
|
.bAlternateSetting = 0,
|
|
|
|
.bNumEndpoints = 0,
|
|
|
|
.bInterfaceClass = 0xFF,
|
|
|
|
.bInterfaceSubClass = 0,
|
|
|
|
.bInterfaceProtocol = 0,
|
|
|
|
.iInterface = 0,
|
|
|
|
};
|
|
|
|
|
|
|
|
const struct usb_interface ifaces[] = {{
|
|
|
|
.num_altsetting = 1,
|
|
|
|
.altsetting = &iface,
|
|
|
|
}};
|
|
|
|
|
|
|
|
const struct usb_config_descriptor config = {
|
|
|
|
.bLength = USB_DT_CONFIGURATION_SIZE,
|
|
|
|
.bDescriptorType = USB_DT_CONFIGURATION,
|
|
|
|
.wTotalLength = 0,
|
|
|
|
.bNumInterfaces = 1,
|
|
|
|
.bConfigurationValue = 1,
|
|
|
|
.iConfiguration = 0,
|
|
|
|
.bmAttributes = 0x80,
|
|
|
|
.bMaxPower = 0x32,
|
|
|
|
|
|
|
|
.interface = ifaces,
|
|
|
|
};
|
|
|
|
|
|
|
|
const char *usb_strings[] = {
|
|
|
|
"x",
|
|
|
|
"Black Sphere Technologies",
|
|
|
|
"Simple Device",
|
2011-11-13 16:07:21 +00:00
|
|
|
"1001",
|
2011-03-14 18:12:46 +00:00
|
|
|
};
|
|
|
|
|
2012-08-17 01:50:38 +00:00
|
|
|
static int simple_control_callback(usbd_device *usbd_dev, struct usb_setup_data *req, u8 **buf,
|
|
|
|
u16 *len, void (**complete)(usbd_device *usbd_dev, struct usb_setup_data *req))
|
2011-03-14 18:12:46 +00:00
|
|
|
{
|
|
|
|
(void)buf;
|
|
|
|
(void)len;
|
|
|
|
(void)complete;
|
2012-08-17 01:50:38 +00:00
|
|
|
(void)usbd_dev;
|
2011-03-14 18:12:46 +00:00
|
|
|
|
2011-11-13 16:07:21 +00:00
|
|
|
if (req->bmRequestType != 0x40)
|
|
|
|
return 0; /* Only accept vendor request. */
|
2012-08-17 01:50:38 +00:00
|
|
|
|
2011-11-13 16:07:21 +00:00
|
|
|
if (req->wValue & 1)
|
2011-03-14 18:12:46 +00:00
|
|
|
gpio_set(GPIOC, GPIO6);
|
|
|
|
else
|
|
|
|
gpio_clear(GPIOC, GPIO6);
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2012-08-17 01:50:38 +00:00
|
|
|
usbd_device *usbd_dev;
|
|
|
|
|
2011-03-14 18:12:46 +00:00
|
|
|
rcc_clock_setup_in_hse_8mhz_out_72mhz();
|
|
|
|
|
|
|
|
rcc_peripheral_enable_clock(&RCC_APB2ENR, RCC_APB2ENR_IOPAEN);
|
|
|
|
rcc_peripheral_enable_clock(&RCC_APB2ENR, RCC_APB2ENR_IOPCEN);
|
2011-12-17 01:11:39 +00:00
|
|
|
rcc_peripheral_enable_clock(&RCC_AHBENR, RCC_AHBENR_OTGFSEN);
|
2011-03-14 18:12:46 +00:00
|
|
|
|
|
|
|
/* LED output */
|
2011-11-13 16:07:21 +00:00
|
|
|
gpio_set_mode(GPIOC, GPIO_MODE_OUTPUT_2_MHZ,
|
|
|
|
GPIO_CNF_OUTPUT_PUSHPULL, GPIO6);
|
2011-03-14 18:12:46 +00:00
|
|
|
|
2012-08-17 01:50:38 +00:00
|
|
|
usbd_dev = usbd_init(&stm32f107_usb_driver, &dev, &config, usb_strings);
|
2011-03-14 18:12:46 +00:00
|
|
|
usbd_register_control_callback(
|
2012-08-17 01:50:38 +00:00
|
|
|
usbd_dev,
|
2011-11-13 16:07:21 +00:00
|
|
|
USB_REQ_TYPE_VENDOR,
|
2011-03-14 18:12:46 +00:00
|
|
|
USB_REQ_TYPE_TYPE,
|
|
|
|
simple_control_callback);
|
|
|
|
|
2011-11-13 16:07:21 +00:00
|
|
|
while (1)
|
2012-08-17 01:50:38 +00:00
|
|
|
usbd_poll(usbd_dev);
|
2011-03-14 18:12:46 +00:00
|
|
|
}
|
|
|
|
|