142ecdaf
rguillom
first commit
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
/*
LUFA Library
Copyright (C) Dean Camera, 2019.
dean [at] fourwalledcubicle [dot] com
www.lufa-lib.org
*/
/*
Copyright 2010 OBinou (obconseil [at] gmail [dot] com)
Copyright 2019 Dean Camera (dean [at] fourwalledcubicle [dot] com)
Permission to use, copy, modify, distribute, and sell this
software and its documentation for any purpose is hereby granted
without fee, provided that the above copyright notice appear in
all copies and that both that the copyright notice and this
permission notice and warranty disclaimer appear in supporting
documentation, and that the name of the author not be used in
advertising or publicity pertaining to distribution of the
software without specific, written prior permission.
The author disclaims all warranties with regard to this
software, including all implied warranties of merchantability
and fitness. In no event shall the author be liable for any
special, indirect or consequential damages or any damages
whatsoever resulting from loss of use, data or profits, whether
in an action of contract, negligence or other tortious action,
arising out of or in connection with the use or performance of
this software.
*/
/** \file
*
* Main source file for the PAD program. This file contains the main tasks of
* the project and is responsible for the initial application hardware configuration.
*/
#include "PAD.h"
|
01b3f0af
rguillom
PAD.c modif fonct...
|
41
42
43
44
45
46
47
|
#define debut_rcpt 0xff //valeur arbitraire pour détecter un début de trame
uint8_t boutons;
uint8_t joystick_x;
uint8_t joystick_y;
|
142ecdaf
rguillom
first commit
|
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
/** Main program entry point. This routine contains the overall program flow, including initial
* setup of all components and the main program loop.
*/
int main(void)
{
SetupHardware();
//LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);
GlobalInterruptEnable();
for (;;)
{
USB_USBTask();
//HID_Task();
}
|
752b62a9
rguillom
Descriptors + PAD...
|
63
|
}
|
142ecdaf
rguillom
first commit
|
64
65
66
67
|
/** Configures the board hardware and chip peripherals for the project's functionality. */
void SetupHardware(void)
{
|
01b3f0af
rguillom
PAD.c modif fonct...
|
68
|
#if (ARCH == ARCH_AVR8)
|
142ecdaf
rguillom
first commit
|
69
70
71
72
73
74
|
/* Disable watchdog if enabled by bootloader/fuses */
MCUSR &= ~(1 << WDRF);
wdt_disable();
/* Disable clock division */
clock_prescale_set(clock_div_1);
|
01b3f0af
rguillom
PAD.c modif fonct...
|
75
|
#endif
|
142ecdaf
rguillom
first commit
|
76
|
|
01b3f0af
rguillom
PAD.c modif fonct...
|
77
|
/**INITIALISATIONS*/
|
142ecdaf
rguillom
first commit
|
78
79
|
/* Hardware Initialization */
USB_Init();
|
01b3f0af
rguillom
PAD.c modif fonct...
|
80
|
Serial_Init(9600,0); //9600 Bauds, configuration
|
142ecdaf
rguillom
first commit
|
81
82
|
/* Initialize Relays */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
83
84
|
//DDRD |= ALL_RELAYS; // Port pour la liaison série
//PORTD &= ~ALL_RELAYS;
|
142ecdaf
rguillom
first commit
|
85
86
|
}
|
752b62a9
rguillom
Descriptors + PAD...
|
87
88
89
90
91
|
/** Event handler for the USB_ConfigurationChanged event. This is fired when the host sets the current configuration
* of the USB device after enumeration, and configures the keyboard device endpoints.
*/
void EVENT_USB_Device_ConfigurationChanged(void)
|
142ecdaf
rguillom
first commit
|
92
|
{
|
752b62a9
rguillom
Descriptors + PAD...
|
93
94
|
bool ConfigSuccess = true;
|
01b3f0af
rguillom
PAD.c modif fonct...
|
95
96
97
|
/* Setup HID Report Endpoints */
ConfigSuccess &= Endpoint_ConfigureEndpoint(KEYBOARD_OUT_EPADDR, EP_TYPE_INTERRUPT, LED_EPSIZE, 1);
ConfigSuccess &= Endpoint_ConfigureEndpoint(KEYBOARD_IN_Bout_EPADDR, EP_TYPE_INTERRUPT, BOUTONS_EPSIZE, 1);
|
813e00af
rguillom
Partie 3 : Descri...
|
98
|
ConfigSuccess &= Endpoint_ConfigureEndpoint(KEYBOARD_IN_Joy_EPADDR, EP_TYPE_INTERRUPT, JOYSTICK_EPSIZE, 1);
|
01b3f0af
rguillom
PAD.c modif fonct...
|
99
|
|
752b62a9
rguillom
Descriptors + PAD...
|
100
101
102
103
104
105
106
107
108
|
/* Turn on Start-of-Frame events for tracking HID report period expiry */
USB_Device_EnableSOFEvents();
/* Indicate endpoint configuration success or failure */
//LEDs_SetAllLEDs(ConfigSuccess ? LEDMASK_USB_READY : LEDMASK_USB_ERROR);
}
|
01b3f0af
rguillom
PAD.c modif fonct...
|
109
110
111
|
/** Sends the next PAD report to the host, via the buttons and joystick endpoint. */
void Send_EP_IN_Report(void)
|
752b62a9
rguillom
Descriptors + PAD...
|
112
|
{
|
01b3f0af
rguillom
PAD.c modif fonct...
|
113
114
115
|
//static USB_KeyboardReport_Data_t PrevKeyboardReportData;
//USB_KeyboardReport_Data_t KeyboardReportData;
//bool SendReport = false;
|
752b62a9
rguillom
Descriptors + PAD...
|
116
117
|
/* Create the next keyboard report for transmission to the host */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
118
|
//CreateKeyboardReport(&KeyboardReportData);
|
752b62a9
rguillom
Descriptors + PAD...
|
119
120
|
/* Check if the idle period is set and has elapsed */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
121
122
|
//if (IdleCount && (!(IdleMSRemaining)))
//{
|
752b62a9
rguillom
Descriptors + PAD...
|
123
|
/* Reset the idle time remaining counter */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
124
|
// IdleMSRemaining = IdleCount;
|
752b62a9
rguillom
Descriptors + PAD...
|
125
126
|
/* Idle period is set and has elapsed, must send a report to the host */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
127
128
129
130
|
//SendReport = true;
//}
//else
//{
|
752b62a9
rguillom
Descriptors + PAD...
|
131
|
/* Check to see if the report data has changed - if so a report MUST be sent */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
132
133
|
//SendReport = (memcmp(&PrevKeyboardReportData, &KeyboardReportData, sizeof(USB_KeyboardReport_Data_t)) != 0);
//}
|
752b62a9
rguillom
Descriptors + PAD...
|
134
135
136
|
/** Envoi sur INTERFACE BOUTONS**/
|
01b3f0af
rguillom
PAD.c modif fonct...
|
137
|
/* Select the Buttons Report Endpoint */
|
752b62a9
rguillom
Descriptors + PAD...
|
138
139
140
|
Endpoint_SelectEndpoint(KEYBOARD_IN_Bout_EPADDR);
/* Check if Keyboard Endpoint Ready for Read/Write and if we should send a new report */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
141
|
if (Endpoint_IsReadWriteAllowed() && Endpoint_IsINReady)
|
752b62a9
rguillom
Descriptors + PAD...
|
142
143
|
{
/* Save the current report data for later comparison to check for changes */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
144
|
//PrevKeyboardReportData = KeyboardReportData;
|
142ecdaf
rguillom
first commit
|
145
|
|
752b62a9
rguillom
Descriptors + PAD...
|
146
|
/* Write Keyboard Report Data */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
147
148
|
//Endpoint_Write_Stream_LE(&KeyboardReportData, sizeof(KeyboardReportData), NULL);
Endpoint_Write_8(boutons);
|
752b62a9
rguillom
Descriptors + PAD...
|
149
150
151
152
|
/* Finalize the stream transfer to send the last packet */
Endpoint_ClearIN();
}
|
01b3f0af
rguillom
PAD.c modif fonct...
|
153
|
else printf("Buttons endpoint not ready to send\n");
|
752b62a9
rguillom
Descriptors + PAD...
|
154
155
156
157
158
159
|
/** Envoi sur INTERFACE Joystick**/
/* Select the Keyboard Report Endpoint */
Endpoint_SelectEndpoint(KEYBOARD_IN_Joy_EPADDR);
/* Check if Keyboard Endpoint Ready for Read/Write and if we should send a new report */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
160
|
if (Endpoint_IsReadWriteAllowed() && Endpoint_IsINReady)
|
142ecdaf
rguillom
first commit
|
161
|
{
|
752b62a9
rguillom
Descriptors + PAD...
|
162
|
/* Save the current report data for later comparison to check for changes */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
163
|
//PrevKeyboardReportData = KeyboardReportData;
|
752b62a9
rguillom
Descriptors + PAD...
|
164
165
|
/* Write Keyboard Report Data */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
166
167
168
|
//Endpoint_Write_Stream_LE(&KeyboardReportData, sizeof(KeyboardReportData), NULL);
Endpoint_Write_8(joystick_x);
Endpoint_Write_8(joystick_y);
|
752b62a9
rguillom
Descriptors + PAD...
|
169
170
171
|
/* Finalize the stream transfer to send the last packet */
Endpoint_ClearIN();
|
142ecdaf
rguillom
first commit
|
172
|
}
|
01b3f0af
rguillom
PAD.c modif fonct...
|
173
|
else printf("Joystick endpoint not ready to send\n");
|
142ecdaf
rguillom
first commit
|
174
175
|
}
|
752b62a9
rguillom
Descriptors + PAD...
|
176
|
|
01b3f0af
rguillom
PAD.c modif fonct...
|
177
|
|
752b62a9
rguillom
Descriptors + PAD...
|
178
|
/** Reads the next LED status report from the host from the LED data endpoint, if one has been sent. */
|
01b3f0af
rguillom
PAD.c modif fonct...
|
179
|
void Receive_EP_OUT_Report(void) //Réception Liaison Série
|
752b62a9
rguillom
Descriptors + PAD...
|
180
181
182
183
184
185
186
187
188
189
190
191
192
|
{
/* Select the Keyboard LED Report Endpoint */
Endpoint_SelectEndpoint(KEYBOARD_OUT_EPADDR);
/* Check if Keyboard LED Endpoint contains a packet */
if (Endpoint_IsOUTReceived())
{
/* Check to see if the packet contains data */
if (Endpoint_IsReadWriteAllowed())
{
/* Read in the LED report from the host */
uint8_t LEDReport = Endpoint_Read_8();
|
01b3f0af
rguillom
PAD.c modif fonct...
|
193
194
|
/* On envoie l'octet de commande de led sur la liaison série */
Serial_SendByte(LEDReport);
|
752b62a9
rguillom
Descriptors + PAD...
|
195
|
}
|
01b3f0af
rguillom
PAD.c modif fonct...
|
196
|
else printf("LED endpoint not ready to receive\n");
|
752b62a9
rguillom
Descriptors + PAD...
|
197
198
199
200
201
|
/* Handshake the OUT Endpoint - clear endpoint and ready for next report */
Endpoint_ClearOUT();
}
}
|
01b3f0af
rguillom
PAD.c modif fonct...
|
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
|
void Reception_Serie(void){
if(Serial_IsCharReceived()){ // A la réception d'un caractère...
/* on vérifie qu'on a bien un début de trame*/
unsigned char caractere = Serial_ReceiveByte();
/* si oui, on récupère les trois octets suivants*/
if (caractere==debut_rcpt){
boutons = Serial_ReceiveByte();
joystick_x = Serial_ReceiveByte();
joystick_y = Serial_ReceiveByte();
}
}
}
/** Function to manage PAD report generation and transmission to the host, when in report mode. */
void PAD_Task(void)
{
/* Device must be connected and configured for the task to run */
if (USB_DeviceState != DEVICE_STATE_Configured)
return;
Reception_Serie(); //Réception des données de la liaison série
/* Send the next button/joystick report to the host */
Send_EP_IN_Report();
/* Process the LED report sent from the host */
Receive_EP_OUT_Report();
}
|