/******************************************************************************
*
* Copyright (C) 2009-2012 Broadcom Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
******************************************************************************/
// This module manages the serial port over which HCI commands
// and data are sent/received.
#pragma once
#include <stdbool.h>
#include <stdint.h>
typedef enum {
USERIAL_PORT_1,
USERIAL_PORT_2,
USERIAL_PORT_3,
USERIAL_PORT_4,
USERIAL_PORT_5,
USERIAL_PORT_6,
USERIAL_PORT_7,
USERIAL_PORT_8,
USERIAL_PORT_9,
USERIAL_PORT_10,
USERIAL_PORT_11,
USERIAL_PORT_12,
USERIAL_PORT_13,
USERIAL_PORT_14,
USERIAL_PORT_15,
USERIAL_PORT_16,
USERIAL_PORT_17,
USERIAL_PORT_18,
} userial_port_t;
// Initializes the userial module. This function should only ever be called once.
// It returns true if the module could be initialized, false if there was an error.
bool userial_init(void);
// Opens the given serial port. Returns true if successful, false otherwise.
// Once this function is called, the userial module will begin producing
// buffers from data read off the serial port. If you wish to pause the
// production of buffers, call |userial_pause_reading|. You can then resume
// by calling |userial_resume_reading|. This function returns true if the
// serial port was successfully opened and buffer production has started. It
// returns false if there was an error.
bool userial_open(userial_port_t port);
void userial_close(void);
void userial_close_reader(void);
// Reads a maximum of |len| bytes from the serial port into |p_buffer|.
// This function returns the number of bytes actually read, which may be
// less than |len|. This function will not block.
uint16_t userial_read(uint16_t msg_id, uint8_t *p_buffer, uint16_t len);
// Writes a maximum of |len| bytes from |p_data| to the serial port.
// This function returns the number of bytes actually written, which may be
// less than |len|. This function may block.
uint16_t userial_write(uint16_t msg_id, const uint8_t *p_data, uint16_t len);