+\r
+/** RFCOMM layer callback for event for when a RFCOMM logical channel has been fully opened and configured between\r
+ * the local and remote device. Once open, this RFCOMM channel can be read from and written to freely until is it\r
+ * closed by either end.\r
+ *\r
+ * \param[in] RFCOMMChannel RFCOMM channel that was opened\r
+ */ \r
+void RFCOMM_ChannelOpened(RFCOMM_Channel_t* const RFCOMMChannel)\r
+{\r
+ /* Save the serial port RFCOMM logical channel for later use */\r
+ SerialChannel_RFCOMM = RFCOMMChannel;\r
+}\r
+\r
+/** RFCOMM layer callback event for when a packet is received on an open RFCOMM channel.\r
+ *\r
+ * \param[in] ACLChannel RFCOMM ACL channel that the data was directed to\r
+ * \param[in] DataLen Length of the received data, in bytes\r
+ * \param[in] Data Pointer to a buffer where the received data is stored\r
+ */\r
+void RFCOMM_DataReceived(RFCOMM_Channel_t* const ACLChannel, uint16_t DataLen, const uint8_t* Data)\r
+{\r
+ /* Write the received bytes to the serial port */\r
+ for (uint8_t i = 0; i < DataLen; i++)\r
+ putchar(Data[i]);\r
+ \r
+ /* Echo the data back to the sending device */\r
+ RFCOMM_SendData(DataLen, Data, SerialChannel_RFCOMM, SerialChannel_ACL);\r
+}\r
+\r
+/** RFCOMM layer callback event for when the remote device has updated the channel terminal control signals\r
+ * for a particular RFCOMM channel.\r
+ *\r
+ * \param[in] RFCOMMChannel RFCOMM logical channel whose signals were altered\r
+ */ \r
+void RFCOMM_ChannelSignalsReceived(RFCOMM_Channel_t* const RFCOMMChannel)\r
+{\r
+ // Currently do nothing in response to the remote device sending new terminal control signals\r
+}\r