aes4000: port to asynchronous model
This commit is contained in:
parent
d731d5f3a3
commit
d914712437
3 changed files with 92 additions and 49 deletions
|
@ -8,8 +8,8 @@ AES2501_SRC = drivers/aes2501.c drivers/aes2501.h
|
||||||
AES4000_SRC = drivers/aes4000.c
|
AES4000_SRC = drivers/aes4000.c
|
||||||
FDU2000_SRC = drivers/fdu2000.c
|
FDU2000_SRC = drivers/fdu2000.c
|
||||||
|
|
||||||
DRIVER_SRC = $(UPEKTS_SRC)
|
DRIVER_SRC = $(UPEKTS_SRC) $(AES4000_SRC)
|
||||||
#DRIVER_SRC = $(URU4000_SRC) $(AES1610_SRC) $(AES2501_SRC) $(AES4000_SRC) $(UPEKTC_SRC) $(FDU2000_SRC)
|
#DRIVER_SRC = $(URU4000_SRC) $(AES1610_SRC) $(AES2501_SRC) $(UPEKTC_SRC) $(FDU2000_SRC)
|
||||||
|
|
||||||
NBIS_SRC = \
|
NBIS_SRC = \
|
||||||
nbis/include/bozorth.h \
|
nbis/include/bozorth.h \
|
||||||
|
|
|
@ -329,10 +329,10 @@ static struct fp_driver * const primitive_drivers[] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct fp_img_driver * const img_drivers[] = {
|
static struct fp_img_driver * const img_drivers[] = {
|
||||||
|
&aes4000_driver,
|
||||||
/* &uru4000_driver,
|
/* &uru4000_driver,
|
||||||
&aes1610_driver,
|
&aes1610_driver,
|
||||||
&aes2501_driver,
|
&aes2501_driver,
|
||||||
&aes4000_driver,
|
|
||||||
&upektc_driver,
|
&upektc_driver,
|
||||||
&fdu2000_driver, */
|
&fdu2000_driver, */
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* AuthenTec AES4000 driver for libfprint
|
* AuthenTec AES4000 driver for libfprint
|
||||||
* Copyright (C) 2007 Daniel Drake <dsd@gentoo.org>
|
* Copyright (C) 2007-2008 Daniel Drake <dsd@gentoo.org>
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
@ -34,6 +34,10 @@
|
||||||
#define NR_SUBARRAYS 6
|
#define NR_SUBARRAYS 6
|
||||||
#define SUBARRAY_LEN 768
|
#define SUBARRAY_LEN 768
|
||||||
|
|
||||||
|
struct aes4k_dev {
|
||||||
|
libusb_urb_handle *img_trf;
|
||||||
|
};
|
||||||
|
|
||||||
static const struct aes_regwrite init_reqs[] = {
|
static const struct aes_regwrite init_reqs[] = {
|
||||||
/* master reset */
|
/* master reset */
|
||||||
{ 0x80, 0x01 },
|
{ 0x80, 0x01 },
|
||||||
|
@ -109,45 +113,32 @@ static const struct aes_regwrite init_reqs[] = {
|
||||||
{ 0x81, 0x00 },
|
{ 0x81, 0x00 },
|
||||||
};
|
};
|
||||||
|
|
||||||
static int capture(struct fp_img_dev *dev, gboolean unconditional,
|
static void do_capture(struct fp_img_dev *dev);
|
||||||
struct fp_img **ret)
|
|
||||||
|
static void img_cb(libusb_dev_handle *devh, libusb_urb_handle *urbh,
|
||||||
|
enum libusb_urb_cb_status status, unsigned char endpoint,
|
||||||
|
int rqlength, unsigned char *data, int actual_length, void *user_data)
|
||||||
{
|
{
|
||||||
int i;
|
struct fp_img_dev *dev = user_data;
|
||||||
int r;
|
struct aes4k_dev *aesdev = dev->priv;
|
||||||
int transferred;
|
unsigned char *ptr = data;
|
||||||
struct fp_img *img;
|
struct fp_img *img;
|
||||||
unsigned char *data;
|
int i;
|
||||||
unsigned char *ptr;
|
|
||||||
struct libusb_bulk_transfer msg = {
|
|
||||||
.endpoint = EP_IN,
|
|
||||||
.length = DATA_BUFLEN,
|
|
||||||
};
|
|
||||||
|
|
||||||
r = aes_write_regv(dev, init_reqs, G_N_ELEMENTS(init_reqs));
|
if (status == FP_URB_CANCELLED) {
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
img = fpi_img_new_for_imgdev(dev);
|
|
||||||
data = g_malloc(DATA_BUFLEN);
|
|
||||||
ptr = data;
|
|
||||||
msg.data = data;
|
|
||||||
|
|
||||||
/* See the timeout explanation in the uru4000 driver for the reasoning
|
|
||||||
* behind this silly loop. */
|
|
||||||
retry:
|
|
||||||
r = libusb_bulk_transfer(dev->udev, &msg, &transferred, 1000);
|
|
||||||
if (r == -ETIMEDOUT)
|
|
||||||
goto retry;
|
|
||||||
|
|
||||||
if (r < 0) {
|
|
||||||
fp_err("data read failed, error %d", r);
|
|
||||||
goto err;
|
goto err;
|
||||||
} else if (transferred < DATA_BUFLEN) {
|
} else if (status != FP_URB_COMPLETED) {
|
||||||
fp_err("short data read (%d)", r);
|
fpi_imgdev_session_error(dev, -EIO);
|
||||||
r = -EIO;
|
goto err;
|
||||||
|
} else if (rqlength != actual_length) {
|
||||||
|
fpi_imgdev_session_error(dev, -EPROTO);
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fpi_imgdev_report_finger_status(dev, TRUE);
|
||||||
|
|
||||||
|
img = fpi_img_new_for_imgdev(dev);
|
||||||
|
img->flags = FP_IMG_COLORS_INVERTED | FP_IMG_V_FLIPPED | FP_IMG_H_FLIPPED;
|
||||||
for (i = 0; i < NR_SUBARRAYS; i++) {
|
for (i = 0; i < NR_SUBARRAYS; i++) {
|
||||||
fp_dbg("subarray header byte %02x", *ptr);
|
fp_dbg("subarray header byte %02x", *ptr);
|
||||||
ptr++;
|
ptr++;
|
||||||
|
@ -155,14 +146,60 @@ retry:
|
||||||
ptr += SUBARRAY_LEN;
|
ptr += SUBARRAY_LEN;
|
||||||
}
|
}
|
||||||
|
|
||||||
img->flags = FP_IMG_COLORS_INVERTED | FP_IMG_V_FLIPPED | FP_IMG_H_FLIPPED;
|
fpi_imgdev_image_captured(dev, img);
|
||||||
*ret = img;
|
|
||||||
g_free(data);
|
/* FIXME: rather than assuming finger has gone, we should poll regs until
|
||||||
return 0;
|
* it really has, then restart the capture */
|
||||||
|
fpi_imgdev_report_finger_status(dev, FALSE);
|
||||||
|
|
||||||
|
do_capture(dev);
|
||||||
|
|
||||||
err:
|
err:
|
||||||
g_free(data);
|
g_free(data);
|
||||||
fp_img_free(img);
|
aesdev->img_trf = NULL;
|
||||||
return r;
|
libusb_urb_handle_free(urbh);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void do_capture(struct fp_img_dev *dev)
|
||||||
|
{
|
||||||
|
struct aes4k_dev *aesdev = dev->priv;
|
||||||
|
struct libusb_bulk_transfer trf = {
|
||||||
|
.endpoint = EP_IN,
|
||||||
|
.length = DATA_BUFLEN,
|
||||||
|
.data = g_malloc(DATA_BUFLEN),
|
||||||
|
};
|
||||||
|
|
||||||
|
aesdev->img_trf = libusb_async_bulk_transfer(dev->udev, &trf, img_cb, dev,
|
||||||
|
0);
|
||||||
|
if (!aesdev->img_trf) {
|
||||||
|
g_free(trf.data);
|
||||||
|
fpi_imgdev_session_error(dev, -EIO);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void init_reqs_cb(struct fp_img_dev *dev, int result)
|
||||||
|
{
|
||||||
|
fpi_imgdev_activate_complete(dev, result);
|
||||||
|
if (result == 0)
|
||||||
|
do_capture(dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int dev_activate(struct fp_img_dev *dev, enum fp_imgdev_state state)
|
||||||
|
{
|
||||||
|
aes_write_regv(dev, init_reqs, G_N_ELEMENTS(init_reqs), init_reqs_cb);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void dev_deactivate(struct fp_img_dev *dev)
|
||||||
|
{
|
||||||
|
struct aes4k_dev *aesdev = dev->priv;
|
||||||
|
|
||||||
|
/* FIXME: should wait for cancellation to complete before returning
|
||||||
|
* from deactivation, otherwise app may legally exit before we've
|
||||||
|
* cleaned up */
|
||||||
|
if (aesdev->img_trf)
|
||||||
|
libusb_urb_handle_cancel(dev->udev, aesdev->img_trf);
|
||||||
|
fpi_imgdev_deactivate_complete(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dev_init(struct fp_img_dev *dev, unsigned long driver_data)
|
static int dev_init(struct fp_img_dev *dev, unsigned long driver_data)
|
||||||
|
@ -170,17 +207,22 @@ static int dev_init(struct fp_img_dev *dev, unsigned long driver_data)
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
r = libusb_claim_interface(dev->udev, 0);
|
r = libusb_claim_interface(dev->udev, 0);
|
||||||
if (r < 0) {
|
if (r < 0)
|
||||||
fp_err("could not claim interface 0");
|
fp_err("could not claim interface 0");
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
dev->priv = g_malloc0(sizeof(struct aes4k_dev));
|
||||||
|
|
||||||
|
if (r == 0)
|
||||||
|
fpi_imgdev_init_complete(dev, 0);
|
||||||
|
|
||||||
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void dev_exit(struct fp_img_dev *dev)
|
static void dev_deinit(struct fp_img_dev *dev)
|
||||||
{
|
{
|
||||||
|
g_free(dev->priv);
|
||||||
libusb_release_interface(dev->udev, 0);
|
libusb_release_interface(dev->udev, 0);
|
||||||
|
fpi_imgdev_deinit_complete(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct usb_id id_table[] = {
|
static const struct usb_id id_table[] = {
|
||||||
|
@ -204,7 +246,8 @@ struct fp_img_driver aes4000_driver = {
|
||||||
.bz3_threshold = 9,
|
.bz3_threshold = 9,
|
||||||
|
|
||||||
.init = dev_init,
|
.init = dev_init,
|
||||||
.exit = dev_exit,
|
.deinit = dev_deinit,
|
||||||
.capture = capture,
|
.activate = dev_activate,
|
||||||
|
.deactivate = dev_deactivate,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue