普通文本  |  130行  |  3.63 KB

/******************************************************************************
 *
 *  Copyright (C) 2009-2013 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.
 *
 ******************************************************************************/

#include <string.h>
#include "bt_target.h"
#include "bt_utils.h"
#include "gap_int.h"

/*******************************************************************************
 *
 * Function         gap_allocate_cb
 *
 * Description      Look through the GAP Control Blocks for a free one.
 *
 * Returns          Pointer to the control block or NULL if not found
 *
 ******************************************************************************/
tGAP_INFO* gap_allocate_cb(void) {
  tGAP_INFO* p_cb = &gap_cb.blk[0];
  uint8_t x;

  for (x = 0; x < GAP_MAX_BLOCKS; x++, p_cb++) {
    if (!p_cb->in_use) {
      memset(p_cb, 0, sizeof(tGAP_INFO));

      p_cb->in_use = true;
      p_cb->index = x;
      p_cb->p_data = (void*)NULL;
      return (p_cb);
    }
  }

  /* If here, no free control blocks found */
  return (NULL);
}

/*******************************************************************************
 *
 * Function         gap_free_cb
 *
 * Description      Release GAP control block.
 *
 * Returns          Pointer to the control block or NULL if not found
 *
 ******************************************************************************/
void gap_free_cb(tGAP_INFO* p_cb) {
  if (p_cb) {
    p_cb->gap_cback = NULL;
    p_cb->in_use = false;
  }
}

/*******************************************************************************
 *
 * Function         gap_is_service_busy
 *
 * Description      Look through the GAP Control Blocks that are in use
 *                  and check to see if the event waiting for is the command
 *                  requested.
 *
 * Returns          true if already in use
 *                  false if not busy
 *
 ******************************************************************************/
bool gap_is_service_busy(uint16_t request) {
  tGAP_INFO* p_cb = &gap_cb.blk[0];
  uint8_t x;

  for (x = 0; x < GAP_MAX_BLOCKS; x++, p_cb++) {
    if (p_cb->in_use && p_cb->event == request) return (true);
  }

  /* If here, service is not busy */
  return (false);
}

/*******************************************************************************
 *
 * Function         gap_convert_btm_status
 *
 * Description      Converts a BTM error status into a GAP error status
 *
 *
 * Returns          GAP_UNKNOWN_BTM_STATUS is returned if not recognized
 *
 ******************************************************************************/
uint16_t gap_convert_btm_status(tBTM_STATUS btm_status) {
  switch (btm_status) {
    case BTM_SUCCESS:
      return (BT_PASS);

    case BTM_CMD_STARTED:
      return (GAP_CMD_INITIATED);

    case BTM_BUSY:
      return (GAP_ERR_BUSY);

    case BTM_MODE_UNSUPPORTED:
    case BTM_ILLEGAL_VALUE:
      return (GAP_ERR_ILL_PARM);

    case BTM_WRONG_MODE:
      return (GAP_DEVICE_NOT_UP);

    case BTM_UNKNOWN_ADDR:
      return (GAP_BAD_BD_ADDR);

    case BTM_DEVICE_TIMEOUT:
      return (GAP_ERR_TIMEOUT);

    default:
      return (GAP_ERR_PROCESSING);
  }
}