]> git.donarmstrong.com Git - qmk_firmware.git/blob - tmk_core/protocol/lufa/LUFA-120730/LUFA/Drivers/USB/Core/UC3/USBController_UC3.c
Merge commit 'a074364c3731d66b56d988c8a6c960a83ea0e0a1' as 'tmk_core'
[qmk_firmware.git] / tmk_core / protocol / lufa / LUFA-120730 / LUFA / Drivers / USB / Core / UC3 / USBController_UC3.c
1 /*\r
2              LUFA Library\r
3      Copyright (C) Dean Camera, 2012.\r
4 \r
5   dean [at] fourwalledcubicle [dot] com\r
6            www.lufa-lib.org\r
7 */\r
8 \r
9 /*\r
10   Copyright 2012  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
11 \r
12   Permission to use, copy, modify, distribute, and sell this\r
13   software and its documentation for any purpose is hereby granted\r
14   without fee, provided that the above copyright notice appear in\r
15   all copies and that both that the copyright notice and this\r
16   permission notice and warranty disclaimer appear in supporting\r
17   documentation, and that the name of the author not be used in\r
18   advertising or publicity pertaining to distribution of the\r
19   software without specific, written prior permission.\r
20 \r
21   The author disclaim all warranties with regard to this\r
22   software, including all implied warranties of merchantability\r
23   and fitness.  In no event shall the author be liable for any\r
24   special, indirect or consequential damages or any damages\r
25   whatsoever resulting from loss of use, data or profits, whether\r
26   in an action of contract, negligence or other tortious action,\r
27   arising out of or in connection with the use or performance of\r
28   this software.\r
29 */\r
30 \r
31 #include "../../../../Common/Common.h"\r
32 #if (ARCH == ARCH_UC3)\r
33 \r
34 #define  __INCLUDE_FROM_USB_DRIVER\r
35 #define  __INCLUDE_FROM_USB_CONTROLLER_C\r
36 #include "../USBController.h"\r
37 \r
38 #if (!defined(USB_HOST_ONLY) && !defined(USB_DEVICE_ONLY))\r
39 volatile uint8_t USB_CurrentMode = USB_MODE_None;\r
40 #endif\r
41 \r
42 #if !defined(USE_STATIC_OPTIONS)\r
43 volatile uint8_t USB_Options;\r
44 #endif\r
45 \r
46 void USB_Init(\r
47                #if defined(USB_CAN_BE_BOTH)\r
48                const uint8_t Mode\r
49                #endif\r
50 \r
51                #if (defined(USB_CAN_BE_BOTH) && !defined(USE_STATIC_OPTIONS))\r
52                ,\r
53                #elif (!defined(USB_CAN_BE_BOTH) && defined(USE_STATIC_OPTIONS))\r
54                void\r
55                #endif\r
56 \r
57                #if !defined(USE_STATIC_OPTIONS)\r
58                const uint8_t Options\r
59                #endif\r
60                )\r
61 {\r
62         #if !defined(USE_STATIC_OPTIONS)\r
63         USB_Options = Options;\r
64         #endif\r
65 \r
66         #if defined(USB_CAN_BE_BOTH)\r
67         if (Mode == USB_MODE_UID)\r
68         {\r
69                 AVR32_USBB.USBCON.uide = true;\r
70                 USB_INT_Enable(USB_INT_IDTI);\r
71                 USB_CurrentMode = USB_GetUSBModeFromUID();\r
72         }\r
73         else\r
74         {\r
75                 AVR32_USBB.USBCON.uide = false;\r
76                 USB_CurrentMode = Mode;\r
77         }\r
78         #else\r
79         AVR32_USBB.USBCON.uide = false;\r
80         #endif\r
81 \r
82         USB_IsInitialized = true;\r
83 \r
84         USB_ResetInterface();\r
85 }\r
86 \r
87 void USB_Disable(void)\r
88 {\r
89         USB_INT_DisableAllInterrupts();\r
90         USB_INT_ClearAllInterrupts();\r
91 \r
92         USB_Detach();\r
93         USB_Controller_Disable();\r
94 \r
95         USB_OTGPAD_Off();\r
96 \r
97         #if defined(USB_CAN_BE_BOTH)\r
98         USB_CurrentMode = USB_MODE_None;\r
99         #endif\r
100 \r
101         AVR32_PM.GCCTRL[3].cen = false;\r
102 \r
103         USB_IsInitialized = false;\r
104 }\r
105 \r
106 void USB_ResetInterface(void)\r
107 {\r
108         #if defined(USB_CAN_BE_BOTH)\r
109         bool UIDModeSelectEnabled = AVR32_USBB.USBCON.uide;\r
110         #endif\r
111 \r
112         AVR32_PM.GCCTRL[AVR32_PM_GCLK_USBB].pllsel = !(USB_Options & USB_OPT_GCLK_SRC_OSC);\r
113         AVR32_PM.GCCTRL[AVR32_PM_GCLK_USBB].oscsel = !(USB_Options & USB_OPT_GCLK_CHANNEL_0);\r
114         AVR32_PM.GCCTRL[AVR32_PM_GCLK_USBB].diven  = (F_USB != USB_CLOCK_REQUIRED_FREQ);\r
115         AVR32_PM.GCCTRL[AVR32_PM_GCLK_USBB].div    = (F_USB == USB_CLOCK_REQUIRED_FREQ) ? 0 : (uint32_t)((F_USB / USB_CLOCK_REQUIRED_FREQ / 2) - 1);\r
116         AVR32_PM.GCCTRL[AVR32_PM_GCLK_USBB].cen    = true;\r
117 \r
118         USB_INT_DisableAllInterrupts();\r
119         USB_INT_ClearAllInterrupts();\r
120 \r
121         USB_Controller_Reset();\r
122 \r
123         #if defined(USB_CAN_BE_BOTH)\r
124         if (UIDModeSelectEnabled)\r
125           USB_INT_Enable(USB_INT_IDTI);\r
126         #endif\r
127 \r
128         USB_CLK_Unfreeze();\r
129 \r
130         if (USB_CurrentMode == USB_MODE_Device)\r
131         {\r
132                 #if defined(USB_CAN_BE_DEVICE)\r
133                 AVR32_USBB.USBCON.uimod = true;\r
134 \r
135                 USB_Init_Device();\r
136                 #endif\r
137         }\r
138         else if (USB_CurrentMode == USB_MODE_Host)\r
139         {\r
140                 #if defined(INVERTED_VBUS_ENABLE_LINE)\r
141                 AVR32_USBB.USBCON.vbuspo = true;\r
142                 #endif\r
143                 \r
144                 #if defined(USB_CAN_BE_HOST)\r
145                 AVR32_USBB.USBCON.uimod = false;\r
146 \r
147                 USB_Init_Host();\r
148                 #endif\r
149         }\r
150 \r
151         USB_OTGPAD_On();\r
152 }\r
153 \r
154 #if defined(USB_CAN_BE_DEVICE)\r
155 static void USB_Init_Device(void)\r
156 {\r
157         USB_DeviceState                 = DEVICE_STATE_Unattached;\r
158         USB_Device_ConfigurationNumber  = 0;\r
159 \r
160         #if !defined(NO_DEVICE_REMOTE_WAKEUP)\r
161         USB_Device_RemoteWakeupEnabled  = false;\r
162         #endif\r
163 \r
164         #if !defined(NO_DEVICE_SELF_POWER)\r
165         USB_Device_CurrentlySelfPowered = false;\r
166         #endif\r
167 \r
168         #if !defined(FIXED_CONTROL_ENDPOINT_SIZE)\r
169         USB_Descriptor_Device_t* DeviceDescriptorPtr;\r
170 \r
171         if (CALLBACK_USB_GetDescriptor((DTYPE_Device << 8), 0, (void*)&DeviceDescriptorPtr) != NO_DESCRIPTOR)\r
172           USB_Device_ControlEndpointSize = DeviceDescriptorPtr->Endpoint0Size;\r
173         #endif\r
174 \r
175         if (USB_Options & USB_DEVICE_OPT_LOWSPEED)\r
176         {\r
177                 USB_Device_SetLowSpeed();\r
178         }\r
179         else\r
180         {\r
181                 #if defined(USB_DEVICE_OPT_HIGHSPEED)\r
182                 if (USB_Options & USB_DEVICE_OPT_HIGHSPEED)\r
183                   USB_Device_SetHighSpeed();\r
184                 else\r
185                   USB_Device_SetFullSpeed();\r
186                 #else\r
187                 USB_Device_SetFullSpeed();\r
188                 #endif\r
189         }\r
190 \r
191         USB_INT_Enable(USB_INT_VBUSTI);\r
192 \r
193         Endpoint_ConfigureEndpoint(ENDPOINT_CONTROLEP, EP_TYPE_CONTROL,\r
194                                                            USB_Device_ControlEndpointSize, 1);\r
195 \r
196         USB_INT_Clear(USB_INT_SUSPI);\r
197         USB_INT_Enable(USB_INT_SUSPI);\r
198         USB_INT_Enable(USB_INT_EORSTI);\r
199 \r
200         USB_Attach();\r
201 }\r
202 #endif\r
203 \r
204 #if defined(USB_CAN_BE_HOST)\r
205 static void USB_Init_Host(void)\r
206 {\r
207         USB_HostState                = HOST_STATE_Unattached;\r
208         USB_Host_ConfigurationNumber = 0;\r
209         USB_Host_ControlPipeSize     = PIPE_CONTROLPIPE_DEFAULT_SIZE;\r
210 \r
211         USB_Host_HostMode_On();\r
212 \r
213         USB_Host_VBUS_Auto_On();\r
214 \r
215         USB_INT_Enable(USB_INT_DCONNI);\r
216         USB_INT_Enable(USB_INT_BCERRI);\r
217 \r
218         USB_Attach();\r
219 }\r
220 #endif\r
221 \r
222 #endif\r