ehci_controller_fake.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /**************************************************************************/
  2. /*!
  3. @file ehci_controller_fake
  4. @author hathach (tinyusb.org)
  5. @section LICENSE
  6. Software License Agreement (BSD License)
  7. Copyright (c) 2013, hathach (tinyusb.org)
  8. All rights reserved.
  9. Redistribution and use in source and binary forms, with or without
  10. modification, are permitted provided that the following conditions are met:
  11. 1. Redistributions of source code must retain the above copyright
  12. notice, this list of conditions and the following disclaimer.
  13. 2. Redistributions in binary form must reproduce the above copyright
  14. notice, this list of conditions and the following disclaimer in the
  15. documentation and/or other materials provided with the distribution.
  16. 3. Neither the name of the copyright holders nor the
  17. names of its contributors may be used to endorse or promote products
  18. derived from this software without specific prior written permission.
  19. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY
  20. EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  21. WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  22. DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY
  23. DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  24. INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  25. LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION HOWEVER CAUSED AND
  26. ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. INCLUDING NEGLIGENCE OR OTHERWISE ARISING IN ANY WAY OUT OF THE USE OF THIS
  28. SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. This file is part of the tinyusb stack.
  30. */
  31. /**************************************************************************/
  32. /** \file
  33. * \brief TBD
  34. *
  35. * \note TBD
  36. */
  37. /** \ingroup TBD
  38. * \defgroup TBD
  39. * \brief TBD
  40. *
  41. * @{
  42. */
  43. #ifndef _TUSB_EHCI_CONTROLLER_H_
  44. #define _TUSB_EHCI_CONTROLLER_H_
  45. #include "host/hcd.h"
  46. #ifdef __cplusplus
  47. extern "C" {
  48. #endif
  49. extern ehci_data_t ehci_data;
  50. void ehci_controller_init(void);
  51. void ehci_controller_run(uint8_t hostid);
  52. void ehci_controller_run_error(uint8_t hostid);
  53. void ehci_controller_control_xfer_proceed(uint8_t dev_addr, uint8_t p_data[]);
  54. void ehci_controller_device_plug(uint8_t hostid, tusb_speed_t speed);
  55. void ehci_controller_device_unplug(uint8_t hostid);
  56. ehci_registers_t* get_operational_register(uint8_t hostid);
  57. ehci_link_t* get_period_frame_list(uint8_t hostid);
  58. ehci_qhd_t* get_async_head(uint8_t hostid);
  59. ehci_link_t* get_period_head(uint8_t hostid, uint8_t interval_ms);
  60. ehci_qhd_t* get_control_qhd(uint8_t dev_addr);
  61. ehci_qtd_t* get_control_qtds(uint8_t dev_addr);
  62. ehci_qhd_t* qhd_get_from_pipe_handle(pipe_handle_t pipe_hdl);
  63. #ifdef __cplusplus
  64. }
  65. #endif
  66. #endif /* _TUSB_EHCI_CONTROLLER_H_ */
  67. /** @} */