fbb71ecb4628c12137dcb5fe01d4e504b9d12e71
[fw/stlink] / example / stm32f4 / STM32_USB_OTG_Driver / src / usb_otg.c
1 /**
2   ******************************************************************************
3   * @file    usb_otg.c
4   * @author  MCD Application Team
5   * @version V2.0.0
6   * @date    22-July-2011
7   * @brief   OTG Core Layer
8   ******************************************************************************
9   * @attention
10   *
11   * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
12   * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
13   * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
14   * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
15   * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
16   * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
17   *
18   * <h2><center>&copy; COPYRIGHT 2011 STMicroelectronics</center></h2>
19   ******************************************************************************
20   */
21
22 /* Includes ------------------------------------------------------------------*/
23 #include "usb_defines.h"
24 #include "usb_regs.h"
25 #include "usb_core.h"
26 #include "usb_otg.h"
27
28 /** @addtogroup USB_OTG_DRIVER
29   * @{
30   */
31   
32 /** @defgroup USB_OTG 
33   * @brief This file is the interface between EFSL ans Host mass-storage class
34   * @{
35   */
36
37
38 /** @defgroup USB_OTG_Private_Defines
39   * @{
40   */ 
41 /**
42   * @}
43   */ 
44  
45
46 /** @defgroup USB_OTG_Private_TypesDefinitions
47   * @{
48   */ 
49 /**
50   * @}
51   */ 
52
53
54
55 /** @defgroup USB_OTG_Private_Macros
56   * @{
57   */ 
58 /**
59   * @}
60   */ 
61
62
63 /** @defgroup USB_OTG_Private_Variables
64   * @{
65   */ 
66 /**
67   * @}
68   */ 
69
70
71 /** @defgroup USB_OTG_Private_FunctionPrototypes
72   * @{
73   */ 
74
75 static uint32_t USB_OTG_Read_itr(USB_OTG_CORE_HANDLE *pdev);
76
77 /**
78   * @}
79   */ 
80
81
82 /** @defgroup USB_OTG_Private_Functions
83   * @{
84   */ 
85
86
87 /*                           OTG Interrupt Handler                         */
88
89
90 /**
91   * @brief  STM32_USBO_OTG_ISR_Handler
92   *         
93   * @param  None
94   * @retval : None
95   */
96 uint32_t STM32_USBO_OTG_ISR_Handler(USB_OTG_CORE_HANDLE *pdev)
97 {
98   uint32_t retval = 0;
99   USB_OTG_GINTSTS_TypeDef  gintsts ;
100   gintsts.d32 = 0;
101
102   gintsts.d32 = USB_OTG_Read_itr(pdev);
103   if (gintsts.d32 == 0)
104   {
105     return 0;
106   }
107   if (gintsts.b.otgintr)
108   {
109     retval |= 1;//USB_OTG_HandleOTG_ISR(pdev);
110   }
111   if (gintsts.b.conidstschng)
112   {
113     retval |= 2;//USB_OTG_HandleConnectorIDStatusChange_ISR(pdev);
114   }
115   if (gintsts.b.sessreqintr)
116   {
117     retval |= 3;//USB_OTG_HandleSessionRequest_ISR(pdev);
118   }
119   return retval;
120 }
121
122
123 /**
124   * @brief  USB_OTG_Read_itr
125   *         returns the Core Interrupt register
126   * @param  None
127   * @retval : status
128   */
129 static uint32_t USB_OTG_Read_itr(USB_OTG_CORE_HANDLE *pdev)
130 {
131   USB_OTG_GINTSTS_TypeDef  gintsts;
132   USB_OTG_GINTMSK_TypeDef  gintmsk;
133   USB_OTG_GINTMSK_TypeDef  gintmsk_common;
134   
135   
136   gintsts.d32 = 0;
137   gintmsk.d32 = 0;
138   gintmsk_common.d32 = 0;
139   
140   /* OTG interrupts */
141   gintmsk_common.b.sessreqintr = 1;
142   gintmsk_common.b.conidstschng = 1;
143   gintmsk_common.b.otgintr = 1;
144   
145   gintsts.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GINTSTS);
146   gintmsk.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GINTMSK);
147   return ((gintsts.d32 & gintmsk.d32 ) & gintmsk_common.d32);
148 }
149
150
151 /**
152   * @brief  USB_OTG_GetCurrentState
153   *         Return current OTG State
154   * @param  None
155   * @retval : None
156   */
157 uint32_t USB_OTG_GetCurrentState (USB_OTG_CORE_HANDLE *pdev)
158 {
159   return pdev->otg.OTG_State;
160 }
161
162
163 /**
164 * @}
165 */ 
166
167 /**
168 * @}
169 */ 
170
171 /**
172 * @}
173 */
174
175 /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/