diff options
Diffstat (limited to 'drivers/crypto/ccree/cc_fips.c')
| -rw-r--r-- | drivers/crypto/ccree/cc_fips.c | 29 | 
1 files changed, 17 insertions, 12 deletions
diff --git a/drivers/crypto/ccree/cc_fips.c b/drivers/crypto/ccree/cc_fips.c index b4d0a6d983e0..5ad3ffb7acaa 100644 --- a/drivers/crypto/ccree/cc_fips.c +++ b/drivers/crypto/ccree/cc_fips.c @@ -1,5 +1,5 @@  // SPDX-License-Identifier: GPL-2.0 -/* Copyright (C) 2012-2018 ARM Limited or its affiliates. */ +/* Copyright (C) 2012-2019 ARM Limited (or its affiliates). */  #include <linux/kernel.h>  #include <linux/fips.h> @@ -49,8 +49,6 @@ void cc_fips_fini(struct cc_drvdata *drvdata)  	/* Kill tasklet */  	tasklet_kill(&fips_h->tasklet); - -	kfree(fips_h);  	drvdata->fips_handle = NULL;  } @@ -72,20 +70,28 @@ static inline void tee_fips_error(struct device *dev)  		dev_err(dev, "TEE reported error!\n");  } +/* + * This function check if cryptocell tee fips error occurred + * and in such case triggers system error + */ +void cc_tee_handle_fips_error(struct cc_drvdata *p_drvdata) +{ +	struct device *dev = drvdata_to_dev(p_drvdata); + +	if (!cc_get_tee_fips_status(p_drvdata)) +		tee_fips_error(dev); +} +  /* Deferred service handler, run as interrupt-fired tasklet */  static void fips_dsr(unsigned long devarg)  {  	struct cc_drvdata *drvdata = (struct cc_drvdata *)devarg; -	struct device *dev = drvdata_to_dev(drvdata); -	u32 irq, state, val; +	u32 irq, val;  	irq = (drvdata->irq & (CC_GPR0_IRQ_MASK));  	if (irq) { -		state = cc_ioread(drvdata, CC_REG(GPR_HOST)); - -		if (state != (CC_FIPS_SYNC_TEE_STATUS | CC_FIPS_SYNC_MODULE_OK)) -			tee_fips_error(dev); +		cc_tee_handle_fips_error(drvdata);  	}  	/* after verifing that there is nothing to do, @@ -104,7 +110,7 @@ int cc_fips_init(struct cc_drvdata *p_drvdata)  	if (p_drvdata->hw_rev < CC_HW_REV_712)  		return 0; -	fips_h = kzalloc(sizeof(*fips_h), GFP_KERNEL); +	fips_h = devm_kzalloc(dev, sizeof(*fips_h), GFP_KERNEL);  	if (!fips_h)  		return -ENOMEM; @@ -113,8 +119,7 @@ int cc_fips_init(struct cc_drvdata *p_drvdata)  	dev_dbg(dev, "Initializing fips tasklet\n");  	tasklet_init(&fips_h->tasklet, fips_dsr, (unsigned long)p_drvdata); -	if (!cc_get_tee_fips_status(p_drvdata)) -		tee_fips_error(dev); +	cc_tee_handle_fips_error(p_drvdata);  	return 0;  }  |