Minor documentation enhancements.
[pub/USBasp.git] / Demos / Host / Incomplete / BluetoothHost / Lib / BluetoothStack.h
index fb25ec7..e434e6c 100644 (file)
        /* Includes: */
                #include <LUFA/Drivers/USB/USB.h>
                
+               #include "../ConfigDescriptor.h"
+               
        /* Macros: */
-               #define BLUETOOTH_DATA_IN_PIPE         1
-               #define BLUETOOTH_DATA_OUT_PIPE        2
-               #define BLUETOOTH_EVENTS_PIPE          3
-
                #define BLUETOOTH_MAX_OPEN_CHANNELS    6
                
                #define CHANNEL_PSM_SDP                0x0001
                #define MAXIMUM_CHANNEL_MTU            255
                
        /* Enums: */
-               /** Enum for the possible states for a bluetooth ACL channel. */
+               /** Enum for the possible states for a Bluetooth ACL channel. */
                enum BT_ChannelStates_t
                {
-                       Channel_Closed                = 0, /**< Channel is closed and inactive. No data may be sent or received. */
-                       Channel_WaitConnect           = 1, /**< A connection request has been received, but a response has not been sent. */
-                       Channel_WaitConnectRsp        = 2, /**< A connection request has been sent, but a response has not been received. */
-                       Channel_Config_WaitConfig     = 3, /**< Channel has been connected, but not yet configured on either end. */
-                       Channel_Config_WaitSendConfig = 4, /**< Channel configuration has been received and accepted, but not yet sent. */
-                       Channel_Config_WaitReqResp    = 5, /**< Channel configuration has been sent but not responded to, and a configuration
-                                                               request from the remote end has not yet been received. */
-                       Channel_Config_WaitResp       = 6, /**< Channel configuration has been sent but not accepted, but a configuration request
-                                                               from the remote end has been accepted. */
-                       Channel_Config_WaitReq        = 7, /**< Channel configuration has been sent and accepted, but a configuration request
-                                                               from the remote end has not yet been accepted. */
-                       Channel_Open                  = 8, /**< Channel is open and ready to send or receive data */
-                       Channel_WaitDisconnect        = 9, /**< A disconnection request has been sent, but not yet acknowledged. */
+                       BT_Channel_Closed                = 0, /**< Channel is closed and inactive. No data may be sent or received. */
+                       BT_Channel_WaitConnect           = 1, /**< A connection request has been received, but a response has not been sent. */
+                       BT_Channel_WaitConnectRsp        = 2, /**< A connection request has been sent, but a response has not been received. */
+                       BT_Channel_Config_WaitConfig     = 3, /**< Channel has been connected, but not yet configured on either end. */
+                       BT_Channel_Config_WaitSendConfig = 4, /**< Channel configuration has been received and accepted, but not yet sent. */
+                       BT_Channel_Config_WaitReqResp    = 5, /**< Channel configuration has been sent but not responded to, and a configuration
+                                                              *   request from the remote end has not yet been received.
+                                                              */
+                       BT_Channel_Config_WaitResp       = 6, /**< Channel configuration has been sent but not accepted, but a configuration request
+                                                              *   from the remote end has been accepted.
+                                                              */
+                       BT_Channel_Config_WaitReq        = 7, /**< Channel configuration has been sent and accepted, but a configuration request
+                                                              *   from the remote end has not yet been accepted.
+                                                              */
+                       BT_Channel_Open                  = 8, /**< Channel is open and ready to send or receive data */
+                       BT_Channel_WaitDisconnect        = 9, /**< A disconnection request has been sent, but not yet acknowledged. */
                };
 
                /** Enum for the possible error codes returned by the \ref Bluetooth_SendPacket() function. */
                enum BT_SendPacket_ErrorCodes_t
                {
-                       BT_SENDPACKET_NoError            = 0, /**< The packet was sent sucessfully. */
-                       BT_SENDPACKET_NotConnected       = 1, /**< The bluetooth stack is not currently connected to a remote device. */
+                       BT_SENDPACKET_NoError            = 0, /**< The packet was sent successfully. */
+                       BT_SENDPACKET_NotConnected       = 1, /**< The Bluetooth stack is not currently connected to a remote device. */
                        BT_SENDPACKET_ChannelNotOpen     = 2, /**< The given channel is not currently in the Open state. */
                };
 
        /* Type Defines: */
