DualVirtualSerial.c 6.41 KB
Newer Older
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
/*
             LUFA Library
     Copyright (C) Dean Camera, 2009.
              
  dean [at] fourwalledcubicle [dot] com
      www.fourwalledcubicle.com
*/

/*
  Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com)

  Permission to use, copy, modify, and distribute this software
  and its documentation for any purpose and without fee is hereby
  granted, 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 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
97
98
99
100
101
{
	SetupHardware();
	
	LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);

	for (;;)
	{
		CheckJoystickMovement();

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

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

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

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

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

132
133
134
/** 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.
 */
135
void CheckJoystickMovement(void)
136
{
137
138
139
140
	uint8_t     JoyStatus_LCL = Joystick_GetStatus();
	char*       ReportString  = NULL;
	static bool ActionSent = false;

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

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

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

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

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

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

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