2010-01-12 12:50:09 +01:00
|
|
|
/*-
|
2009-10-12 16:52:26 +02:00
|
|
|
* Public platform independent Near Field Communication (NFC) library
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009, Roel Verdult
|
2010-09-10 15:35:25 +02:00
|
|
|
* Copyright (C) 2010, Romuald Conty
|
2009-10-12 16:52:26 +02:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU Lesser General Public License as published by the
|
|
|
|
* Free Software Foundation, either version 3 of the License, or (at your
|
|
|
|
* option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
* more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
2010-01-12 12:50:09 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2010-01-10 19:14:26 +01:00
|
|
|
* @file nfc.h
|
2010-01-12 12:50:09 +01:00
|
|
|
* @brief libnfc interface
|
2009-08-27 12:49:45 +02:00
|
|
|
*
|
2009-10-12 16:52:26 +02:00
|
|
|
* Provide all usefull functions (API) to handle NFC devices.
|
2009-08-27 12:49:45 +02:00
|
|
|
*/
|
|
|
|
|
2009-10-13 14:43:52 +02:00
|
|
|
#ifndef _LIBNFC_H_
|
2010-09-07 19:51:03 +02:00
|
|
|
# define _LIBNFC_H_
|
2009-10-12 16:52:26 +02:00
|
|
|
|
2010-09-07 19:51:03 +02:00
|
|
|
# include <stdint.h>
|
|
|
|
# include <stdbool.h>
|
2009-05-27 12:13:19 +02:00
|
|
|
|
2010-09-07 19:51:03 +02:00
|
|
|
# ifdef _WIN32
|
2010-03-31 16:03:12 +02:00
|
|
|
/* Windows platform */
|
2010-09-07 19:51:03 +02:00
|
|
|
# ifndef _WINDLL
|
2010-03-31 16:03:12 +02:00
|
|
|
/* CMake compilation */
|
2010-09-07 19:51:03 +02:00
|
|
|
# ifdef nfc_EXPORTS
|
|
|
|
# define NFC_EXPORT __declspec(dllexport)
|
|
|
|
# else
|
|
|
|
/* nfc_EXPORTS */
|
|
|
|
# define NFC_EXPORT __declspec(dllimport)
|
|
|
|
# endif
|
|
|
|
/* nfc_EXPORTS */
|
|
|
|
# else
|
|
|
|
/* _WINDLL */
|
2010-03-31 16:03:12 +02:00
|
|
|
/* Manual makefile */
|
2010-09-07 19:51:03 +02:00
|
|
|
# define NFC_EXPORT
|
|
|
|
# endif
|
|
|
|
/* _WINDLL */
|
|
|
|
# else
|
|
|
|
/* _WIN32 */
|
|
|
|
# define NFC_EXPORT
|
|
|
|
# endif
|
|
|
|
/* _WIN32 */
|
2009-11-10 10:47:59 +01:00
|
|
|
|
2010-09-07 19:51:03 +02:00
|
|
|
# include <nfc/nfc-types.h>
|
2009-04-29 14:47:41 +02:00
|
|
|
|
2010-09-07 19:51:03 +02:00
|
|
|
# ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
# endif // __cplusplus
|
2009-11-02 08:46:29 +01:00
|
|
|
|
2010-01-12 12:50:09 +01:00
|
|
|
/* NFC Device/Hardware manipulation */
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT nfc_device_t *nfc_connect (nfc_device_desc_t * pndd);
|
|
|
|
NFC_EXPORT void nfc_disconnect (nfc_device_t * pnd);
|
2010-09-10 15:35:25 +02:00
|
|
|
NFC_EXPORT void nfc_list_devices (nfc_device_desc_t pnddDevices[], size_t szDevices, size_t * pszDeviceFound);
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT bool nfc_configure (nfc_device_t * pnd, const nfc_device_option_t ndo, const bool bEnable);
|
2009-08-27 12:49:45 +02:00
|
|
|
|
2010-01-12 12:50:09 +01:00
|
|
|
/* NFC initiator: act as "reader" */
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT bool nfc_initiator_init (nfc_device_t * pnd);
|
|
|
|
NFC_EXPORT bool nfc_initiator_select_passive_target (nfc_device_t * pnd, const nfc_modulation_t nmInitModulation,
|
|
|
|
const byte_t * pbtInitData, const size_t szInitDataLen,
|
|
|
|
nfc_target_info_t * pti);
|
|
|
|
NFC_EXPORT bool nfc_initiator_list_passive_targets (nfc_device_t * pnd, const nfc_modulation_t nmInitModulation,
|
|
|
|
nfc_target_info_t anti[], const size_t szTargets,
|
|
|
|
size_t * pszTargetFound);
|
|
|
|
NFC_EXPORT bool nfc_initiator_poll_targets (nfc_device_t * pnd, const nfc_target_type_t * pnttTargetTypes,
|
|
|
|
const size_t szTargetTypes, const byte_t btPollNr, const byte_t btPeriod,
|
|
|
|
nfc_target_t * pntTargets, size_t * pszTargetFound);
|
|
|
|
NFC_EXPORT bool nfc_initiator_select_dep_target (nfc_device_t * pnd, const nfc_modulation_t nmInitModulation,
|
|
|
|
const byte_t * pbtPidData, const size_t szPidDataLen,
|
|
|
|
const byte_t * pbtNFCID3i, const size_t szNFCID3iDataLen,
|
|
|
|
const byte_t * pbtGbData, const size_t szGbDataLen,
|
|
|
|
nfc_target_info_t * pti);
|
|
|
|
NFC_EXPORT bool nfc_initiator_deselect_target (nfc_device_t * pnd);
|
|
|
|
NFC_EXPORT bool nfc_initiator_transceive_bytes (nfc_device_t * pnd, const byte_t * pbtTx, const size_t szTxLen,
|
|
|
|
byte_t * pbtRx, size_t * pszRxLen);
|
2010-09-10 15:35:25 +02:00
|
|
|
NFC_EXPORT bool nfc_initiator_transceive_bits (nfc_device_t * pnd, const byte_t * pbtTx, const size_t szTxBits,
|
|
|
|
const byte_t * pbtTxPar, byte_t * pbtRx, size_t * pszRxBits,
|
|
|
|
byte_t * pbtRxPar);
|
|
|
|
|
2010-01-12 12:50:09 +01:00
|
|
|
/* NFC target: act as tag (i.e. MIFARE Classic) or NFC target device. */
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT bool nfc_target_init (nfc_device_t * pnd, byte_t * pbtRx, size_t * pszRxBits);
|
2010-09-10 15:35:25 +02:00
|
|
|
NFC_EXPORT bool nfc_target_send_bytes (nfc_device_t * pnd, const byte_t * pbtTx, const size_t szTxLen);
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT bool nfc_target_receive_bytes (nfc_device_t * pnd, byte_t * pbtRx, size_t * pszRxLen);
|
|
|
|
NFC_EXPORT bool nfc_target_send_bits (nfc_device_t * pnd, const byte_t * pbtTx, const size_t szTxBits,
|
|
|
|
const byte_t * pbtTxPar);
|
2010-09-10 15:35:25 +02:00
|
|
|
NFC_EXPORT bool nfc_target_receive_bits (nfc_device_t * pnd, byte_t * pbtRx, size_t * pszRxBits, byte_t * pbtRxPar);
|
|
|
|
|
2010-07-29 16:16:11 +02:00
|
|
|
/* Error reporting */
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT const char *nfc_strerror (const nfc_device_t * pnd);
|
|
|
|
NFC_EXPORT int nfc_strerror_r (const nfc_device_t * pnd, char *pcStrErrBuf, size_t szBufLen);
|
|
|
|
NFC_EXPORT void nfc_perror (const nfc_device_t * pnd, const char *pcString);
|
2010-07-29 16:16:11 +02:00
|
|
|
|
2010-01-10 19:14:26 +01:00
|
|
|
/* Special data accessors */
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT const char *nfc_device_name (nfc_device_t * pnd);
|
2009-12-14 20:18:29 +01:00
|
|
|
|
2010-01-10 19:14:26 +01:00
|
|
|
/* Misc. functions */
|
2010-09-07 19:51:03 +02:00
|
|
|
NFC_EXPORT void iso14443a_crc (byte_t * pbtData, size_t szLen, byte_t * pbtCrc);
|
|
|
|
NFC_EXPORT void append_iso14443a_crc (byte_t * pbtData, size_t szLen);
|
|
|
|
NFC_EXPORT const char *nfc_version (void);
|
2010-01-10 19:14:26 +01:00
|
|
|
|
2010-08-15 16:08:29 +02:00
|
|
|
/* Common device-level errors */
|
2010-09-07 19:51:03 +02:00
|
|
|
# define DEIO 0x1000/* Input/output error */
|
|
|
|
# define DEINVAL 0x2000/* Invalid argument */
|
|
|
|
# define DETIMEOUT 0x3000/* Operation timeout */
|
2010-08-15 16:08:29 +02:00
|
|
|
|
2010-09-07 19:51:03 +02:00
|
|
|
# ifdef __cplusplus
|
2009-11-02 08:46:29 +01:00
|
|
|
}
|
2010-09-07 19:51:03 +02:00
|
|
|
# endif // __cplusplus
|
|
|
|
#endif // _LIBNFC_H_
|