/**************************************************************************** * boards/arm/stm32/photon/src/stm32_composite.c * * 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 * * 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. * ****************************************************************************/ /**************************************************************************** * Included Files ****************************************************************************/ #include #include #include #include #include #include #include #include #include "stm32.h" #if defined(CONFIG_BOARDCTL_USBDEVCTRL) && defined(CONFIG_USBDEV_COMPOSITE) /**************************************************************************** * Pre-processor Definitions ****************************************************************************/ /**************************************************************************** * Private Data ****************************************************************************/ /**************************************************************************** * Private Functions ****************************************************************************/ /**************************************************************************** * Name: board_composite0_connect * * Description: * Connect the USB composite device on the specified USB device port for * configuration 0. * * Input Parameters: * port - The USB device port. * * Returned Value: * A non-NULL handle value is returned on success. NULL is returned on * any failure. * ****************************************************************************/ static void *board_composite0_connect(int port) { /* Here we are composing the configuration of the usb composite device. * * The standard is to use one CDC/ACM and one USB mass storage device. */ /* Change "dev" array size to add more composite devs */ struct composite_devdesc_s dev[1]; int ifnobase = 0; int strbase = (COMPOSITE_NSTRIDS) - 1; int dev_idx = 0; #ifdef CONFIG_USBADB /* Configure the ADB USB device */ /* Ask the adb driver to fill in the constants we didn't * know here. */ usbdev_adb_get_composite_devdesc(&dev[dev_idx]); /* Interfaces */ dev[dev_idx].devinfo.ifnobase = ifnobase; /* Offset to Interface-IDs */ dev[dev_idx].minor = 0; /* The minor interface number */ /* Strings */ dev[dev_idx].devinfo.strbase = strbase; /* Offset to String Numbers */ /* Endpoints */ dev[dev_idx].devinfo.epno[USBADB_EP_BULKIN_IDX] = 1; dev[dev_idx].devinfo.epno[USBADB_EP_BULKOUT_IDX] = 2; /* Count up the base numbers */ ifnobase += dev[dev_idx].devinfo.ninterfaces; strbase += dev[dev_idx].devinfo.nstrings; dev_idx += 1; #endif /* Add other composite devices here */ return composite_initialize(composite_getdevdescs(), dev, dev_idx); } /**************************************************************************** * Public Functions ****************************************************************************/ /**************************************************************************** * Name: board_composite_initialize * * Description: * Perform architecture specific initialization of a composite USB device. * ****************************************************************************/ int board_composite_initialize(int port) { return OK; } /**************************************************************************** * Name: board_composite_connect * * Description: * Connect the USB composite device on the specified USB device port using * the specified configuration. The interpretation of the configid is * board specific. * * Input Parameters: * port - The USB device port. * configid - The USB composite configuration * * Returned Value: * A non-NULL handle value is returned on success. NULL is returned on * any failure. * ****************************************************************************/ void *board_composite_connect(int port, int configid) { if (configid == 0) { return board_composite0_connect(port); } return NULL; } #endif /* CONFIG_BOARDCTL_USBDEVCTRL && CONFIG_USBDEV_COMPOSITE */