-               /** Type define for a Bluetooth ACL channel information structure. This structure contains all the relevent
+               /** Type define for a Bluetooth ACL channel information structure. This structure contains all the relevant
                 *  information on an ACL channel for data transmission and reception by the stack.
                 */
                typedef struct
                        uint16_t            ConnectionHandle; /**< Connection handle to the remote device, used internally in the stack. */
                        uint8_t             RemoteAddress[6]; /**< Bluetooth device address of the attached remote device. */
                        Bluetooth_Channel_t Channels[BLUETOOTH_MAX_OPEN_CHANNELS]; /**< Channel information structures for the connection. */
-                       uint8_t             SignallingIdentifier; /**< Next Signalling Channel unique command sequence identifier. */
+                       uint8_t             SignalingIdentifier; /**< Next Signaling Channel unique command sequence identifier. */
                } Bluetooth_Connection_t;
                
                /** Local Bluetooth device information structure, for the defining of local device characteristics for the Bluetooth stack. */
                {
                        uint32_t Class; /**< Class of the local device, a mask of DEVICE_CLASS_* masks. */
                        char     PINCode[16]; /**< Pin code required to send or receive in order to authenticate with a remote device. */
-                       char     Name[]; /**< Name of the local bluetooth device, up to 248 characters. */
+                       char     Name[]; /**< Name of the local Bluetooth device, up to 248 characters. */
                } Bluetooth_Device_t;
                
                /** Bluetooth stack state information structure, for the containment of the Bluetooth stack state. The values in
                        bool    IsInitialized; /**< Indicates if the Bluetooth stack is currently initialized and ready for connections
                                                *   to or from a remote Bluetooth device.
                                                */
-                       uint8_t LocalBDADDR[6]; /**< Local bluetooth adapter's BDADDR, valid when the stack is fully initialized. */
+                       uint8_t LocalBDADDR[6]; /**< Local Bluetooth adapter's BDADDR, valid when the stack is fully initialized. */
                } Bluetooth_Stack_State_t;
        
        /* Includes: */
                void                 Bluetooth_ConnectionComplete(void);
                void                 Bluetooth_DisconnectionComplete(void);
                bool                 Bluetooth_ChannelConnectionRequest(const uint16_t PSM);
-               void                 Bluetooth_PacketReceived(void* Data, uint16_t DataLen, Bluetooth_Channel_t* const Channel);
-               Bluetooth_Channel_t* Bluetooth_GetChannelData(const uint16_t SearchValue, const uint8_t SearchKey);
+               void                 Bluetooth_PacketReceived(void* Data, uint16_t DataLen,
+                                                             Bluetooth_Channel_t* const ACLChannel);
+               void                 Bluetooth_ChannelOpened(Bluetooth_Channel_t* const ACLChannel);
+
+               Bluetooth_Channel_t* Bluetooth_GetChannelData(const uint16_t SearchValue,
+                                                             const uint8_t SearchKey);
                Bluetooth_Channel_t* Bluetooth_OpenChannel(const uint16_t PSM);
-               void                 Bluetooth_CloseChannel(Bluetooth_Channel_t* const Channel);
-               uint8_t              Bluetooth_SendPacket(void* Data, uint16_t DataLen, Bluetooth_Channel_t* const Channel);
+               void                 Bluetooth_CloseChannel(Bluetooth_Channel_t* const ACLChannel);
+               uint8_t              Bluetooth_SendPacket(void* Data,
+                                                         uint16_t DataLen,
+                                                         Bluetooth_Channel_t* const ACLChannel);
 
        /* External Variables: */
                extern Bluetooth_Device_t      Bluetooth_DeviceConfiguration;