2012-08-04 12:20:47 +02:00
/* Copyright (C) 2012 Kristian Lauszus, TKJ Electronics. All rights reserved.
2013-03-28 09:46:43 +01:00
2012-08-04 12:20:47 +02:00
This software may be distributed and modified under the terms of the GNU
General Public License version 2 ( GPL2 ) as published by the Free Software
Foundation and appearing in the file GPL2 . TXT included in the packaging of
this file . Please note that GPL2 Section 2 [ b ] requires that all works based
on this software must also be made publicly available under the terms of
the GPL2 ( " Copyleft " ) .
2013-03-28 09:46:43 +01:00
2012-08-04 12:20:47 +02:00
Contact information
- - - - - - - - - - - - - - - - - - -
2013-03-28 09:46:43 +01:00
2012-08-04 12:20:47 +02:00
Kristian Lauszus , TKJ Electronics
Web : http : //www.tkjelectronics.com
e - mail : kristianl @ tkjelectronics . com
*/
# ifndef _btd_h_
# define _btd_h_
# include "Usb.h"
2016-01-16 20:01:11 +01:00
# include "usbhid.h"
2021-04-16 08:44:54 +02:00
# include <EEPROM.h>
2012-08-04 12:20:47 +02:00
//PID and VID of the Sony PS3 devices
2013-08-14 00:43:15 +02:00
# define PS3_VID 0x054C // Sony Corporation
# define PS3_PID 0x0268 // PS3 Controller DualShock 3
# define PS3NAVIGATION_PID 0x042F // Navigation controller
# define PS3MOVE_PID 0x03D5 // Motion controller
2017-12-08 17:34:26 +01:00
// These dongles do not present themselves correctly, so we have to check for them manually
# define IOGEAR_GBU521_VID 0x0A5C
2013-08-14 00:57:11 +02:00
# define IOGEAR_GBU521_PID 0x21E8
2017-12-08 17:34:26 +01:00
# define BELKIN_F8T065BF_VID 0x050D
# define BELKIN_F8T065BF_PID 0x065A
2012-08-04 12:20:47 +02:00
/* Bluetooth dongle data taken from descriptors */
2013-12-13 10:35:27 +01:00
# define BULK_MAXPKTSIZE 64 // Max size for ACL data
2012-08-04 12:20:47 +02:00
// Used in control endpoint header for HCI Commands
# define bmREQ_HCI_OUT USB_SETUP_HOST_TO_DEVICE|USB_SETUP_TYPE_CLASS|USB_SETUP_RECIPIENT_DEVICE
/* Bluetooth HCI states for hci_task() */
2013-11-24 21:55:15 +01:00
# define HCI_INIT_STATE 0
# define HCI_RESET_STATE 1
# define HCI_CLASS_STATE 2
# define HCI_BDADDR_STATE 3
# define HCI_LOCAL_VERSION_STATE 4
2019-07-02 20:30:33 +02:00
# define HCI_WRITE_NAME_STATE 5
2013-11-24 21:55:15 +01:00
# define HCI_CHECK_DEVICE_SERVICE 6
2013-12-11 09:29:38 +01:00
# define HCI_INQUIRY_STATE 7 // These three states are only used if it should pair and connect to a device
2013-11-24 21:55:15 +01:00
# define HCI_CONNECT_DEVICE_STATE 8
# define HCI_CONNECTED_DEVICE_STATE 9
# define HCI_SCANNING_STATE 10
# define HCI_CONNECT_IN_STATE 11
# define HCI_REMOTE_NAME_STATE 12
# define HCI_CONNECTED_STATE 13
# define HCI_DISABLE_SCAN_STATE 14
# define HCI_DONE_STATE 15
# define HCI_DISCONNECT_STATE 16
2019-07-02 20:30:33 +02:00
# define HCI_LOCAL_EXTENDED_FEATURES_STATE 17
# define HCI_WRITE_SIMPLE_PAIRING_STATE 18
2020-11-15 17:29:54 +01:00
# define HCI_SET_EVENT_MASK_STATE 19
2012-08-04 12:20:47 +02:00
/* HCI event flags*/
2014-09-02 10:34:39 +02:00
# define HCI_FLAG_CMD_COMPLETE (1UL << 0)
# define HCI_FLAG_CONNECT_COMPLETE (1UL << 1)
# define HCI_FLAG_DISCONNECT_COMPLETE (1UL << 2)
# define HCI_FLAG_REMOTE_NAME_COMPLETE (1UL << 3)
# define HCI_FLAG_INCOMING_REQUEST (1UL << 4)
# define HCI_FLAG_READ_BDADDR (1UL << 5)
# define HCI_FLAG_READ_VERSION (1UL << 6)
# define HCI_FLAG_DEVICE_FOUND (1UL << 7)
# define HCI_FLAG_CONNECT_EVENT (1UL << 8)
2019-07-02 20:30:33 +02:00
# define HCI_FLAG_LOCAL_EXTENDED_FEATURES (1UL << 9)
2012-08-04 12:20:47 +02:00
2013-12-11 10:37:18 +01:00
/* Macros for HCI event flag tests */
2013-12-13 11:18:30 +01:00
# define hci_check_flag(flag) (hci_event_flag & (flag))
# define hci_set_flag(flag) (hci_event_flag |= (flag))
# define hci_clear_flag(flag) (hci_event_flag &= ~(flag))
2012-08-04 12:20:47 +02:00
/* HCI Events managed */
2012-08-21 14:31:11 +02:00
# define EV_INQUIRY_COMPLETE 0x01
# define EV_INQUIRY_RESULT 0x02
2012-08-04 12:20:47 +02:00
# define EV_CONNECT_COMPLETE 0x03
# define EV_INCOMING_CONNECT 0x04
# define EV_DISCONNECT_COMPLETE 0x05
# define EV_AUTHENTICATION_COMPLETE 0x06
# define EV_REMOTE_NAME_COMPLETE 0x07
# define EV_ENCRYPTION_CHANGE 0x08
# define EV_CHANGE_CONNECTION_LINK 0x09
2020-11-15 17:29:54 +01:00
# define EV_READ_REMOTE_VERSION_INFORMATION_COMPLETE 0x0C
# define EV_QOS_SETUP_COMPLETE 0x0D
# define EV_COMMAND_COMPLETE 0x0E
# define EV_COMMAND_STATUS 0x0F
2012-08-04 12:20:47 +02:00
# define EV_ROLE_CHANGED 0x12
# define EV_NUM_COMPLETE_PKT 0x13
# define EV_PIN_CODE_REQUEST 0x16
# define EV_LINK_KEY_REQUEST 0x17
# define EV_LINK_KEY_NOTIFICATION 0x18
# define EV_DATA_BUFFER_OVERFLOW 0x1A
# define EV_MAX_SLOTS_CHANGE 0x1B
# define EV_LOOPBACK_COMMAND 0x19
# define EV_PAGE_SCAN_REP_MODE 0x20
2019-06-30 20:44:12 +02:00
# define EV_READ_REMOTE_EXTENDED_FEATURES_COMPLETE 0x23
2020-11-15 17:29:54 +01:00
# define EV_IO_CAPABILITY_REQUEST 0x31
# define EV_IO_CAPABILITY_RESPONSE 0x32
2019-06-30 20:44:12 +02:00
# define EV_USER_CONFIRMATION_REQUEST 0x33
2020-11-15 17:29:54 +01:00
# define EV_SIMPLE_PAIRING_COMPLETE 0x36
2012-08-04 12:20:47 +02:00
2013-12-11 09:29:38 +01:00
/* Bluetooth states for the different Bluetooth drivers */
# define L2CAP_WAIT 0
# define L2CAP_DONE 1
/* Used for HID Control channel */
# define L2CAP_CONTROL_CONNECT_REQUEST 2
# define L2CAP_CONTROL_CONFIG_REQUEST 3
# define L2CAP_CONTROL_SUCCESS 4
# define L2CAP_CONTROL_DISCONNECT 5
/* Used for HID Interrupt channel */
# define L2CAP_INTERRUPT_SETUP 6
# define L2CAP_INTERRUPT_CONNECT_REQUEST 7
# define L2CAP_INTERRUPT_CONFIG_REQUEST 8
# define L2CAP_INTERRUPT_DISCONNECT 9
/* Used for SDP channel */
# define L2CAP_SDP_WAIT 10
2013-12-13 10:36:15 +01:00
# define L2CAP_SDP_SUCCESS 11
2013-12-11 09:29:38 +01:00
/* Used for RFCOMM channel */
2013-12-13 10:41:12 +01:00
# define L2CAP_RFCOMM_WAIT 12
# define L2CAP_RFCOMM_SUCCESS 13
2013-12-11 09:29:38 +01:00
2013-12-13 10:41:12 +01:00
# define L2CAP_DISCONNECT_RESPONSE 14 // Used for both SDP and RFCOMM channel
2013-12-13 10:35:27 +01:00
2013-12-11 09:29:38 +01:00
/* Bluetooth states used by some drivers */
2013-12-13 10:36:15 +01:00
# define TURN_ON_LED 17
# define PS3_ENABLE_SIXAXIS 18
# define WII_CHECK_MOTION_PLUS_STATE 19
# define WII_CHECK_EXTENSION_STATE 20
# define WII_INIT_MOTION_PLUS_STATE 21
2013-12-11 09:29:38 +01:00
2013-12-11 10:37:18 +01:00
/* L2CAP event flags for HID Control channel */
2014-09-02 10:34:39 +02:00
# define L2CAP_FLAG_CONNECTION_CONTROL_REQUEST (1UL << 0)
# define L2CAP_FLAG_CONFIG_CONTROL_SUCCESS (1UL << 1)
# define L2CAP_FLAG_CONTROL_CONNECTED (1UL << 2)
# define L2CAP_FLAG_DISCONNECT_CONTROL_RESPONSE (1UL << 3)
2013-12-11 09:29:38 +01:00
2013-12-11 10:37:18 +01:00
/* L2CAP event flags for HID Interrupt channel */
2014-09-02 10:34:39 +02:00
# define L2CAP_FLAG_CONNECTION_INTERRUPT_REQUEST (1UL << 4)
# define L2CAP_FLAG_CONFIG_INTERRUPT_SUCCESS (1UL << 5)
# define L2CAP_FLAG_INTERRUPT_CONNECTED (1UL << 6)
# define L2CAP_FLAG_DISCONNECT_INTERRUPT_RESPONSE (1UL << 7)
2013-12-11 09:29:38 +01:00
2013-12-11 10:37:18 +01:00
/* L2CAP event flags for SDP channel */
2014-09-02 10:34:39 +02:00
# define L2CAP_FLAG_CONNECTION_SDP_REQUEST (1UL << 8)
# define L2CAP_FLAG_CONFIG_SDP_SUCCESS (1UL << 9)
# define L2CAP_FLAG_DISCONNECT_SDP_REQUEST (1UL << 10)
2013-12-11 09:29:38 +01:00
2013-12-11 10:37:18 +01:00
/* L2CAP event flags for RFCOMM channel */
2014-09-02 10:34:39 +02:00
# define L2CAP_FLAG_CONNECTION_RFCOMM_REQUEST (1UL << 11)
# define L2CAP_FLAG_CONFIG_RFCOMM_SUCCESS (1UL << 12)
# define L2CAP_FLAG_DISCONNECT_RFCOMM_REQUEST (1UL << 13)
2013-12-11 09:29:38 +01:00
2014-09-02 10:34:39 +02:00
# define L2CAP_FLAG_DISCONNECT_RESPONSE (1UL << 14)
2013-12-11 09:29:38 +01:00
/* Macros for L2CAP event flag tests */
2013-12-13 11:18:30 +01:00
# define l2cap_check_flag(flag) (l2cap_event_flag & (flag))
# define l2cap_set_flag(flag) (l2cap_event_flag |= (flag))
# define l2cap_clear_flag(flag) (l2cap_event_flag &= ~(flag))
2013-12-11 09:29:38 +01:00
2012-08-04 12:20:47 +02:00
/* L2CAP signaling commands */
# define L2CAP_CMD_COMMAND_REJECT 0x01
# define L2CAP_CMD_CONNECTION_REQUEST 0x02
# define L2CAP_CMD_CONNECTION_RESPONSE 0x03
# define L2CAP_CMD_CONFIG_REQUEST 0x04
# define L2CAP_CMD_CONFIG_RESPONSE 0x05
# define L2CAP_CMD_DISCONNECT_REQUEST 0x06
# define L2CAP_CMD_DISCONNECT_RESPONSE 0x07
# define L2CAP_CMD_INFORMATION_REQUEST 0x0A
# define L2CAP_CMD_INFORMATION_RESPONSE 0x0B
// Used For Connection Response - Remember to Include High Byte
# define PENDING 0x01
# define SUCCESSFUL 0x00
2012-08-21 14:31:11 +02:00
/* Bluetooth L2CAP PSM - see http://www.bluetooth.org/Technical/AssignedNumbers/logical_link.htm */
# define SDP_PSM 0x01 // Service Discovery Protocol PSM Value
# define RFCOMM_PSM 0x03 // RFCOMM PSM Value
# define HID_CTRL_PSM 0x11 // HID_Control PSM Value
# define HID_INTR_PSM 0x13 // HID_Interrupt PSM Value
2019-07-03 00:30:18 +02:00
/* Used for SDP */
# define SDP_SERVICE_SEARCH_REQUEST 0x02
# define SDP_SERVICE_SEARCH_RESPONSE 0x03
# define SDP_SERVICE_ATTRIBUTE_REQUEST 0x04
# define SDP_SERVICE_ATTRIBUTE_RESPONSE 0x05
2019-08-31 18:22:21 +02:00
# define SDP_SERVICE_SEARCH_ATTRIBUTE_REQUEST 0x06 // See the RFCOMM specs
# define SDP_SERVICE_SEARCH_ATTRIBUTE_RESPONSE 0x07 // See the RFCOMM specs
2019-07-03 00:30:18 +02:00
# define PNP_INFORMATION_UUID 0x1200
# define SERIALPORT_UUID 0x1101 // See http://www.bluetooth.org/Technical/AssignedNumbers/service_discovery.htm
# define L2CAP_UUID 0x0100
2012-08-04 12:20:47 +02:00
// Used to determine if it is a Bluetooth dongle
# define WI_SUBCLASS_RF 0x01 // RF Controller
# define WI_PROTOCOL_BT 0x01 // Bluetooth Programming Interface
# define BTD_MAX_ENDPOINTS 4
2014-01-12 16:31:47 +01:00
# define BTD_NUM_SERVICES 4 // Max number of Bluetooth services - if you need more than 4 simply increase this number
2012-08-04 12:20:47 +02:00
2013-11-24 21:55:15 +01:00
# define PAIR 1
2014-09-10 01:32:46 +02:00
class BluetoothService ;
2012-08-04 12:20:47 +02:00
2013-02-05 19:51:45 +01:00
/**
* The Bluetooth Dongle class will take care of all the USB communication
* and then pass the data to the BluetoothService classes .
*/
2012-08-04 12:20:47 +02:00
class BTD : public USBDeviceConfig , public UsbConfigXtracter {
public :
2013-03-28 09:46:43 +01:00
/**
* Constructor for the BTD class .
* @ param p Pointer to USB class instance .
*/
BTD ( USB * p ) ;
/** @name USBDeviceConfig implementation */
2013-10-07 00:47:53 +02:00
/**
2014-01-12 16:31:47 +01:00
* Address assignment and basic initialization is done here .
2013-10-07 00:47:53 +02:00
* @ param parent Hub number .
* @ param port Port number on the hub .
* @ param lowspeed Speed of the device .
* @ return 0 on success .
*/
2014-11-10 07:35:13 +01:00
uint8_t ConfigureDevice ( uint8_t parent , uint8_t port , bool lowspeed ) ;
2013-03-28 09:46:43 +01:00
/**
* Initialize the Bluetooth dongle .
* @ param parent Hub number .
* @ param port Port number on the hub .
* @ param lowspeed Speed of the device .
* @ return 0 on success .
*/
2014-11-10 07:35:13 +01:00
uint8_t Init ( uint8_t parent , uint8_t port , bool lowspeed ) ;
2013-03-28 09:46:43 +01:00
/**
* Release the USB device .
* @ return 0 on success .
*/
2014-11-10 07:35:13 +01:00
uint8_t Release ( ) ;
2013-03-28 09:46:43 +01:00
/**
2014-01-12 16:31:47 +01:00
* Poll the USB Input endpoints and run the state machines .
2013-03-28 09:46:43 +01:00
* @ return 0 on success .
*/
2014-11-10 07:35:13 +01:00
uint8_t Poll ( ) ;
2013-03-28 09:46:43 +01:00
/**
* Get the device address .
* @ return The device address .
*/
virtual uint8_t GetAddress ( ) {
return bAddress ;
} ;
/**
* Used to check if the dongle has been initialized .
* @ return True if it ' s ready .
*/
virtual bool isReady ( ) {
return bPollEnable ;
} ;
2013-12-25 11:09:57 +01:00
2013-07-15 18:20:58 +02:00
/**
* Used by the USB core to check what this driver support .
* @ param klass The device ' s USB class .
* @ return Returns true if the device ' s USB class matches this driver .
*/
2015-02-19 09:14:39 +01:00
virtual bool DEVCLASSOK ( uint8_t klass ) {
2013-12-25 11:09:57 +01:00
return ( klass = = USB_CLASS_WIRELESS_CTRL ) ;
2013-12-30 16:05:50 +01:00
} ;
2013-07-15 18:20:58 +02:00
/**
* Used by the USB core to check what this driver support .
* Used to set the Bluetooth address into the PS3 controllers .
* @ param vid The device ' s VID .
* @ param pid The device ' s PID .
* @ return Returns true if the device ' s VID and PID matches this driver .
*/
2015-02-19 09:14:39 +01:00
virtual bool VIDPIDOK ( uint16_t vid , uint16_t pid ) {
2017-12-08 17:34:26 +01:00
if ( ( vid = = IOGEAR_GBU521_VID & & pid = = IOGEAR_GBU521_PID ) | | ( vid = = BELKIN_F8T065BF_VID & & pid = = BELKIN_F8T065BF_PID ) )
2013-11-24 15:23:41 +01:00
return true ;
2013-12-25 11:09:57 +01:00
if ( my_bdaddr [ 0 ] ! = 0x00 | | my_bdaddr [ 1 ] ! = 0x00 | | my_bdaddr [ 2 ] ! = 0x00 | | my_bdaddr [ 3 ] ! = 0x00 | | my_bdaddr [ 4 ] ! = 0x00 | | my_bdaddr [ 5 ] ! = 0x00 ) { // Check if Bluetooth address is set
if ( vid = = PS3_VID & & ( pid = = PS3_PID | | pid = = PS3NAVIGATION_PID | | pid = = PS3MOVE_PID ) )
2013-11-24 15:23:41 +01:00
return true ;
}
return false ;
2013-07-15 18:20:58 +02:00
} ;
2013-03-28 09:46:43 +01:00
/**@}*/
/** @name UsbConfigXtracter implementation */
/**
* UsbConfigXtracter implementation , used to extract endpoint information .
* @ param conf Configuration value .
* @ param iface Interface number .
* @ param alt Alternate setting .
* @ param proto Interface Protocol .
* @ param ep Endpoint Descriptor .
*/
2014-11-10 07:35:13 +01:00
void EndpointXtract ( uint8_t conf , uint8_t iface , uint8_t alt , uint8_t proto , const USB_ENDPOINT_DESCRIPTOR * ep ) ;
2013-03-28 09:46:43 +01:00
/**@}*/
/** Disconnects both the L2CAP Channel and the HCI Connection for all Bluetooth services. */
2014-09-10 01:32:46 +02:00
void disconnect ( ) ;
2013-03-28 09:46:43 +01:00
/**
2014-01-12 16:31:47 +01:00
* Register Bluetooth dongle members / services .
2013-03-28 09:46:43 +01:00
* @ param pService Pointer to BluetoothService class instance .
2014-01-12 16:31:47 +01:00
* @ return The service ID on success or - 1 on fail .
2013-03-28 09:46:43 +01:00
*/
2014-09-10 01:32:46 +02:00
int8_t registerBluetoothService ( BluetoothService * pService ) {
2014-01-12 16:31:47 +01:00
for ( uint8_t i = 0 ; i < BTD_NUM_SERVICES ; i + + ) {
2013-03-28 09:46:43 +01:00
if ( ! btService [ i ] ) {
btService [ i ] = pService ;
return i ; // Return ID
}
}
2014-09-10 01:32:46 +02:00
return - 1 ; // Error registering BluetoothService
2013-03-28 09:46:43 +01:00
} ;
/** @name HCI Commands */
/**
* Used to send a HCI Command .
* @ param data Data to send .
* @ param nbytes Number of bytes to send .
*/
void HCI_Command ( uint8_t * data , uint16_t nbytes ) ;
/** Reset the Bluetooth dongle. */
void hci_reset ( ) ;
/** Read the Bluetooth address of the dongle. */
void hci_read_bdaddr ( ) ;
/** Read the HCI Version of the Bluetooth dongle. */
void hci_read_local_version_information ( ) ;
2020-11-15 17:29:54 +01:00
/** Used to check if the dongle supports simple paring */
2019-06-30 20:44:12 +02:00
void hci_read_local_extended_features ( uint8_t page_number ) ;
2013-03-28 09:46:43 +01:00
/**
* Set the local name of the Bluetooth dongle .
* @ param name Desired name .
*/
2019-07-02 20:30:33 +02:00
void hci_write_local_name ( const char * name ) ;
2020-11-15 17:29:54 +01:00
/** Used to enable simply paring if the dongle supports it */
2019-07-02 20:30:33 +02:00
void hci_write_simple_pairing_mode ( bool enable ) ;
2020-11-15 17:29:54 +01:00
/** Used to enable events related to simple paring */
void hci_set_event_mask ( ) ;
2013-03-28 09:46:43 +01:00
/** Enable visibility to other Bluetooth devices. */
void hci_write_scan_enable ( ) ;
/** Disable visibility to other Bluetooth devices. */
void hci_write_scan_disable ( ) ;
/** Read the remote devices name. */
void hci_remote_name ( ) ;
/** Accept the connection with the Bluetooth device. */
void hci_accept_connection ( ) ;
/**
* Disconnect the HCI connection .
* @ param handle The HCI Handle for the connection .
*/
void hci_disconnect ( uint16_t handle ) ;
/**
* Respond with the pin for the connection .
* The pin is automatically set for the Wii library ,
* but can be customized for the SPP library .
*/
void hci_pin_code_request_reply ( ) ;
/** Respons when no pin was set. */
void hci_pin_code_negative_request_reply ( ) ;
2021-04-16 08:44:54 +02:00
/** Used when we have already been paired, we will use the key in eeprom */
void hci_link_key_request_reply ( ) ;
2013-03-28 09:46:43 +01:00
/**
* Command is used to reply to a Link Key Request event from the BR / EDR Controller
* if the Host does not have a stored Link Key for the connection .
*/
void hci_link_key_request_negative_reply ( ) ;
2020-11-15 17:29:54 +01:00
/** Used to during simple paring to confirm that the we want to connect */
2019-06-30 20:44:12 +02:00
void hci_user_confirmation_request_reply ( ) ;
2013-03-28 09:46:43 +01:00
/** Used to try to authenticate with the remote device. */
void hci_authentication_request ( ) ;
/** Start a HCI inquiry. */
void hci_inquiry ( ) ;
/** Cancel a HCI inquiry. */
void hci_inquiry_cancel ( ) ;
2013-11-24 15:31:12 +01:00
/** Connect to last device communicated with. */
2013-03-28 09:46:43 +01:00
void hci_connect ( ) ;
2020-11-15 17:29:54 +01:00
/** Used during simple paring to reply to a IO capability request */
void hci_io_capability_request_reply ( ) ;
2013-11-24 15:31:12 +01:00
/**
* Connect to device .
* @ param bdaddr Bluetooth address of the device .
*/
void hci_connect ( uint8_t * bdaddr ) ;
2013-03-28 09:46:43 +01:00
/** Used to a set the class of the device. */
void hci_write_class_of_device ( ) ;
/**@}*/
/** @name L2CAP Commands */
/**
* Used to send L2CAP Commands .
* @ param handle HCI Handle .
* @ param data Data to send .
* @ param nbytes Number of bytes to send .
* @ param channelLow , channelHigh Low and high byte of channel to send to .
* If argument is omitted then the Standard L2CAP header : Channel ID ( 0x01 ) for ACL - U will be used .
*/
void L2CAP_Command ( uint16_t handle , uint8_t * data , uint8_t nbytes , uint8_t channelLow = 0x01 , uint8_t channelHigh = 0x00 ) ;
/**
* L2CAP Connection Request .
* @ param handle HCI handle .
* @ param rxid Identifier .
* @ param scid Source Channel Identifier .
* @ param psm Protocol / Service Multiplexer - see : https : //www.bluetooth.org/Technical/AssignedNumbers/logical_link.htm.
*/
void l2cap_connection_request ( uint16_t handle , uint8_t rxid , uint8_t * scid , uint16_t psm ) ;
/**
* L2CAP Connection Response .
* @ param handle HCI handle .
* @ param rxid Identifier .
* @ param dcid Destination Channel Identifier .
* @ param scid Source Channel Identifier .
* @ param result Result - First send : : PENDING and then : : SUCCESSFUL .
*/
void l2cap_connection_response ( uint16_t handle , uint8_t rxid , uint8_t * dcid , uint8_t * scid , uint8_t result ) ;
/**
* L2CAP Config Request .
* @ param handle HCI Handle .
* @ param rxid Identifier .
* @ param dcid Destination Channel Identifier .
*/
void l2cap_config_request ( uint16_t handle , uint8_t rxid , uint8_t * dcid ) ;
/**
* L2CAP Config Response .
* @ param handle HCI Handle .
* @ param rxid Identifier .
* @ param scid Source Channel Identifier .
*/
void l2cap_config_response ( uint16_t handle , uint8_t rxid , uint8_t * scid ) ;
/**
* L2CAP Disconnection Request .
* @ param handle HCI Handle .
* @ param rxid Identifier .
* @ param dcid Device Channel Identifier .
* @ param scid Source Channel Identifier .
*/
void l2cap_disconnection_request ( uint16_t handle , uint8_t rxid , uint8_t * dcid , uint8_t * scid ) ;
/**
* L2CAP Disconnection Response .
* @ param handle HCI Handle .
* @ param rxid Identifier .
* @ param dcid Device Channel Identifier .
* @ param scid Source Channel Identifier .
*/
void l2cap_disconnection_response ( uint16_t handle , uint8_t rxid , uint8_t * dcid , uint8_t * scid ) ;
/**
* L2CAP Information Response .
* @ param handle HCI Handle .
* @ param rxid Identifier .
* @ param infoTypeLow , infoTypeHigh Infotype .
*/
void l2cap_information_response ( uint16_t handle , uint8_t rxid , uint8_t infoTypeLow , uint8_t infoTypeHigh ) ;
/**@}*/
/** Use this to see if it is waiting for a incoming connection. */
2017-02-07 15:27:00 +01:00
bool waitingForConnection ;
2013-03-28 09:46:43 +01:00
/** This is used by the service to know when to store the device information. */
bool l2capConnectionClaimed ;
/** This is used by the SPP library to claim the current SDP incoming request. */
bool sdpConnectionClaimed ;
/** This is used by the SPP library to claim the current RFCOMM incoming request. */
bool rfcommConnectionClaimed ;
/** The name you wish to make the dongle show up as. It is set automatically by the SPP library. */
const char * btdName ;
2013-12-11 10:37:18 +01:00
/** The pin you wish to make the dongle use for authentication. It is set automatically by the SPP and BTHID library. */
2013-03-28 09:46:43 +01:00
const char * btdPin ;
/** The bluetooth dongles Bluetooth address. */
uint8_t my_bdaddr [ 6 ] ;
/** HCI handle for the last connection. */
uint16_t hci_handle ;
/** Last incoming devices Bluetooth address. */
uint8_t disc_bdaddr [ 6 ] ;
/** First 30 chars of last remote name. */
2014-01-16 18:56:42 +01:00
char remote_name [ 30 ] ;
2021-04-16 08:44:54 +02:00
/** Link key **/
uint8_t link_key [ 16 ] ;
/** Stored Bluetooth address. */
uint8_t stored_bdaddr [ 6 ] ;
2013-03-28 09:46:43 +01:00
/**
* The supported HCI Version read from the Bluetooth dongle .
* Used by the PS3BT library to check the HCI Version of the Bluetooth dongle ,
* it should be at least 3 to work properly with the library .
*/
uint8_t hci_version ;
/** Call this function to pair with a Wiimote */
void pairWithWiimote ( ) {
pairWithWii = true ;
2013-11-24 21:55:15 +01:00
hci_state = HCI_CHECK_DEVICE_SERVICE ;
2013-03-28 09:46:43 +01:00
} ;
2014-01-12 16:31:47 +01:00
/** Used to only send the ACL data to the Wiimote. */
2013-03-28 09:46:43 +01:00
bool connectToWii ;
/** True if a Wiimote is connecting. */
bool incomingWii ;
2013-11-24 21:55:15 +01:00
/** True when it should pair with a Wiimote. */
2013-03-28 09:46:43 +01:00
bool pairWithWii ;
/** True if it's the new Wiimote with the Motion Plus Inside or a Wii U Pro Controller. */
bool motionPlusInside ;
/** True if it's a Wii U Pro Controller. */
bool wiiUProController ;
2021-04-16 08:44:54 +02:00
/** True if an Xbox One S Controller is Connecting. */
bool incomingXboxOneS ;
2017-02-07 15:27:00 +01:00
/** Call this function to pair with a HID device */
2013-11-24 21:55:15 +01:00
void pairWithHID ( ) {
2017-02-07 15:27:00 +01:00
waitingForConnection = false ;
2013-11-24 21:55:15 +01:00
pairWithHIDDevice = true ;
hci_state = HCI_CHECK_DEVICE_SERVICE ;
} ;
2017-02-07 15:27:00 +01:00
/** Used to only send the ACL data to the HID device. */
2013-11-24 21:55:15 +01:00
bool connectToHIDDevice ;
2017-02-07 15:27:00 +01:00
/** True if a HID device is connecting. */
2013-11-24 21:55:15 +01:00
bool incomingHIDDevice ;
/** True when it should pair with a device like a mouse or keyboard. */
bool pairWithHIDDevice ;
2021-04-16 08:44:54 +02:00
/** True when the device is paired. */
bool pairedDevice ;
2013-11-24 21:55:15 +01:00
2013-03-28 09:46:43 +01:00
/**
* Read the poll interval taken from the endpoint descriptors .
* @ return The poll interval in ms .
*/
uint8_t readPollInterval ( ) {
return pollInterval ;
} ;
2020-11-15 19:02:54 +01:00
/** Used by the drivers to enable simple pairing */
bool useSimplePairing ;
2012-08-04 12:20:47 +02:00
protected :
2013-03-28 09:46:43 +01:00
/** Pointer to USB class instance. */
USB * pUsb ;
/** Device address. */
uint8_t bAddress ;
/** Endpoint info structure. */
EpInfo epInfo [ BTD_MAX_ENDPOINTS ] ;
/** Configuration number. */
uint8_t bConfNum ;
/** Total number of endpoints in the configuration. */
uint8_t bNumEP ;
/** Next poll time based on poll interval taken from the USB descriptor. */
uint32_t qNextPollTime ;
/** Bluetooth dongle control endpoint. */
static const uint8_t BTD_CONTROL_PIPE ;
/** HCI event endpoint index. */
static const uint8_t BTD_EVENT_PIPE ;
/** ACL In endpoint index. */
static const uint8_t BTD_DATAIN_PIPE ;
/** ACL Out endpoint index. */
static const uint8_t BTD_DATAOUT_PIPE ;
/**
* Used to print the USB Endpoint Descriptor .
* @ param ep_ptr Pointer to USB Endpoint Descriptor .
*/
void PrintEndpointDescriptor ( const USB_ENDPOINT_DESCRIPTOR * ep_ptr ) ;
2012-08-04 12:20:47 +02:00
private :
2013-12-01 16:02:23 +01:00
void Initialize ( ) ; // Set all variables, endpoint structs etc. to default values
2014-01-12 16:31:47 +01:00
BluetoothService * btService [ BTD_NUM_SERVICES ] ;
2013-03-28 09:46:43 +01:00
2013-10-07 01:45:21 +02:00
uint16_t PID , VID ; // PID and VID of device connected
2013-03-28 09:46:43 +01:00
uint8_t pollInterval ;
2019-07-03 00:30:18 +02:00
bool simple_pairing_supported ;
2013-12-05 00:40:23 +01:00
bool bPollEnable ;
2013-03-28 09:46:43 +01:00
2016-04-19 11:48:51 +02:00
bool pairWiiUsingSync ; // True if pairing was done using the Wii SYNC button.
2015-04-16 01:57:00 +02:00
bool checkRemoteName ; // Used to check remote device's name before connecting.
2021-01-17 23:34:31 +01:00
bool incomingPSController ; // True if a PS4/PS5 controller is connecting
2014-01-10 17:44:51 +01:00
uint8_t classOfDevice [ 3 ] ; // Class of device of last device
2013-03-28 09:46:43 +01:00
/* Variables used by high level HCI task */
2014-01-12 16:31:47 +01:00
uint8_t hci_state ; // Current state of Bluetooth HCI connection
uint16_t hci_counter ; // Counter used for Bluetooth HCI reset loops
uint16_t hci_num_reset_loops ; // This value indicate how many times it should read before trying to reset
uint16_t hci_event_flag ; // HCI flags of received Bluetooth events
2013-03-28 09:46:43 +01:00
uint8_t inquiry_counter ;
2014-01-12 16:31:47 +01:00
uint8_t hcibuf [ BULK_MAXPKTSIZE ] ; // General purpose buffer for HCI data
uint8_t l2capinbuf [ BULK_MAXPKTSIZE ] ; // General purpose buffer for L2CAP in data
uint8_t l2capoutbuf [ 14 ] ; // General purpose buffer for L2CAP out data
2013-03-28 09:46:43 +01:00
/* State machines */
void HCI_event_task ( ) ; // Poll the HCI event pipe
void HCI_task ( ) ; // HCI state machine
void ACL_event_task ( ) ; // ACL input pipe
/* Used to set the Bluetooth Address internally to the PS3 Controllers */
void setBdaddr ( uint8_t * BDADDR ) ;
void setMoveBdaddr ( uint8_t * BDADDR ) ;
2012-08-04 12:20:47 +02:00
} ;
2014-09-10 01:32:46 +02:00
/** All Bluetooth services should inherit this class. */
class BluetoothService {
public :
BluetoothService ( BTD * p ) : pBtd ( p ) {
if ( pBtd )
pBtd - > registerBluetoothService ( this ) ; // Register it as a Bluetooth service
} ;
/**
* Used to pass acldata to the Bluetooth service .
* @ param ACLData Pointer to the incoming acldata .
*/
virtual void ACLData ( uint8_t * ACLData ) = 0 ;
/** Used to run the different state machines in the Bluetooth service. */
virtual void Run ( ) = 0 ;
/** Used to reset the Bluetooth service. */
virtual void Reset ( ) = 0 ;
/** Used to disconnect both the L2CAP Channel and the HCI Connection for the Bluetooth service. */
virtual void disconnect ( ) = 0 ;
/**
* Used to call your own function when the device is successfully initialized .
* @ param funcOnInit Function to call .
*/
void attachOnInit ( void ( * funcOnInit ) ( void ) ) {
pFuncOnInit = funcOnInit ; // TODO: This really belong in a class of it's own as it is repeated several times
} ;
protected :
/**
* Called when a device is successfully initialized .
* Use attachOnInit ( void ( * funcOnInit ) ( void ) ) to call your own function .
* This is useful for instance if you want to set the LEDs in a specific way .
*/
virtual void onInit ( ) = 0 ;
2014-09-10 01:38:42 +02:00
/** Used to check if the incoming L2CAP data matches the HCI Handle */
bool checkHciHandle ( uint8_t * buf , uint16_t handle ) {
return ( buf [ 0 ] = = ( handle & 0xFF ) ) & & ( buf [ 1 ] = = ( ( handle > > 8 ) | 0x20 ) ) ;
}
2014-09-10 01:32:46 +02:00
/** Pointer to function called in onInit(). */
void ( * pFuncOnInit ) ( void ) ;
/** Pointer to BTD instance. */
BTD * pBtd ;
/** The HCI Handle for the connection. */
uint16_t hci_handle ;
/** L2CAP flags of received Bluetooth events. */
uint32_t l2cap_event_flag ;
/** Identifier for L2CAP commands. */
uint8_t identifier ;
} ;
2012-08-04 12:20:47 +02:00
# endif