crypto: caam - Implement fast-path for error codes with no handler
authorMarek Vasut <marex@denx.de>
Thu, 24 Apr 2014 18:05:14 +0000 (20:05 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Thu, 8 May 2014 13:58:07 +0000 (21:58 +0800)
Implement fast-path error code printout for errors with no associated
handler function. This reduces calls to this kmalloc() nonsense in
SPRINTFCAT() already.

Note that the format of output is compatible with the old code, even
if -- exposed like this -- it looks a bit weird. Checkpatch complains
on this one as well.

Signed-off-by: Marek Vasut <marex@denx.de>
Cc: Herbert Xu <herbert@gondor.apana.org.au>
Cc: Horia Geanta <horia.geanta@freescale.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/crypto/caam/error.c

index 3d7be4c050086ad127a3ac8cb0b64534858f1afa..961331d1b6abe7973a082f726bc44a8ffe473264 100644 (file)
@@ -265,10 +265,18 @@ void caam_jr_strstatus(struct device *jrdev, u32 status)
        };
        u32 ssrc = status >> JRSTA_SSRC_SHIFT;
 
+       /*
+        * If there is no further error handling function, just
+        * print the error code, error string and exit.
+        */
+       if (!status_src[ssrc].report_ssed) {
+               dev_err(jrdev, "%08x: %s: \n", status, status_src[ssrc].error);
+               return;
+       }
+
        sprintf(outstr, "%s: ", status_src[ssrc].error);
 
-       if (status_src[ssrc].report_ssed)
-               status_src[ssrc].report_ssed(status, outstr);
+       status_src[ssrc].report_ssed(status, outstr);
 
        dev_err(jrdev, "%08x: %s\n", status, outstr);
 }