On Fri, 1 Mar 2013 11:16:22 -0500 Akshay Saraswat <[email protected]> wrote:
> SHA-256 and SHA-1 accelerated using ACE hardware. curious about the rationale: how much faster is this than software? > --- > Changes since v2: > - Added falling back to software sha256 in case length exceeds buffer > limit. > - Reduced one tab at lines 533, 559 and 571 in this patch. > - Removed space after a cast at line 506 in this patch. > - Removed blank line at line 561 in this patch. > - Removed space before semicolon at line 576 in this patch. you should retain the list of changes since v1 here. Read: http://www.denx.de/wiki/view/U-Boot/Patches#Sending_updated_patch_versions > +/* Hash status */ > +#define ACE_HASH_BUFRDY_MASK (1 << 0) > +#define ACE_HASH_BUFRDY_OFF (0 << 0) > +#define ACE_HASH_BUFRDY_ON (1 << 0) > +#define ACE_HASH_SEEDSETTING_MASK (1 << 1) > +#define ACE_HASH_SEEDSETTING_OFF (0 << 1) > +#define ACE_HASH_SEEDSETTING_ON (1 << 1) > +#define ACE_HASH_PRNGBUSY_MASK (1 << 2) > +#define ACE_HASH_PRNGBUSY_OFF (0 << 2) > +#define ACE_HASH_PRNGBUSY_ON (1 << 2) > +#define ACE_HASH_PARTIALDONE_MASK (1 << 4) > +#define ACE_HASH_PARTIALDONE_OFF (0 << 4) > +#define ACE_HASH_PARTIALDONE_ON (1 << 4) based on the nomenclature of the above definitions, this hardware obviously has support for breaking up hash requests into multiple buffer submissions, so do that, and not this: > + } else if (buf_len > BUF_LIMIT) { > + /* > + * ACE H/W cannot compute hash value for buffer > 8 MB. > + * Falling back to software. > + */ > + if (hash_type == ACE_SHA_TYPE_SHA1) > + sha1_csum_wd(pbuf, buf_len, pout, CHUNKSZ_SHA1); > + else > + sha256_csum_wd(pbuf, buf_len, pout, CHUNKSZ_SHA256); > + return 0; > + } Kim _______________________________________________ U-Boot mailing list [email protected] http://lists.denx.de/mailman/listinfo/u-boot

