Minor documentation enhancements.
[pub/USBasp.git] / Demos / Host / Incomplete / BluetoothHost / Lib / BluetoothACLPackets.h
index f6f8f76..efe9d39 100644 (file)
-/*\r
-             LUFA Library\r
-     Copyright (C) Dean Camera, 2010.\r
-              \r
-  dean [at] fourwalledcubicle [dot] com\r
-      www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
-  Copyright 2010  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
-  Permission to use, copy, modify, distribute, and sell this \r
-  software and its documentation for any purpose is hereby granted\r
-  without fee, provided that the above copyright notice appear in \r
-  all copies and that both that the copyright notice and this\r
-  permission notice and warranty disclaimer appear in supporting \r
-  documentation, and that the name of the author not be used in \r
-  advertising or publicity pertaining to distribution of the \r
-  software without specific, written prior permission.\r
-\r
-  The author disclaim all warranties with regard to this\r
-  software, including all implied warranties of merchantability\r
-  and fitness.  In no event shall the author be liable for any\r
-  special, indirect or consequential damages or any damages\r
-  whatsoever resulting from loss of use, data or profits, whether\r
-  in an action of contract, negligence or other tortious action,\r
-  arising out of or in connection with the use or performance of\r
-  this software.\r
-*/\r
-\r
-#ifndef _BLUETOOTH_ACLPACKETS_\r
-#define _BLUETOOTH_ACLPACKETS_\r
-\r
-       /* Includes: */\r
-               #include <avr/io.h>\r
-               #include <string.h>\r
-               #include <stdbool.h>\r
-\r
-               #include <LUFA/Drivers/USB/USB.h>\r
-               \r
-               #include "BluetoothStack.h"\r
-               \r
-       /* Macros: */\r
-               #define BT_ACL_DEBUG(s, ...)              printf_P(PSTR("(ACL) " s "\r\n"), __VA_ARGS__)\r
-               #define ACL_DEBUG_LEVEL                   2\r
-\r
-               #define BT_CHANNEL_SIGNALING              0x0001\r
-               #define BT_CHANNEL_CONNECTIONLESS         0x0002\r
-               \r
-               #define BT_SIGNAL_CONNECTION_REQUEST      0x02\r
-               #define BT_SIGNAL_CONNECTION_RESPONSE     0x03\r
-               #define BT_SIGNAL_CONFIGURATION_REQUEST   0x04\r
-               #define BT_SIGNAL_CONFIGURATION_RESPONSE  0x05\r
-               #define BT_SIGNAL_DISCONNECTION_REQUEST   0x06\r
-               #define BT_SIGNAL_DISCONNECTION_RESPONSE  0x07\r
-               #define BT_SIGNAL_ECHO_REQUEST            0x08\r
-               #define BT_SIGNAL_ECHO_RESPONSE           0x09\r
-               #define BT_SIGNAL_INFORMATION_REQUEST     0x0A\r
-               #define BT_SIGNAL_INFORMATION_RESPONSE    0x0B\r
-               \r
-               #define BT_INFOREQ_MTU                    0x0001\r
-               #define BT_INFOREQ_EXTENDEDFEATURES       0x0002\r
-               \r
-               #define BT_INFORMATION_SUCCESSFUL         0x0000\r
-               #define BT_INFORMATION_NOTSUPPORTED       0x0001\r
-               \r
-               #define BT_CONNECTION_SUCCESSFUL          0x0000\r
-               #define BT_CONNECTION_REFUSED_RESOURCES   0x0004\r
-               \r
-               #define BT_CONFIGURATION_SUCCESSFUL       0x0000\r
-               #define BT_CONFIGURATION_REJECTED         0x0002\r
-               #define BT_CONFIGURATION_UNKNOWNOPTIONS   0x0003\r
-               \r
-       /* Type Defines: */\r
-               typedef struct\r
-               {\r
-                       uint16_t ConnectionHandle;\r
-                       uint16_t DataLength;\r
-               } Bluetooth_ACL_Header_t;\r
-\r
-               typedef struct\r
-               {\r
-                       uint16_t PayloadLength;\r
-                       uint16_t DestinationChannel;\r
-               } Bluetooth_DataPacket_Header_t;\r
-               \r
-               typedef struct\r
-               {\r
-                       uint8_t  Code;\r
-                       uint8_t  Identifier;\r
-                       uint16_t Length;\r
-               } Bluetooth_SignalCommand_Header_t;\r
-               \r
-               typedef struct\r
-               {\r
-                       uint16_t PSM;\r
-                       uint16_t SourceChannel;\r
-               } Bluetooth_SignalCommand_ConnectionRequest_t;\r
-\r
-               typedef struct\r
-               {\r
-                       uint16_t DestinationChannel;\r
-                       uint16_t SourceChannel;\r
-                       uint16_t Result;\r
-                       uint16_t Status;\r
-               } Bluetooth_SignalCommand_ConnectionResponse_t;\r
-\r
-               typedef struct\r
-               {\r
-                       uint16_t DestinationChannel;\r
-                       uint16_t SourceChannel;\r
-               } Bluetooth_SignalCommand_DisconnectionRequest_t;\r
-               \r
-               typedef struct\r
-               {\r
-                       uint16_t DestinationChannel;\r
-                       uint16_t SourceChannel;\r
-               } Bluetooth_SignalCommand_DisconnectionResponse_t;              \r
-\r
-               typedef struct\r
-               {\r
-                       uint16_t DestinationChannel;\r
-                       uint16_t Flags;\r
-               } Bluetooth_SignalCommand_ConfigurationRequest_t;\r
-\r
-               typedef struct\r
-               {\r
-                       uint16_t SourceChannel;\r
-                       uint16_t Flags;\r
-                       uint16_t Result;\r
-               } Bluetooth_SignalCommand_ConfigurationResponse_t;\r
-\r
-               typedef struct\r
-               {\r
-                       uint16_t InfoType;\r
-               } Bluetooth_SignalCommand_InformationRequest_t;\r
-               \r
-               typedef struct\r
-               {\r
-                       uint16_t InfoType;\r
-                       uint16_t Result;\r
-               } Bluetooth_SignalCommand_InformationResponse_t;\r
-\r
-       /* Function Prototypes: */\r
-               void Bluetooth_ProcessACLPackets(void);\r
-               void Bluetooth_SendPacket(uint8_t* Data, uint16_t DataLen, Bluetooth_Channel_t* Channel);\r
-               \r
-               #if defined(INCLUDE_FROM_BLUETOOTH_ACLPACKETS_C)\r
-                       static inline void Bluetooth_SignalPacket_ConnectionRequest(Bluetooth_ACL_Header_t* ACLPacketHeader,\r
-                                                                  Bluetooth_DataPacket_Header_t* DataHeader,\r
-                                                                  Bluetooth_SignalCommand_Header_t* SignalCommandHeader);\r
-                       static inline void Bluetooth_SignalPacket_EchoRequest(Bluetooth_ACL_Header_t* ACLPacketHeader,\r
-                                                                  Bluetooth_DataPacket_Header_t* DataHeader,\r
-                                                                  Bluetooth_SignalCommand_Header_t* SignalCommandHeader);\r
-                       static inline void Bluetooth_SignalPacket_ConfigurationRequest(Bluetooth_ACL_Header_t* ACLPacketHeader,\r
-                                                                  Bluetooth_DataPacket_Header_t* DataHeader,\r
-                                                                  Bluetooth_SignalCommand_Header_t* SignalCommandHeader);\r
-                       static inline void Bluetooth_SignalPacket_DisconnectionRequest(Bluetooth_ACL_Header_t* ACLPacketHeader,\r
-                                                                  Bluetooth_DataPacket_Header_t* DataHeader,\r
-                                                                  Bluetooth_SignalCommand_Header_t* SignalCommandHeader);\r
-                       static inline void Bluetooth_SignalPacket_InformationRequest(Bluetooth_ACL_Header_t* ACLPacketHeader,\r
-                                                                  Bluetooth_DataPacket_Header_t* DataHeader,\r
-                                                                  Bluetooth_SignalCommand_Header_t* SignalCommandHeader);\r
-               #endif\r
-               \r
-#endif\r
+/*
+             LUFA Library
+     Copyright (C) Dean Camera, 2010.
+              
+  dean [at] fourwalledcubicle [dot] com
+      www.fourwalledcubicle.com
+*/
+
+/*
+  Copyright 2010  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 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.
+*/
+
+/** \file
+ *
+ *  Header file for BluetoothACLPackets.c.
+ */
+
+#ifndef _BLUETOOTH_ACLPACKETS_
+#define _BLUETOOTH_ACLPACKETS_
+
+       /* Includes: */
+               #include <avr/io.h>
+               #include <string.h>
+               #include <stdbool.h>
+               #include <stdio.h>
+
+               #include <LUFA/Drivers/USB/USB.h>
+               #include <LUFA/Drivers/Peripheral/SerialStream.h>
+               
+               #include "BluetoothStack.h"
+               
+       /* Macros: */
+               #define BT_ACL_DEBUG(l, s, ...)           do { if (ACL_DEBUG_LEVEL >= l) printf_P(PSTR("(ACL) " s "\r\n"), ##__VA_ARGS__); } while (0)
+               #define ACL_DEBUG_LEVEL                   0
+       
+               /** Lowest possible channel number for L2CAP data channels. */
+               #define BT_CHANNELNUMBER_BASEOFFSET       0x0040
+
+               /** Bluetooth specification defined channel number for signaling commands. */
+               #define BT_CHANNEL_SIGNALING              0x0001
+
+               /** Bluetooth specification defined channel number for connectionless data. */
+               #define BT_CHANNEL_CONNECTIONLESS         0x0002
+               
+               #define BT_ACL_FIRST_AUTOFLUSH            (1 << 13)
+
+               #define BT_SIGNAL_COMMAND_REJECT          0x01
+               #define BT_SIGNAL_CONNECTION_REQUEST      0x02
+               #define BT_SIGNAL_CONNECTION_RESPONSE     0x03
+               #define BT_SIGNAL_CONFIGURATION_REQUEST   0x04
+               #define BT_SIGNAL_CONFIGURATION_RESPONSE  0x05
+               #define BT_SIGNAL_DISCONNECTION_REQUEST   0x06
+               #define BT_SIGNAL_DISCONNECTION_RESPONSE  0x07
+               #define BT_SIGNAL_ECHO_REQUEST            0x08
+               #define BT_SIGNAL_ECHO_RESPONSE           0x09
+               #define BT_SIGNAL_INFORMATION_REQUEST     0x0A
+               #define BT_SIGNAL_INFORMATION_RESPONSE    0x0B
+               
+               #define BT_INFOREQ_MTU                    0x0001
+               #define BT_INFOREQ_EXTENDEDFEATURES       0x0002
+               
+               #define BT_INFORMATION_SUCCESSFUL         0x0000
+               #define BT_INFORMATION_NOTSUPPORTED       0x0001
+               
+               #define BT_CONNECTION_SUCCESSFUL          0x0000
+               #define BT_CONNECTION_REFUSED_PSM         0x0002
+               #define BT_CONNECTION_REFUSED_RESOURCES   0x0004
+               
+               #define BT_CONFIGURATION_SUCCESSFUL       0x0000
+               #define BT_CONFIGURATION_REJECTED         0x0002
+               #define BT_CONFIGURATION_UNKNOWNOPTIONS   0x0003
+               
+               #define BT_CONFIG_OPTION_MTU              1
+                               
+       /* Type Defines: */
+               /** Bluetooth ACL header structure, common to all ACL data packets. */
+               typedef struct
+               {
+                       uint16_t ConnectionHandle; /**< Unique device connection handle of the ACL packet */
+                       uint16_t DataLength; /**< Length of the packet payload, in bytes */
+               } BT_ACL_Header_t;
+
+               /** Bluetooth ACL data packet header structure, for ACL packets containing L2CAP data. */
+               typedef struct
+               {
+                       uint16_t PayloadLength; /**< Size of the data payload, in bytes */
+                       uint16_t DestinationChannel; /**< Destination channel in the device the data is directed to */
+               } BT_DataPacket_Header_t;
+               
+               /** Bluetooth signaling command header structure, for all ACL packets containing a signaling command. */
+               typedef struct
+               {
+                       uint8_t  Code; /**< Signal code, a BT_SIGNAL_* mask value */
+                       uint8_t  Identifier; /**< Unique signal command identifier to link requests and responses */
+                       uint16_t Length; /**< Length of the signaling command data, in bytes */
+               } BT_Signal_Header_t;
+               
+               /** Connection Request signaling command structure, for channel connection requests. */
+               typedef struct
+               {
+                       uint16_t PSM; /**< Type of data the channel will carry, a CHANNEL_PSM_* mask value */
+                       uint16_t SourceChannel; /**< Channel source on the sending device this channel will link to */
+               } BT_Signal_ConnectionReq_t;
+
+               /** Connection response signaling command structure, for responses to channel connection requests. */
+               typedef struct
+               {
+                       uint16_t DestinationChannel; /**< Destination device channel that the connection request was processed on */
+                       uint16_t SourceChannel; /**< Source device channel address that the connection request came from */
+                       uint16_t Result; /**< Connection result, a BT_CONNECTION_* mask value */
+                       uint16_t Status; /**< Status of the request if the result was set to the Pending value */
+               } BT_Signal_ConnectionResp_t;
+
+               /** Disconnection request signaling command structure, for channel disconnection requests. */
+               typedef struct
+               {
+                       uint16_t DestinationChannel; /**< Destination channel address which is to be disconnected */
+                       uint16_t SourceChannel; /**< Source channel address which is to be disconnected */
+               } BT_Signal_DisconnectionReq_t;
+               
+               /** Disconnection response signaling command structure, for responses to channel disconnection requests. */
+               typedef struct
+               {
+                       uint16_t DestinationChannel; /**< Destination channel address which was disconnected */
+                       uint16_t SourceChannel; /**< Source channel address which was disconnected */
+               } BT_Signal_DisconnectionResp_t;                
+
+               /** Configuration Request signaling command structure, for channel configuration requests. */
+               typedef struct
+               {
+                       uint16_t DestinationChannel; /**< Destination channel address which is to be disconnected */
+                       uint16_t Flags; /**< Configuration flags for the request, including command continuation */
+               } BT_Signal_ConfigurationReq_t;
+
+               /** Configuration Response signaling command structure, for responses to channel configuration requests. */
+               typedef struct
+               {
+                       uint16_t SourceChannel; /**< Source channel that the configuration request was directed at */
+                       uint16_t Flags; /**< Configuration flags for the response, including response continuation */
+                       uint16_t Result; /**< Configuration result, a BT_CONFIGURATION_* mask value */
+               } BT_Signal_ConfigurationResp_t;
+
+               /** Information Request signaling command structure, for device information requests. */
+               typedef struct
+               {
+                       uint16_t InfoType; /**< Data type that is being requested, a BT_INFOREQ_* mask value */
+               } BT_Signal_InformationReq_t;
+               
+               /** Information Response signaling command structure, for responses to information requests. */
+               typedef struct
+               {
+                       uint16_t InfoType; /**< Data type that was requested, a BT_INFOREQ_* mask value */
+                       uint16_t Result; /**< Result of the request, a BT_INFORMATION_* mask value */
+               } BT_Signal_InformationResp_t;
+               
+               /** Configuration Option header structure, placed at the start of each option in a Channel Configuration
+                *  request's options list.
+                */
+               typedef struct
+               {
+                       uint8_t Type; /**< Option type, a BT_CONFIG_OPTION_* mask value */
+                       uint8_t Length; /**< Length of the option's value, in bytes */
+               } BT_Config_Option_Header_t;
+
+       /* Function Prototypes: */
+               void Bluetooth_ACLTask(void);
+               
+               #if defined(INCLUDE_FROM_BLUETOOTH_ACLPACKETS_C)
+                       static void Bluetooth_ProcessIncomingACLPackets(void);
+
+                       static inline void Bluetooth_Signal_ConnectionReq(const BT_Signal_Header_t* const SignalCommandHeader);
+                       static inline void Bluetooth_Signal_ConnectionResp(const BT_Signal_Header_t* const SignalCommandHeader);
+                       static inline void Bluetooth_Signal_ConfigurationReq(const BT_Signal_Header_t* const SignalCommandHeader);
+                       static inline void Bluetooth_Signal_ConfigurationResp(const BT_Signal_Header_t* const SignalCommandHeader);
+                       static inline void Bluetooth_Signal_DisconnectionReq(const BT_Signal_Header_t* const SignalCommandHeader);
+                       static inline void Bluetooth_Signal_DisconnectionResp(const BT_Signal_Header_t* const SignalCommandHeader);
+                       static inline void Bluetooth_Signal_EchoReq(const BT_Signal_Header_t* const SignalCommandHeader);
+                       static inline void Bluetooth_Signal_InformationReq(const BT_Signal_Header_t* const SignalCommandHeader);
+               #endif
+               
+#endif