linux/drivers/crypto/qat/qat_dh895xcc
Allan, Bruce W 22e4dda06d crypto: qat - fix device reset flow
When the device needs a reset, e.g. when an uncorrectable PCIe AER event
occurs, various services/data structures need to be cleaned up, the
hardware reset and the services/data structures initialized and started.
The code to perform the cleanup and initialization was not performed when
a device reset was done.

This patch moves some of the initialization code out of the .probe entry-
point into a separate function that is now called during probe as well as
after the hardware has been reset.  Similarly, a new function is added for
first cleaning up these services/data structures prior to resetting.  The
new functions are adf_dev_init() and adf_dev_shutdown(), respectively, for
which there are already prototypes but no actual functions just yet and are
now called when the device is reset and during probe/cleanup of the driver.
The down and up flows via ioctl calls has similarly been updated.

In addition, there are two other bugs in the reset flow - one in the logic
for determining whether to schedule a device reset upon receiving an
uncorrectable AER event which prevents the reset flow from being initiated,
and another with clearing the status bit indicating a device is configured
(when resetting the device the configuration remains across the reset so
the bit should not be cleared, otherwise, the necessary services will not
be re-started in adf_dev_start() after the reset - clear the bit only when
actually deleting the configuration).

Signed-off-by: Bruce Allan <bruce.w.allan@intel.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
2015-01-13 22:30:45 +11:00
..
Makefile crypto: qat - Fix build problem with O= 2014-06-23 21:37:53 +08:00
adf_admin.c crypto: qat - Enforce valid numa configuration 2014-10-24 22:37:36 +08:00
adf_dh895xcc_hw_data.c crypto: qat - fix device reset flow 2015-01-13 22:30:45 +11:00
adf_dh895xcc_hw_data.h crypto: qat - Move BAR definitions to device specific module 2014-11-06 23:14:59 +08:00
adf_drv.c crypto: qat - fix device reset flow 2015-01-13 22:30:45 +11:00
adf_drv.h
adf_hw_arbiter.c crypto: qat - Fixed new checkpatch warnings 2014-06-26 14:49:43 +08:00
adf_isr.c Merge git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6 2014-12-13 13:33:26 -08:00
qat_admin.c