Changed AVRISP-MKII project to use the Watchdog interrupt for command timeouts, to...
[pub/USBasp.git] / LUFA / Drivers / USB / Class / Common / Printer.h
1 /*
2 LUFA Library
3 Copyright (C) Dean Camera, 2011.
4
5 dean [at] fourwalledcubicle [dot] com
6 www.lufa-lib.org
7 */
8
9 /*
10 Copyright 2011 Dean Camera (dean [at] fourwalledcubicle [dot] com)
11
12 Permission to use, copy, modify, distribute, and sell this
13 software and its documentation for any purpose is hereby granted
14 without fee, provided that the above copyright notice appear in
15 all copies and that both that the copyright notice and this
16 permission notice and warranty disclaimer appear in supporting
17 documentation, and that the name of the author not be used in
18 advertising or publicity pertaining to distribution of the
19 software without specific, written prior permission.
20
21 The author disclaim all warranties with regard to this
22 software, including all implied warranties of merchantability
23 and fitness. In no event shall the author be liable for any
24 special, indirect or consequential damages or any damages
25 whatsoever resulting from loss of use, data or profits, whether
26 in an action of contract, negligence or other tortious action,
27 arising out of or in connection with the use or performance of
28 this software.
29 */
30
31 /** \file
32 * \brief Common definitions and declarations for the library USB Printer Class driver.
33 *
34 * Common definitions and declarations for the library USB Printer Class driver.
35 *
36 * \note This file should not be included directly. It is automatically included as needed by the USB module driver
37 * dispatch header located in LUFA/Drivers/USB.h.
38 */
39
40 /** \ingroup Group_USBClassPrinter
41 * @defgroup Group_USBClassPrinterCommon Common Class Definitions
42 *
43 * \section Sec_ModDescription Module Description
44 * Constants, Types and Enum definitions that are common to both Device and Host modes for the USB
45 * Printer Class.
46 *
47 * @{
48 */
49
50 #ifndef _PRINTER_CLASS_COMMON_H_
51 #define _PRINTER_CLASS_COMMON_H_
52
53 /* Includes: */
54 #include "../../HighLevel/StdDescriptors.h"
55
56 #include <string.h>
57
58 /* Enable C linkage for C++ Compilers: */
59 #if defined(__cplusplus)
60 extern "C" {
61 #endif
62
63 /* Preprocessor Checks: */
64 #if !defined(__INCLUDE_FROM_PRINTER_DRIVER)
65 #error Do not include this file directly. Include LUFA/Drivers/USB.h instead.
66 #endif
67
68 /* Macros: */
69 /** \name Virtual Printer Status Line Masks */
70 //@{
71 /** Port status mask for a printer device, indicating that an error has *not* occurred. */
72 #define PRNT_PORTSTATUS_NOTERROR (1 << 3)
73
74 /** Port status mask for a printer device, indicating that the device is currently selected. */
75 #define PRNT_PORTSTATUS_SELECT (1 << 4)
76
77 /** Port status mask for a printer device, indicating that the device is currently out of paper. */
78 #define PRNT_PORTSTATUS_PAPEREMPTY (1 << 5)
79 //@}
80
81 /* Enums: */
82 /** Enum for possible Class, Subclass and Protocol values of device and interface descriptors relating to the Printer
83 * device class.
84 */
85 enum PRNT_Descriptor_ClassSubclassProtocol_t
86 {
87 PRNT_CSCP_PrinterClass = 0x07, /**< Descriptor Class value indicating that the device or interface
88 * belongs to the Printer class.
89 */
90 PRNT_CSCP_PrinterSubclass = 0x01, /**< Descriptor Subclass value indicating that the device or interface
91 * belongs to the Printer subclass.
92 */
93 PRNT_CSCP_BidirectionalProtocol = 0x02, /**< Descriptor Protocol value indicating that the device or interface
94 * belongs to the Bidirectional protocol of the Printer class.
95 */
96 };
97
98 /** Enum for the Printer class specific control requests that can be issued by the USB bus host. */
99 enum PRNT_ClassRequests_t
100 {
101 PRNT_REQ_GetDeviceID = 0x00, /**< Printer class-specific request to retrieve the Unicode ID
102 * string of the device, containing the device's name, manufacturer
103 * and supported printer languages.
104 */
105 PRNT_REQ_GetPortStatus = 0x01, /**< Printer class-specific request to get the current status of the
106 * virtual printer port, for device selection and ready states.
107 */
108 PRNT_REQ_SoftReset = 0x02, /**< Printer class-specific request to reset the device, ready for new
109 * printer commands.
110 */
111 };
112
113 /* Disable C linkage for C++ Compilers: */
114 #if defined(__cplusplus)
115 }
116 #endif
117
118 #endif
119
120 /** @} */
121