DualVirtualSerial.c 6.43 KB
Newer Older
1
2
/*
             LUFA Library
Dean Camera's avatar
Dean Camera committed
3
     Copyright (C) Dean Camera, 2010.
4
5
6
7
8
9
              
  dean [at] fourwalledcubicle [dot] com
      www.fourwalledcubicle.com
*/

/*
Dean Camera's avatar
Dean Camera committed
10
  Copyright 2010  Dean Camera (dean [at] fourwalledcubicle [dot] com)
11

12
13
14
15
16
17
18
  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 
19
20
21
22
23
24
25
26
27
28
29
  software without specific, written prior permission.

  The author disclaim 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.
*/
30
31
32

/** \file
 *
33
 *  Main source file for the DualVirtualSerial demo. This file contains the main tasks of
34
35
36
 *  the demo and is responsible for the initial application hardware configuration.
 */

37
#include "DualVirtualSerial.h"
38

39
40
41
42
43
/** LUFA CDC Class driver interface configuration and state information. This structure is
 *  passed to all CDC Class driver functions, so that multiple instances of the same class
 *  within a device can be differentiated from one another. This is for the first CDC interface,
 *  which sends strings to the host for each joystick movement.
 */
44
USB_ClassInfo_CDC_Device_t VirtualSerial1_CDC_Interface =
45
	{
46
47
		.Config =
			{
48
				.ControlInterfaceNumber           = 0,
49

50
51
52
				.DataINEndpointNumber             = CDC1_TX_EPNUM,
				.DataINEndpointSize               = CDC_TXRX_EPSIZE,
				.DataINEndpointDoubleBank         = false,
53

54
55
56
				.DataOUTEndpointNumber            = CDC1_RX_EPNUM,
				.DataOUTEndpointSize              = CDC_TXRX_EPSIZE,
				.DataOUTEndpointDoubleBank        = false,
57

58
59
60
				.NotificationEndpointNumber       = CDC1_NOTIFICATION_EPNUM,
				.NotificationEndpointSize         = CDC_NOTIFICATION_EPSIZE,
				.NotificationEndpointDoubleBank   = false,
61
			},
62
63
	};

64
65
66
67
68
/** LUFA CDC Class driver interface configuration and state information. This structure is
 *  passed to all CDC Class driver functions, so that multiple instances of the same class
 *  within a device can be differentiated from one another. This is for the second CDC interface,
 *  which echos back all received data from the host.
 */
69
USB_ClassInfo_CDC_Device_t VirtualSerial2_CDC_Interface =
70
	{
71
72
		.Config =
			{
73
				.ControlInterfaceNumber           = 2,
74

75
76
77
				.DataINEndpointNumber             = CDC2_TX_EPNUM,
				.DataINEndpointSize               = CDC_TXRX_EPSIZE,
				.DataINEndpointDoubleBank         = false,
78

79
80
81
				.DataOUTEndpointNumber            = CDC2_RX_EPNUM,
				.DataOUTEndpointSize              = CDC_TXRX_EPSIZE,
				.DataOUTEndpointDoubleBank        = false,
82

83
84
85
				.NotificationEndpointNumber       = CDC2_NOTIFICATION_EPNUM,
				.NotificationEndpointSize         = CDC_NOTIFICATION_EPSIZE,
				.NotificationEndpointDoubleBank   = false,
86
			},
87
	};
88

89
90
91
/** Main program entry point. This routine contains the overall program flow, including initial
 *  setup of all components and the main program loop.
 */
92
int main(void)
93
94
95
96
{
	SetupHardware();
	
	LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);
97
	sei();
98
99
100
101
102

	for (;;)
	{
		CheckJoystickMovement();

103
		/* Discard all received data on the first CDC interface */
104
		while (CDC_Device_BytesReceived(&VirtualSerial1_CDC_Interface))
105
		  CDC_Device_ReceiveByte(&VirtualSerial1_CDC_Interface);
106

107
		/* Echo all received data on the second CDC interface */
108
		while (CDC_Device_BytesReceived(&VirtualSerial2_CDC_Interface))
109
		  CDC_Device_SendByte(&VirtualSerial2_CDC_Interface, CDC_Device_ReceiveByte(&VirtualSerial2_CDC_Interface));
110
		  
111
112
		CDC_Device_USBTask(&VirtualSerial1_CDC_Interface);
		CDC_Device_USBTask(&VirtualSerial2_CDC_Interface);
113
114
115
116
		USB_USBTask();
	}
}

117
/** Configures the board hardware and chip peripherals for the demo's functionality. */
118
void SetupHardware(void)
119
120
121
122
123
{
	/* Disable watchdog if enabled by bootloader/fuses */
	MCUSR &= ~(1 << WDRF);
	wdt_disable();

124
125
	/* Disable clock division */
	clock_prescale_set(clock_div_1);
126
127
128
129
130
131
132

	/* Hardware Initialization */
	Joystick_Init();
	LEDs_Init();
	USB_Init();
}

133
134
135
/** Checks for changes in the position of the board joystick, sending strings to the host upon each change
 *  through the first of the CDC interfaces.
 */
136
void CheckJoystickMovement(void)
137
{
138
139
140
141
	uint8_t     JoyStatus_LCL = Joystick_GetStatus();
	char*       ReportString  = NULL;
	static bool ActionSent = false;

142
	if (JoyStatus_LCL & JOY_UP)
143
	  ReportString = "Joystick Up\r\n";
144
	else if (JoyStatus_LCL & JOY_DOWN)
145
	  ReportString = "Joystick Down\r\n";
146
	else if (JoyStatus_LCL & JOY_LEFT)
147
	  ReportString = "Joystick Left\r\n";
148
	else if (JoyStatus_LCL & JOY_RIGHT)
149
	  ReportString = "Joystick Right\r\n";
150
	else if (JoyStatus_LCL & JOY_PRESS)
151
	  ReportString = "Joystick Pressed\r\n";
152
153
154
155
	else
	  ActionSent = false;
	  
	if ((ReportString != NULL) && (ActionSent == false))
156
157
158
	{
		ActionSent = true;
		
159
		CDC_Device_SendString(&VirtualSerial1_CDC_Interface, ReportString, strlen(ReportString));		
160
161
162
	}
}

163
/** Event handler for the library USB Connection event. */
164
void EVENT_USB_Device_Connect(void)
165
{
166
167
	LEDs_SetAllLEDs(LEDMASK_USB_ENUMERATING);
}
168

169
/** Event handler for the library USB Disconnection event. */
170
void EVENT_USB_Device_Disconnect(void)
171
172
173
{
	LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);
}
174

175
/** Event handler for the library USB Configuration Changed event. */
176
void EVENT_USB_Device_ConfigurationChanged(void)
177
178
{
	LEDs_SetAllLEDs(LEDMASK_USB_READY);
179

180
	if (!(CDC_Device_ConfigureEndpoints(&VirtualSerial1_CDC_Interface)))
181
	  LEDs_SetAllLEDs(LEDMASK_USB_ERROR);
182

183
	if (!(CDC_Device_ConfigureEndpoints(&VirtualSerial2_CDC_Interface)))
184
185
	  LEDs_SetAllLEDs(LEDMASK_USB_ERROR);
}
186

187
188
/** Event handler for the library USB Unhandled Control Request event. */
void EVENT_USB_Device_UnhandledControlRequest(void)
189
{
190
191
	CDC_Device_ProcessControlRequest(&VirtualSerial1_CDC_Interface);
	CDC_Device_ProcessControlRequest(&VirtualSerial2_CDC_Interface);
192
}