Instead of copying n fields, setup a pointer to the relevant supported_tag information in mifare_tag structures.
This commit is contained in:
parent
0d4744001a
commit
0f72871eb3
2 changed files with 16 additions and 20 deletions
|
@ -23,12 +23,6 @@
|
|||
|
||||
#include "freefare_internal.h"
|
||||
|
||||
struct supported_tag {
|
||||
uint8_t ATQA[2], SAK;
|
||||
enum mifare_tag_type type;
|
||||
const char *friendly_name;
|
||||
};
|
||||
|
||||
struct supported_tag supported_tags[] = {
|
||||
{ { 0x00, 0x44 }, 0x00, ULTRALIGHT, "Mifare UltraLight" },
|
||||
{ { 0x00, 0x04 }, 0x08, CLASSIC_1K, "Mifare Classic 1k" },
|
||||
|
@ -81,16 +75,14 @@ freefare_get_tags (nfc_device_t *device)
|
|||
while (nfc_initiator_select_tag(device,NM_ISO14443A_106,NULL,0,&target_info)) {
|
||||
|
||||
bool found = false;
|
||||
enum mifare_tag_type type;
|
||||
const char *friendly_name;
|
||||
struct supported_tag *tag_info;
|
||||
|
||||
for (int i = 0; i < sizeof (supported_tags) / sizeof (struct supported_tag); i++) {
|
||||
if ((target_info.nai.abtAtqa[0] == supported_tags[i].ATQA[0]) &&
|
||||
(target_info.nai.abtAtqa[1] == supported_tags[i].ATQA[1]) &&
|
||||
(target_info.nai.btSak == supported_tags[i].SAK)) {
|
||||
|
||||
type = supported_tags[i].type;
|
||||
friendly_name = supported_tags[i].friendly_name;
|
||||
tag_info = &(supported_tags[i]);
|
||||
found = true;
|
||||
break;
|
||||
}
|
||||
|
@ -109,7 +101,7 @@ freefare_get_tags (nfc_device_t *device)
|
|||
return tags; // FAIL! Return what has been found so far.
|
||||
|
||||
/* Allocate memory for the found MIFARE target */
|
||||
switch (type) {
|
||||
switch (tag_info->type) {
|
||||
case CLASSIC_1K:
|
||||
case CLASSIC_4K:
|
||||
tags[tag_count-1] = mifare_classic_tag_new ();
|
||||
|
@ -129,8 +121,7 @@ freefare_get_tags (nfc_device_t *device)
|
|||
(tags[tag_count-1])->device = device;
|
||||
(tags[tag_count-1])->info = target_info.nai;
|
||||
(tags[tag_count-1])->active = 0;
|
||||
(tags[tag_count-1])->type = type;
|
||||
(tags[tag_count-1])->friendly_name = friendly_name;
|
||||
(tags[tag_count-1])->tag_info = tag_info;
|
||||
tags[tag_count] = NULL;
|
||||
|
||||
nfc_initiator_deselect_tag (device);
|
||||
|
@ -145,7 +136,7 @@ freefare_get_tags (nfc_device_t *device)
|
|||
enum mifare_tag_type
|
||||
freefare_get_tag_type (MifareTag tag)
|
||||
{
|
||||
return tag->type;
|
||||
return tag->tag_info->type;
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -154,7 +145,7 @@ freefare_get_tag_type (MifareTag tag)
|
|||
const char *
|
||||
freefare_get_tag_friendly_name (MifareTag tag)
|
||||
{
|
||||
return tag->friendly_name;
|
||||
return tag->tag_info->friendly_name;
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -165,7 +156,7 @@ freefare_free_tags (MifareTag *tags)
|
|||
{
|
||||
if (tags) {
|
||||
for (int i=0; tags[i]; i++) {
|
||||
switch (tags[i]->type) {
|
||||
switch (tags[i]->tag_info->type) {
|
||||
case CLASSIC_1K:
|
||||
case CLASSIC_4K:
|
||||
mifare_classic_tag_free (tags[i]);
|
||||
|
|
|
@ -51,6 +51,12 @@ MifareClassicBlockNumber mifare_classic_last_sector_block (MifareClassicBlockNu
|
|||
|
||||
#define MIFARE_ULTRALIGHT_PAGE_COUNT 16
|
||||
|
||||
struct supported_tag {
|
||||
uint8_t ATQA[2], SAK;
|
||||
enum mifare_tag_type type;
|
||||
const char *friendly_name;
|
||||
};
|
||||
|
||||
/*
|
||||
* This structure is common to all supported MIFARE targets but shall not be
|
||||
* used directly (it's some kind of abstract class). All members in this
|
||||
|
@ -62,8 +68,7 @@ MifareClassicBlockNumber mifare_classic_last_sector_block (MifareClassicBlockNu
|
|||
struct mifare_tag {
|
||||
nfc_device_t *device;
|
||||
nfc_iso14443a_info_t info;
|
||||
enum mifare_tag_type type;
|
||||
const char *friendly_name;
|
||||
const struct supported_tag *tag_info;
|
||||
int active;
|
||||
};
|
||||
|
||||
|
@ -101,8 +106,8 @@ struct mifare_ultralight_tag {
|
|||
#define ASSERT_ACTIVE(tag) do { if (!tag->active) return errno = ENXIO, -1; } while (0)
|
||||
#define ASSERT_INACTIVE(tag) do { if (tag->active) return errno = ENXIO, -1; } while (0)
|
||||
|
||||
#define ASSERT_MIFARE_ULTRALIGHT(tag) do { if (tag->type != ULTRALIGHT) return errno = ENODEV, -1; } while (0)
|
||||
#define ASSERT_MIFARE_CLASSIC(tag) do { if ((tag->type != CLASSIC_1K) && (tag->type != CLASSIC_4K)) return errno = ENODEV, -1; } while (0)
|
||||
#define ASSERT_MIFARE_ULTRALIGHT(tag) do { if (tag->tag_info->type != ULTRALIGHT) return errno = ENODEV, -1; } while (0)
|
||||
#define ASSERT_MIFARE_CLASSIC(tag) do { if ((tag->tag_info->type != CLASSIC_1K) && (tag->tag_info->type != CLASSIC_4K)) return errno = ENODEV, -1; } while (0)
|
||||
|
||||
/*
|
||||
* MifareTag cast macros
|
||||
|
|
Loading…
Reference in a new issue