remove autogenerated file
[librfid] / src / rfid_layer2.c
index a6ee43f..4cad6c3 100644 (file)
  *
  *  You should have received a copy of the GNU General Public License
  *  along with this program; if not, write to the Free Software
- *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
  */
 
 #include <stdlib.h>
 #include <stdio.h>
 #include <errno.h>
+#include <string.h> /* for memcpy */
 
 #include <librfid/rfid.h>
 #include <librfid/rfid_layer2.h>
 
-static struct rfid_layer2 *rfid_layer2_list;
+static const struct rfid_layer2 *rfid_layer2s[] = {
+       [RFID_LAYER2_ISO14443A] = &rfid_layer2_iso14443a,
+       [RFID_LAYER2_ISO14443B] = &rfid_layer2_iso14443b,
+       [RFID_LAYER2_ISO15693]  = &rfid_layer2_iso15693,
+};
 
 struct rfid_layer2_handle *
 rfid_layer2_init(struct rfid_reader_handle *rh, unsigned int id)
 {
        struct rfid_layer2 *p;
 
-       for (p = rfid_layer2_list; p; p = p->next)
-               if (p->id == id)
-                       return p->fn.init(rh);
+       if (id >= ARRAY_SIZE(rfid_layer2s)) {
+               DEBUGP("unable to find matching layer2 protocol\n");
+               return NULL;
+       }
 
-       DEBUGP("unable to find matching layer2 protocol\n");
-       return NULL;
+       p = rfid_layer2s[id];
+       return p->fn.init(rh);
 }
 
 int
@@ -79,15 +85,6 @@ rfid_layer2_close(struct rfid_layer2_handle *ph)
        return ph->l2->fn.close(ph);
 }
 
-int
-rfid_layer2_register(struct rfid_layer2 *p)
-{
-       p->next = rfid_layer2_list;
-       rfid_layer2_list = p;
-
-       return 0;
-}
-
 int
 rfid_layer2_getopt(struct rfid_layer2_handle *ph, int optname,
                   void *optval, unsigned int *optlen)
@@ -120,6 +117,15 @@ rfid_layer2_setopt(struct rfid_layer2_handle *ph, int optname,
 {
        if (optname >> 16 == 0) {
                switch (optname) {
+               case RFID_OPT_LAYER2_UID:
+               printf("----> sizeof(ph->uid): %d\n",sizeof(ph->uid));
+                       if ((ph->uid_len < sizeof(ph->uid)) && (optlen<=sizeof(ph->uid))) {
+                               //(ph->uid_len<optlen)
+                               ph->uid_len = optlen;
+                               memcpy(ph->uid, optval, optlen);
+                       } else
+                               return -EINVAL;
+               break;
                default:
                        return -EINVAL;
                        break;