HCP protocol implementation now in hcp_tiny.c/hcp_tiny.h Removed old hcp folder Switched functions from FCP_COM_RESULT_ to FPC_BEP_RESULT_ codes Change-Id: I16750ffb485056b79bd55efaa2e884299f7f27b8
179 lines
5.1 KiB
C
179 lines
5.1 KiB
C
/*
|
|
* Copyright (c) 2020 Fingerprint Cards AB
|
|
*
|
|
* 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
|
|
*
|
|
* https://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.
|
|
*/
|
|
|
|
#ifndef BEP_HOST_IF_H
|
|
#define BEP_HOST_IF_H
|
|
|
|
/**
|
|
* @file bep_host_if.h
|
|
* @brief BEP Host Interface API
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
#include "fpc_bep_types.h"
|
|
// #include "fpc_com_chain.h"
|
|
|
|
#include "hcp_tiny.h"
|
|
|
|
#define REMOVE_ID_ALL_TEMPLATES 0U
|
|
|
|
/**
|
|
* @brief Sends HCP commands for capturing an image in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[in] timeout Timeout in ms
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_capture(HCP_comm_t *chain, uint16_t timeout);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for enrolling a finger in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_enroll_finger(HCP_comm_t *chain);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for identifying a finger in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[out] template_id Template id that was identified (only valid if match is true)
|
|
* @param[out] match True if match
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_identify_finger(HCP_comm_t *chain, uint32_t timeout, uint16_t *template_id, bool *match);
|
|
|
|
|
|
/**
|
|
* @brief Sends HCP commands for saving template of an enrolled finger in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[in] template_id Template id to save
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_save_template(HCP_comm_t *chain, uint16_t template_id);
|
|
|
|
/**
|
|
* @brief Remove template(s) stored
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[in] template_id template id to remove, if =REMOVE_ID_ALL_TEMPLATES removes all templates
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_delete_template(HCP_comm_t *chain, uint16_t template_id);
|
|
|
|
/**
|
|
* @brief Gets all template ids from Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[out] template_ids Should be allocated by the caller for storing template ids and should
|
|
* have capacity to hold bio_get_template_count
|
|
* @param[in] nof_templates This should be acquired using bio_get_template_count
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_get_template_ids(HCP_comm_t *chain, uint16_t *template_ids,
|
|
uint32_t nof_templates);
|
|
|
|
/**
|
|
* @brief Get the number of templates in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[out] template_count
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_get_template_count(HCP_comm_t *chain, uint32_t *template_count);
|
|
|
|
|
|
/**
|
|
* @brief Sends HCP commands for extracting a template from a previously capture image in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_image_extract(HCP_comm_t *chain);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for getting the image size of a previously capture image in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_image_get_size(HCP_comm_t *chain, uint32_t *size);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for getting the image data of a previously capture image in Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_image_get(HCP_comm_t *chain, uint8_t *data, uint32_t size);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for fetching the version of the Bio MCU FW
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[out] version Version string buffer
|
|
* @param[out] len Length of version string buffer
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_version(HCP_comm_t *chain, char *version, int len);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for resetting the Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_reset(HCP_comm_t *chain);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for calibrating the sensor in the Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_sensor_calibrate(HCP_comm_t *chain);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for removing the sensor calibration in the Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_sensor_calibrate_remove(HCP_comm_t *chain);
|
|
|
|
/**
|
|
* @brief Sends HCP commands for setting the sensor in sleep and waiting for finger in the Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[in] timeout Timeout in ms
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_sensor_wait_for_finger(HCP_comm_t *chain, uint16_t timeout);
|
|
|
|
/**
|
|
* @brief Sends HCP commands that returns when finger is not on the sensor in the Bio MCU
|
|
*
|
|
* @param[in] chain HCP com chain
|
|
* @param[in] timeout Timeout in ms
|
|
* @return ::fpc_bep_result_t
|
|
*/
|
|
fpc_bep_result_t bep_sensor_wait_finger_not_present(HCP_comm_t *chain, uint16_t timeout);
|
|
|
|
#endif /* BEP_HOST_IF_H */
|