81 lines
2.4 KiB
Markdown
81 lines
2.4 KiB
Markdown
|
# Introduction
|
||
|
|
||
|
The _libfreefare_ project provides a convenient API for MIFARE card manipulations.
|
||
|
|
||
|
It is part of the _nfc-tools_, you can find more info on them on the [nfc-tools wiki](http://nfc-tools.org/).
|
||
|
|
||
|
If you are new to _libfreefare_ or the _nfc-tools_, you should collect useful information on the [project website](http://nfc-tools.org/) and the [dedicated forums](http://www.libnfc.org/community).
|
||
|
|
||
|
# Feature matrix
|
||
|
## Tags
|
||
|
| Tag | Status |
|
||
|
|:-------------------|:--------------|
|
||
|
| MIFARE Classic 1k | Supported |
|
||
|
| MIFARE Classic 4k | Supported |
|
||
|
| MIFARE DESFire 2k | Supported |
|
||
|
| MIFARE DESFire 4k | Supported |
|
||
|
| MIFARE DESFire 8k | Supported |
|
||
|
| MIFARE DESFire EV1 | Supported |
|
||
|
| MIFARE Mini | Not supported |
|
||
|
| MIFARE Plus S 2k | Not supported |
|
||
|
| MIFARE Plus S 4k | Not supported |
|
||
|
| MIFARE Plus X 2k | Not supported |
|
||
|
| MIFARE Plus X 4k | Not supported |
|
||
|
| MIFARE Ultralight | Supported |
|
||
|
| MIFARE UltralightC | Supported |
|
||
|
|
||
|
## Specifications
|
||
|
| Specification | Status |
|
||
|
|:--------------------------------------|:----------|
|
||
|
| Mifare Application Directory (MAD) v1 | Supported |
|
||
|
| Mifare Application Directory (MAD) v2 | Supported |
|
||
|
| Mifare Application Directory (MAD) v3 | Supported (part of Mifare DESFire support) |
|
||
|
|
||
|
# Installation
|
||
|
You can use released version (see **Download** section) or development version:
|
||
|
|
||
|
First, ensure all dependencies are installed:
|
||
|
* [libnfc](https://github.com/nfc-tools/libnfc);
|
||
|
* git;
|
||
|
* Autotools (autoconf, automake, libtool);
|
||
|
* OpenSSL development package.
|
||
|
```
|
||
|
apt-get install autoconf automake git libtool libssl-dev pkg-config
|
||
|
```
|
||
|
|
||
|
Clone this repository:
|
||
|
```
|
||
|
git clone https://github.com/nfc-tools/libfreefare.git
|
||
|
cd libfreefare
|
||
|
```
|
||
|
|
||
|
Before compiling, remember to run:
|
||
|
```
|
||
|
autoreconf -vis
|
||
|
```
|
||
|
|
||
|
You can now compile **libfreefare** the usual autotools way:
|
||
|
```
|
||
|
./configure --prefix=/usr
|
||
|
make
|
||
|
sudo make install
|
||
|
```
|
||
|
|
||
|
# Debug
|
||
|
In order to debug using gdb, you should tune the CFLAGS:
|
||
|
```
|
||
|
CFLAGS="-O0 -ggdb" ./configure --prefix=/usr
|
||
|
make clean all
|
||
|
```
|
||
|
|
||
|
It is then possible to debug examples using this kind of command from the root of the repository:
|
||
|
```
|
||
|
./libtool --mode=execute gdb examples/mifare-classic-write-ndef
|
||
|
```
|
||
|
|
||
|
If you are only interested in viewing transfert traces between the PCD and the PICC, simply use the `--enable-debug` configure flag:
|
||
|
```
|
||
|
./configure --enable-debug
|
||
|
make clean all
|
||
|
```
|