tcrypt.c 79 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * Quick & dirty crypto testing module.
  4. *
  5. * This will only exist until we have a better testing mechanism
  6. * (e.g. a char device).
  7. *
  8. * Copyright (c) 2002 James Morris <jmorris@intercode.com.au>
  9. * Copyright (c) 2002 Jean-Francois Dive <jef@linuxbe.org>
  10. * Copyright (c) 2007 Nokia Siemens Networks
  11. *
  12. * Updated RFC4106 AES-GCM testing.
  13. * Authors: Aidan O'Mahony (aidan.o.mahony@intel.com)
  14. * Adrian Hoban <adrian.hoban@intel.com>
  15. * Gabriele Paoloni <gabriele.paoloni@intel.com>
  16. * Tadeusz Struk (tadeusz.struk@intel.com)
  17. * Copyright (c) 2010, Intel Corporation.
  18. */
  19. #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
  20. #include <crypto/aead.h>
  21. #include <crypto/hash.h>
  22. #include <crypto/skcipher.h>
  23. #include <linux/err.h>
  24. #include <linux/fips.h>
  25. #include <linux/init.h>
  26. #include <linux/gfp.h>
  27. #include <linux/module.h>
  28. #include <linux/scatterlist.h>
  29. #include <linux/string.h>
  30. #include <linux/moduleparam.h>
  31. #include <linux/jiffies.h>
  32. #include <linux/timex.h>
  33. #include <linux/interrupt.h>
  34. #include "tcrypt.h"
  35. /*
  36. * Need slab memory for testing (size in number of pages).
  37. */
  38. #define TVMEMSIZE 4
  39. /*
  40. * Used by test_cipher_speed()
  41. */
  42. #define ENCRYPT 1
  43. #define DECRYPT 0
  44. #define MAX_DIGEST_SIZE 64
  45. /*
  46. * return a string with the driver name
  47. */
  48. #define get_driver_name(tfm_type, tfm) crypto_tfm_alg_driver_name(tfm_type ## _tfm(tfm))
  49. /*
  50. * Used by test_cipher_speed()
  51. */
  52. static unsigned int sec;
  53. static char *alg = NULL;
  54. static u32 type;
  55. static u32 mask;
  56. static int mode;
  57. static u32 num_mb = 8;
  58. static char *tvmem[TVMEMSIZE];
  59. static char *check[] = {
  60. "des", "md5", "des3_ede", "rot13", "sha1", "sha224", "sha256", "sm3",
  61. "blowfish", "twofish", "serpent", "sha384", "sha512", "md4", "aes",
  62. "cast6", "arc4", "michael_mic", "deflate", "crc32c", "tea", "xtea",
  63. "khazad", "wp512", "wp384", "wp256", "tnepres", "xeta", "fcrypt",
  64. "camellia", "seed", "salsa20", "rmd128", "rmd160", "rmd256", "rmd320",
  65. "lzo", "lzo-rle", "cts", "sha3-224", "sha3-256", "sha3-384",
  66. "sha3-512", "streebog256", "streebog512",
  67. NULL
  68. };
  69. static u32 block_sizes[] = { 16, 64, 256, 1024, 1472, 8192, 0 };
  70. static u32 aead_sizes[] = { 16, 64, 256, 512, 1024, 2048, 4096, 8192, 0 };
  71. #define XBUFSIZE 8
  72. #define MAX_IVLEN 32
  73. static int testmgr_alloc_buf(char *buf[XBUFSIZE])
  74. {
  75. int i;
  76. for (i = 0; i < XBUFSIZE; i++) {
  77. buf[i] = (void *)__get_free_page(GFP_KERNEL);
  78. if (!buf[i])
  79. goto err_free_buf;
  80. }
  81. return 0;
  82. err_free_buf:
  83. while (i-- > 0)
  84. free_page((unsigned long)buf[i]);
  85. return -ENOMEM;
  86. }
  87. static void testmgr_free_buf(char *buf[XBUFSIZE])
  88. {
  89. int i;
  90. for (i = 0; i < XBUFSIZE; i++)
  91. free_page((unsigned long)buf[i]);
  92. }
  93. static void sg_init_aead(struct scatterlist *sg, char *xbuf[XBUFSIZE],
  94. unsigned int buflen, const void *assoc,
  95. unsigned int aad_size)
  96. {
  97. int np = (buflen + PAGE_SIZE - 1)/PAGE_SIZE;
  98. int k, rem;
  99. if (np > XBUFSIZE) {
  100. rem = PAGE_SIZE;
  101. np = XBUFSIZE;
  102. } else {
  103. rem = buflen % PAGE_SIZE;
  104. }
  105. sg_init_table(sg, np + 1);
  106. sg_set_buf(&sg[0], assoc, aad_size);
  107. if (rem)
  108. np--;
  109. for (k = 0; k < np; k++)
  110. sg_set_buf(&sg[k + 1], xbuf[k], PAGE_SIZE);
  111. if (rem)
  112. sg_set_buf(&sg[k + 1], xbuf[k], rem);
  113. }
  114. static inline int do_one_aead_op(struct aead_request *req, int ret)
  115. {
  116. struct crypto_wait *wait = req->base.data;
  117. return crypto_wait_req(ret, wait);
  118. }
  119. struct test_mb_aead_data {
  120. struct scatterlist sg[XBUFSIZE];
  121. struct scatterlist sgout[XBUFSIZE];
  122. struct aead_request *req;
  123. struct crypto_wait wait;
  124. char *xbuf[XBUFSIZE];
  125. char *xoutbuf[XBUFSIZE];
  126. char *axbuf[XBUFSIZE];
  127. };
  128. static int do_mult_aead_op(struct test_mb_aead_data *data, int enc,
  129. u32 num_mb, int *rc)
  130. {
  131. int i, err = 0;
  132. /* Fire up a bunch of concurrent requests */
  133. for (i = 0; i < num_mb; i++) {
  134. if (enc == ENCRYPT)
  135. rc[i] = crypto_aead_encrypt(data[i].req);
  136. else
  137. rc[i] = crypto_aead_decrypt(data[i].req);
  138. }
  139. /* Wait for all requests to finish */
  140. for (i = 0; i < num_mb; i++) {
  141. rc[i] = crypto_wait_req(rc[i], &data[i].wait);
  142. if (rc[i]) {
  143. pr_info("concurrent request %d error %d\n", i, rc[i]);
  144. err = rc[i];
  145. }
  146. }
  147. return err;
  148. }
  149. static int test_mb_aead_jiffies(struct test_mb_aead_data *data, int enc,
  150. int blen, int secs, u32 num_mb)
  151. {
  152. unsigned long start, end;
  153. int bcount;
  154. int ret = 0;
  155. int *rc;
  156. rc = kcalloc(num_mb, sizeof(*rc), GFP_KERNEL);
  157. if (!rc)
  158. return -ENOMEM;
  159. for (start = jiffies, end = start + secs * HZ, bcount = 0;
  160. time_before(jiffies, end); bcount++) {
  161. ret = do_mult_aead_op(data, enc, num_mb, rc);
  162. if (ret)
  163. goto out;
  164. }
  165. pr_cont("%d operations in %d seconds (%llu bytes)\n",
  166. bcount * num_mb, secs, (u64)bcount * blen * num_mb);
  167. out:
  168. kfree(rc);
  169. return ret;
  170. }
  171. static int test_mb_aead_cycles(struct test_mb_aead_data *data, int enc,
  172. int blen, u32 num_mb)
  173. {
  174. unsigned long cycles = 0;
  175. int ret = 0;
  176. int i;
  177. int *rc;
  178. rc = kcalloc(num_mb, sizeof(*rc), GFP_KERNEL);
  179. if (!rc)
  180. return -ENOMEM;
  181. /* Warm-up run. */
  182. for (i = 0; i < 4; i++) {
  183. ret = do_mult_aead_op(data, enc, num_mb, rc);
  184. if (ret)
  185. goto out;
  186. }
  187. /* The real thing. */
  188. for (i = 0; i < 8; i++) {
  189. cycles_t start, end;
  190. start = get_cycles();
  191. ret = do_mult_aead_op(data, enc, num_mb, rc);
  192. end = get_cycles();
  193. if (ret)
  194. goto out;
  195. cycles += end - start;
  196. }
  197. pr_cont("1 operation in %lu cycles (%d bytes)\n",
  198. (cycles + 4) / (8 * num_mb), blen);
  199. out:
  200. kfree(rc);
  201. return ret;
  202. }
  203. static void test_mb_aead_speed(const char *algo, int enc, int secs,
  204. struct aead_speed_template *template,
  205. unsigned int tcount, u8 authsize,
  206. unsigned int aad_size, u8 *keysize, u32 num_mb)
  207. {
  208. struct test_mb_aead_data *data;
  209. struct crypto_aead *tfm;
  210. unsigned int i, j, iv_len;
  211. const char *key;
  212. const char *e;
  213. void *assoc;
  214. u32 *b_size;
  215. char *iv;
  216. int ret;
  217. if (aad_size >= PAGE_SIZE) {
  218. pr_err("associate data length (%u) too big\n", aad_size);
  219. return;
  220. }
  221. iv = kzalloc(MAX_IVLEN, GFP_KERNEL);
  222. if (!iv)
  223. return;
  224. if (enc == ENCRYPT)
  225. e = "encryption";
  226. else
  227. e = "decryption";
  228. data = kcalloc(num_mb, sizeof(*data), GFP_KERNEL);
  229. if (!data)
  230. goto out_free_iv;
  231. tfm = crypto_alloc_aead(algo, 0, 0);
  232. if (IS_ERR(tfm)) {
  233. pr_err("failed to load transform for %s: %ld\n",
  234. algo, PTR_ERR(tfm));
  235. goto out_free_data;
  236. }
  237. ret = crypto_aead_setauthsize(tfm, authsize);
  238. for (i = 0; i < num_mb; ++i)
  239. if (testmgr_alloc_buf(data[i].xbuf)) {
  240. while (i--)
  241. testmgr_free_buf(data[i].xbuf);
  242. goto out_free_tfm;
  243. }
  244. for (i = 0; i < num_mb; ++i)
  245. if (testmgr_alloc_buf(data[i].axbuf)) {
  246. while (i--)
  247. testmgr_free_buf(data[i].axbuf);
  248. goto out_free_xbuf;
  249. }
  250. for (i = 0; i < num_mb; ++i)
  251. if (testmgr_alloc_buf(data[i].xoutbuf)) {
  252. while (i--)
  253. testmgr_free_buf(data[i].xoutbuf);
  254. goto out_free_axbuf;
  255. }
  256. for (i = 0; i < num_mb; ++i) {
  257. data[i].req = aead_request_alloc(tfm, GFP_KERNEL);
  258. if (!data[i].req) {
  259. pr_err("alg: skcipher: Failed to allocate request for %s\n",
  260. algo);
  261. while (i--)
  262. aead_request_free(data[i].req);
  263. goto out_free_xoutbuf;
  264. }
  265. }
  266. for (i = 0; i < num_mb; ++i) {
  267. crypto_init_wait(&data[i].wait);
  268. aead_request_set_callback(data[i].req,
  269. CRYPTO_TFM_REQ_MAY_BACKLOG,
  270. crypto_req_done, &data[i].wait);
  271. }
  272. pr_info("\ntesting speed of multibuffer %s (%s) %s\n", algo,
  273. get_driver_name(crypto_aead, tfm), e);
  274. i = 0;
  275. do {
  276. b_size = aead_sizes;
  277. do {
  278. if (*b_size + authsize > XBUFSIZE * PAGE_SIZE) {
  279. pr_err("template (%u) too big for buffer (%lu)\n",
  280. authsize + *b_size,
  281. XBUFSIZE * PAGE_SIZE);
  282. goto out;
  283. }
  284. pr_info("test %u (%d bit key, %d byte blocks): ", i,
  285. *keysize * 8, *b_size);
  286. /* Set up tfm global state, i.e. the key */
  287. memset(tvmem[0], 0xff, PAGE_SIZE);
  288. key = tvmem[0];
  289. for (j = 0; j < tcount; j++) {
  290. if (template[j].klen == *keysize) {
  291. key = template[j].key;
  292. break;
  293. }
  294. }
  295. crypto_aead_clear_flags(tfm, ~0);
  296. ret = crypto_aead_setkey(tfm, key, *keysize);
  297. if (ret) {
  298. pr_err("setkey() failed flags=%x\n",
  299. crypto_aead_get_flags(tfm));
  300. goto out;
  301. }
  302. iv_len = crypto_aead_ivsize(tfm);
  303. if (iv_len)
  304. memset(iv, 0xff, iv_len);
  305. /* Now setup per request stuff, i.e. buffers */
  306. for (j = 0; j < num_mb; ++j) {
  307. struct test_mb_aead_data *cur = &data[j];
  308. assoc = cur->axbuf[0];
  309. memset(assoc, 0xff, aad_size);
  310. sg_init_aead(cur->sg, cur->xbuf,
  311. *b_size + (enc ? 0 : authsize),
  312. assoc, aad_size);
  313. sg_init_aead(cur->sgout, cur->xoutbuf,
  314. *b_size + (enc ? authsize : 0),
  315. assoc, aad_size);
  316. aead_request_set_ad(cur->req, aad_size);
  317. if (!enc) {
  318. aead_request_set_crypt(cur->req,
  319. cur->sgout,
  320. cur->sg,
  321. *b_size, iv);
  322. ret = crypto_aead_encrypt(cur->req);
  323. ret = do_one_aead_op(cur->req, ret);
  324. if (ret) {
  325. pr_err("calculating auth failed failed (%d)\n",
  326. ret);
  327. break;
  328. }
  329. }
  330. aead_request_set_crypt(cur->req, cur->sg,
  331. cur->sgout, *b_size +
  332. (enc ? 0 : authsize),
  333. iv);
  334. }
  335. if (secs) {
  336. ret = test_mb_aead_jiffies(data, enc, *b_size,
  337. secs, num_mb);
  338. cond_resched();
  339. } else {
  340. ret = test_mb_aead_cycles(data, enc, *b_size,
  341. num_mb);
  342. }
  343. if (ret) {
  344. pr_err("%s() failed return code=%d\n", e, ret);
  345. break;
  346. }
  347. b_size++;
  348. i++;
  349. } while (*b_size);
  350. keysize++;
  351. } while (*keysize);
  352. out:
  353. for (i = 0; i < num_mb; ++i)
  354. aead_request_free(data[i].req);
  355. out_free_xoutbuf:
  356. for (i = 0; i < num_mb; ++i)
  357. testmgr_free_buf(data[i].xoutbuf);
  358. out_free_axbuf:
  359. for (i = 0; i < num_mb; ++i)
  360. testmgr_free_buf(data[i].axbuf);
  361. out_free_xbuf:
  362. for (i = 0; i < num_mb; ++i)
  363. testmgr_free_buf(data[i].xbuf);
  364. out_free_tfm:
  365. crypto_free_aead(tfm);
  366. out_free_data:
  367. kfree(data);
  368. out_free_iv:
  369. kfree(iv);
  370. }
  371. static int test_aead_jiffies(struct aead_request *req, int enc,
  372. int blen, int secs)
  373. {
  374. unsigned long start, end;
  375. int bcount;
  376. int ret;
  377. for (start = jiffies, end = start + secs * HZ, bcount = 0;
  378. time_before(jiffies, end); bcount++) {
  379. if (enc)
  380. ret = do_one_aead_op(req, crypto_aead_encrypt(req));
  381. else
  382. ret = do_one_aead_op(req, crypto_aead_decrypt(req));
  383. if (ret)
  384. return ret;
  385. }
  386. pr_cont("%d operations in %d seconds (%llu bytes)\n",
  387. bcount, secs, (u64)bcount * blen);
  388. return 0;
  389. }
  390. static int test_aead_cycles(struct aead_request *req, int enc, int blen)
  391. {
  392. unsigned long cycles = 0;
  393. int ret = 0;
  394. int i;
  395. /* Warm-up run. */
  396. for (i = 0; i < 4; i++) {
  397. if (enc)
  398. ret = do_one_aead_op(req, crypto_aead_encrypt(req));
  399. else
  400. ret = do_one_aead_op(req, crypto_aead_decrypt(req));
  401. if (ret)
  402. goto out;
  403. }
  404. /* The real thing. */
  405. for (i = 0; i < 8; i++) {
  406. cycles_t start, end;
  407. start = get_cycles();
  408. if (enc)
  409. ret = do_one_aead_op(req, crypto_aead_encrypt(req));
  410. else
  411. ret = do_one_aead_op(req, crypto_aead_decrypt(req));
  412. end = get_cycles();
  413. if (ret)
  414. goto out;
  415. cycles += end - start;
  416. }
  417. out:
  418. if (ret == 0)
  419. printk("1 operation in %lu cycles (%d bytes)\n",
  420. (cycles + 4) / 8, blen);
  421. return ret;
  422. }
  423. static void test_aead_speed(const char *algo, int enc, unsigned int secs,
  424. struct aead_speed_template *template,
  425. unsigned int tcount, u8 authsize,
  426. unsigned int aad_size, u8 *keysize)
  427. {
  428. unsigned int i, j;
  429. struct crypto_aead *tfm;
  430. int ret = -ENOMEM;
  431. const char *key;
  432. struct aead_request *req;
  433. struct scatterlist *sg;
  434. struct scatterlist *sgout;
  435. const char *e;
  436. void *assoc;
  437. char *iv;
  438. char *xbuf[XBUFSIZE];
  439. char *xoutbuf[XBUFSIZE];
  440. char *axbuf[XBUFSIZE];
  441. unsigned int *b_size;
  442. unsigned int iv_len;
  443. struct crypto_wait wait;
  444. iv = kzalloc(MAX_IVLEN, GFP_KERNEL);
  445. if (!iv)
  446. return;
  447. if (aad_size >= PAGE_SIZE) {
  448. pr_err("associate data length (%u) too big\n", aad_size);
  449. goto out_noxbuf;
  450. }
  451. if (enc == ENCRYPT)
  452. e = "encryption";
  453. else
  454. e = "decryption";
  455. if (testmgr_alloc_buf(xbuf))
  456. goto out_noxbuf;
  457. if (testmgr_alloc_buf(axbuf))
  458. goto out_noaxbuf;
  459. if (testmgr_alloc_buf(xoutbuf))
  460. goto out_nooutbuf;
  461. sg = kmalloc(sizeof(*sg) * 9 * 2, GFP_KERNEL);
  462. if (!sg)
  463. goto out_nosg;
  464. sgout = &sg[9];
  465. tfm = crypto_alloc_aead(algo, 0, 0);
  466. if (IS_ERR(tfm)) {
  467. pr_err("alg: aead: Failed to load transform for %s: %ld\n", algo,
  468. PTR_ERR(tfm));
  469. goto out_notfm;
  470. }
  471. crypto_init_wait(&wait);
  472. printk(KERN_INFO "\ntesting speed of %s (%s) %s\n", algo,
  473. get_driver_name(crypto_aead, tfm), e);
  474. req = aead_request_alloc(tfm, GFP_KERNEL);
  475. if (!req) {
  476. pr_err("alg: aead: Failed to allocate request for %s\n",
  477. algo);
  478. goto out_noreq;
  479. }
  480. aead_request_set_callback(req, CRYPTO_TFM_REQ_MAY_BACKLOG,
  481. crypto_req_done, &wait);
  482. i = 0;
  483. do {
  484. b_size = aead_sizes;
  485. do {
  486. assoc = axbuf[0];
  487. memset(assoc, 0xff, aad_size);
  488. if ((*keysize + *b_size) > TVMEMSIZE * PAGE_SIZE) {
  489. pr_err("template (%u) too big for tvmem (%lu)\n",
  490. *keysize + *b_size,
  491. TVMEMSIZE * PAGE_SIZE);
  492. goto out;
  493. }
  494. key = tvmem[0];
  495. for (j = 0; j < tcount; j++) {
  496. if (template[j].klen == *keysize) {
  497. key = template[j].key;
  498. break;
  499. }
  500. }
  501. ret = crypto_aead_setkey(tfm, key, *keysize);
  502. ret = crypto_aead_setauthsize(tfm, authsize);
  503. iv_len = crypto_aead_ivsize(tfm);
  504. if (iv_len)
  505. memset(iv, 0xff, iv_len);
  506. crypto_aead_clear_flags(tfm, ~0);
  507. printk(KERN_INFO "test %u (%d bit key, %d byte blocks): ",
  508. i, *keysize * 8, *b_size);
  509. memset(tvmem[0], 0xff, PAGE_SIZE);
  510. if (ret) {
  511. pr_err("setkey() failed flags=%x\n",
  512. crypto_aead_get_flags(tfm));
  513. goto out;
  514. }
  515. sg_init_aead(sg, xbuf, *b_size + (enc ? 0 : authsize),
  516. assoc, aad_size);
  517. sg_init_aead(sgout, xoutbuf,
  518. *b_size + (enc ? authsize : 0), assoc,
  519. aad_size);
  520. aead_request_set_ad(req, aad_size);
  521. if (!enc) {
  522. /*
  523. * For decryption we need a proper auth so
  524. * we do the encryption path once with buffers
  525. * reversed (input <-> output) to calculate it
  526. */
  527. aead_request_set_crypt(req, sgout, sg,
  528. *b_size, iv);
  529. ret = do_one_aead_op(req,
  530. crypto_aead_encrypt(req));
  531. if (ret) {
  532. pr_err("calculating auth failed failed (%d)\n",
  533. ret);
  534. break;
  535. }
  536. }
  537. aead_request_set_crypt(req, sg, sgout,
  538. *b_size + (enc ? 0 : authsize),
  539. iv);
  540. if (secs) {
  541. ret = test_aead_jiffies(req, enc, *b_size,
  542. secs);
  543. cond_resched();
  544. } else {
  545. ret = test_aead_cycles(req, enc, *b_size);
  546. }
  547. if (ret) {
  548. pr_err("%s() failed return code=%d\n", e, ret);
  549. break;
  550. }
  551. b_size++;
  552. i++;
  553. } while (*b_size);
  554. keysize++;
  555. } while (*keysize);
  556. out:
  557. aead_request_free(req);
  558. out_noreq:
  559. crypto_free_aead(tfm);
  560. out_notfm:
  561. kfree(sg);
  562. out_nosg:
  563. testmgr_free_buf(xoutbuf);
  564. out_nooutbuf:
  565. testmgr_free_buf(axbuf);
  566. out_noaxbuf:
  567. testmgr_free_buf(xbuf);
  568. out_noxbuf:
  569. kfree(iv);
  570. }
  571. static void test_hash_sg_init(struct scatterlist *sg)
  572. {
  573. int i;
  574. sg_init_table(sg, TVMEMSIZE);
  575. for (i = 0; i < TVMEMSIZE; i++) {
  576. sg_set_buf(sg + i, tvmem[i], PAGE_SIZE);
  577. memset(tvmem[i], 0xff, PAGE_SIZE);
  578. }
  579. }
  580. static inline int do_one_ahash_op(struct ahash_request *req, int ret)
  581. {
  582. struct crypto_wait *wait = req->base.data;
  583. return crypto_wait_req(ret, wait);
  584. }
  585. struct test_mb_ahash_data {
  586. struct scatterlist sg[XBUFSIZE];
  587. char result[64];
  588. struct ahash_request *req;
  589. struct crypto_wait wait;
  590. char *xbuf[XBUFSIZE];
  591. };
  592. static inline int do_mult_ahash_op(struct test_mb_ahash_data *data, u32 num_mb,
  593. int *rc)
  594. {
  595. int i, err = 0;
  596. /* Fire up a bunch of concurrent requests */
  597. for (i = 0; i < num_mb; i++)
  598. rc[i] = crypto_ahash_digest(data[i].req);
  599. /* Wait for all requests to finish */
  600. for (i = 0; i < num_mb; i++) {
  601. rc[i] = crypto_wait_req(rc[i], &data[i].wait);
  602. if (rc[i]) {
  603. pr_info("concurrent request %d error %d\n", i, rc[i]);
  604. err = rc[i];
  605. }
  606. }
  607. return err;
  608. }
  609. static int test_mb_ahash_jiffies(struct test_mb_ahash_data *data, int blen,
  610. int secs, u32 num_mb)
  611. {
  612. unsigned long start, end;
  613. int bcount;
  614. int ret = 0;
  615. int *rc;
  616. rc = kcalloc(num_mb, sizeof(*rc), GFP_KERNEL);
  617. if (!rc)
  618. return -ENOMEM;
  619. for (start = jiffies, end = start + secs * HZ, bcount = 0;
  620. time_before(jiffies, end); bcount++) {
  621. ret = do_mult_ahash_op(data, num_mb, rc);
  622. if (ret)
  623. goto out;
  624. }
  625. pr_cont("%d operations in %d seconds (%llu bytes)\n",
  626. bcount * num_mb, secs, (u64)bcount * blen * num_mb);
  627. out:
  628. kfree(rc);
  629. return ret;
  630. }
  631. static int test_mb_ahash_cycles(struct test_mb_ahash_data *data, int blen,
  632. u32 num_mb)
  633. {
  634. unsigned long cycles = 0;
  635. int ret = 0;
  636. int i;
  637. int *rc;
  638. rc = kcalloc(num_mb, sizeof(*rc), GFP_KERNEL);
  639. if (!rc)
  640. return -ENOMEM;
  641. /* Warm-up run. */
  642. for (i = 0; i < 4; i++) {
  643. ret = do_mult_ahash_op(data, num_mb, rc);
  644. if (ret)
  645. goto out;
  646. }
  647. /* The real thing. */
  648. for (i = 0; i < 8; i++) {
  649. cycles_t start, end;
  650. start = get_cycles();
  651. ret = do_mult_ahash_op(data, num_mb, rc);
  652. end = get_cycles();
  653. if (ret)
  654. goto out;
  655. cycles += end - start;
  656. }
  657. pr_cont("1 operation in %lu cycles (%d bytes)\n",
  658. (cycles + 4) / (8 * num_mb), blen);
  659. out:
  660. kfree(rc);
  661. return ret;
  662. }
  663. static void test_mb_ahash_speed(const char *algo, unsigned int secs,
  664. struct hash_speed *speed, u32 num_mb)
  665. {
  666. struct test_mb_ahash_data *data;
  667. struct crypto_ahash *tfm;
  668. unsigned int i, j, k;
  669. int ret;
  670. data = kcalloc(num_mb, sizeof(*data), GFP_KERNEL);
  671. if (!data)
  672. return;
  673. tfm = crypto_alloc_ahash(algo, 0, 0);
  674. if (IS_ERR(tfm)) {
  675. pr_err("failed to load transform for %s: %ld\n",
  676. algo, PTR_ERR(tfm));
  677. goto free_data;
  678. }
  679. for (i = 0; i < num_mb; ++i) {
  680. if (testmgr_alloc_buf(data[i].xbuf))
  681. goto out;
  682. crypto_init_wait(&data[i].wait);
  683. data[i].req = ahash_request_alloc(tfm, GFP_KERNEL);
  684. if (!data[i].req) {
  685. pr_err("alg: hash: Failed to allocate request for %s\n",
  686. algo);
  687. goto out;
  688. }
  689. ahash_request_set_callback(data[i].req, 0, crypto_req_done,
  690. &data[i].wait);
  691. sg_init_table(data[i].sg, XBUFSIZE);
  692. for (j = 0; j < XBUFSIZE; j++) {
  693. sg_set_buf(data[i].sg + j, data[i].xbuf[j], PAGE_SIZE);
  694. memset(data[i].xbuf[j], 0xff, PAGE_SIZE);
  695. }
  696. }
  697. pr_info("\ntesting speed of multibuffer %s (%s)\n", algo,
  698. get_driver_name(crypto_ahash, tfm));
  699. for (i = 0; speed[i].blen != 0; i++) {
  700. /* For some reason this only tests digests. */
  701. if (speed[i].blen != speed[i].plen)
  702. continue;
  703. if (speed[i].blen > XBUFSIZE * PAGE_SIZE) {
  704. pr_err("template (%u) too big for tvmem (%lu)\n",
  705. speed[i].blen, XBUFSIZE * PAGE_SIZE);
  706. goto out;
  707. }
  708. if (speed[i].klen)
  709. crypto_ahash_setkey(tfm, tvmem[0], speed[i].klen);
  710. for (k = 0; k < num_mb; k++)
  711. ahash_request_set_crypt(data[k].req, data[k].sg,
  712. data[k].result, speed[i].blen);
  713. pr_info("test%3u "
  714. "(%5u byte blocks,%5u bytes per update,%4u updates): ",
  715. i, speed[i].blen, speed[i].plen,
  716. speed[i].blen / speed[i].plen);
  717. if (secs) {
  718. ret = test_mb_ahash_jiffies(data, speed[i].blen, secs,
  719. num_mb);
  720. cond_resched();
  721. } else {
  722. ret = test_mb_ahash_cycles(data, speed[i].blen, num_mb);
  723. }
  724. if (ret) {
  725. pr_err("At least one hashing failed ret=%d\n", ret);
  726. break;
  727. }
  728. }
  729. out:
  730. for (k = 0; k < num_mb; ++k)
  731. ahash_request_free(data[k].req);
  732. for (k = 0; k < num_mb; ++k)
  733. testmgr_free_buf(data[k].xbuf);
  734. crypto_free_ahash(tfm);
  735. free_data:
  736. kfree(data);
  737. }
  738. static int test_ahash_jiffies_digest(struct ahash_request *req, int blen,
  739. char *out, int secs)
  740. {
  741. unsigned long start, end;
  742. int bcount;
  743. int ret;
  744. for (start = jiffies, end = start + secs * HZ, bcount = 0;
  745. time_before(jiffies, end); bcount++) {
  746. ret = do_one_ahash_op(req, crypto_ahash_digest(req));
  747. if (ret)
  748. return ret;
  749. }
  750. printk("%6u opers/sec, %9lu bytes/sec\n",
  751. bcount / secs, ((long)bcount * blen) / secs);
  752. return 0;
  753. }
  754. static int test_ahash_jiffies(struct ahash_request *req, int blen,
  755. int plen, char *out, int secs)
  756. {
  757. unsigned long start, end;
  758. int bcount, pcount;
  759. int ret;
  760. if (plen == blen)
  761. return test_ahash_jiffies_digest(req, blen, out, secs);
  762. for (start = jiffies, end = start + secs * HZ, bcount = 0;
  763. time_before(jiffies, end); bcount++) {
  764. ret = do_one_ahash_op(req, crypto_ahash_init(req));
  765. if (ret)
  766. return ret;
  767. for (pcount = 0; pcount < blen; pcount += plen) {
  768. ret = do_one_ahash_op(req, crypto_ahash_update(req));
  769. if (ret)
  770. return ret;
  771. }
  772. /* we assume there is enough space in 'out' for the result */
  773. ret = do_one_ahash_op(req, crypto_ahash_final(req));
  774. if (ret)
  775. return ret;
  776. }
  777. pr_cont("%6u opers/sec, %9lu bytes/sec\n",
  778. bcount / secs, ((long)bcount * blen) / secs);
  779. return 0;
  780. }
  781. static int test_ahash_cycles_digest(struct ahash_request *req, int blen,
  782. char *out)
  783. {
  784. unsigned long cycles = 0;
  785. int ret, i;
  786. /* Warm-up run. */
  787. for (i = 0; i < 4; i++) {
  788. ret = do_one_ahash_op(req, crypto_ahash_digest(req));
  789. if (ret)
  790. goto out;
  791. }
  792. /* The real thing. */
  793. for (i = 0; i < 8; i++) {
  794. cycles_t start, end;
  795. start = get_cycles();
  796. ret = do_one_ahash_op(req, crypto_ahash_digest(req));
  797. if (ret)
  798. goto out;
  799. end = get_cycles();
  800. cycles += end - start;
  801. }
  802. out:
  803. if (ret)
  804. return ret;
  805. pr_cont("%6lu cycles/operation, %4lu cycles/byte\n",
  806. cycles / 8, cycles / (8 * blen));
  807. return 0;
  808. }
  809. static int test_ahash_cycles(struct ahash_request *req, int blen,
  810. int plen, char *out)
  811. {
  812. unsigned long cycles = 0;
  813. int i, pcount, ret;
  814. if (plen == blen)
  815. return test_ahash_cycles_digest(req, blen, out);
  816. /* Warm-up run. */
  817. for (i = 0; i < 4; i++) {
  818. ret = do_one_ahash_op(req, crypto_ahash_init(req));
  819. if (ret)
  820. goto out;
  821. for (pcount = 0; pcount < blen; pcount += plen) {
  822. ret = do_one_ahash_op(req, crypto_ahash_update(req));
  823. if (ret)
  824. goto out;
  825. }
  826. ret = do_one_ahash_op(req, crypto_ahash_final(req));
  827. if (ret)
  828. goto out;
  829. }
  830. /* The real thing. */
  831. for (i = 0; i < 8; i++) {
  832. cycles_t start, end;
  833. start = get_cycles();
  834. ret = do_one_ahash_op(req, crypto_ahash_init(req));
  835. if (ret)
  836. goto out;
  837. for (pcount = 0; pcount < blen; pcount += plen) {
  838. ret = do_one_ahash_op(req, crypto_ahash_update(req));
  839. if (ret)
  840. goto out;
  841. }
  842. ret = do_one_ahash_op(req, crypto_ahash_final(req));
  843. if (ret)
  844. goto out;
  845. end = get_cycles();
  846. cycles += end - start;
  847. }
  848. out:
  849. if (ret)
  850. return ret;
  851. pr_cont("%6lu cycles/operation, %4lu cycles/byte\n",
  852. cycles / 8, cycles / (8 * blen));
  853. return 0;
  854. }
  855. static void test_ahash_speed_common(const char *algo, unsigned int secs,
  856. struct hash_speed *speed, unsigned mask)
  857. {
  858. struct scatterlist sg[TVMEMSIZE];
  859. struct crypto_wait wait;
  860. struct ahash_request *req;
  861. struct crypto_ahash *tfm;
  862. char *output;
  863. int i, ret;
  864. tfm = crypto_alloc_ahash(algo, 0, mask);
  865. if (IS_ERR(tfm)) {
  866. pr_err("failed to load transform for %s: %ld\n",
  867. algo, PTR_ERR(tfm));
  868. return;
  869. }
  870. printk(KERN_INFO "\ntesting speed of async %s (%s)\n", algo,
  871. get_driver_name(crypto_ahash, tfm));
  872. if (crypto_ahash_digestsize(tfm) > MAX_DIGEST_SIZE) {
  873. pr_err("digestsize(%u) > %d\n", crypto_ahash_digestsize(tfm),
  874. MAX_DIGEST_SIZE);
  875. goto out;
  876. }
  877. test_hash_sg_init(sg);
  878. req = ahash_request_alloc(tfm, GFP_KERNEL);
  879. if (!req) {
  880. pr_err("ahash request allocation failure\n");
  881. goto out;
  882. }
  883. crypto_init_wait(&wait);
  884. ahash_request_set_callback(req, CRYPTO_TFM_REQ_MAY_BACKLOG,
  885. crypto_req_done, &wait);
  886. output = kmalloc(MAX_DIGEST_SIZE, GFP_KERNEL);
  887. if (!output)
  888. goto out_nomem;
  889. for (i = 0; speed[i].blen != 0; i++) {
  890. if (speed[i].blen > TVMEMSIZE * PAGE_SIZE) {
  891. pr_err("template (%u) too big for tvmem (%lu)\n",
  892. speed[i].blen, TVMEMSIZE * PAGE_SIZE);
  893. break;
  894. }
  895. if (speed[i].klen)
  896. crypto_ahash_setkey(tfm, tvmem[0], speed[i].klen);
  897. pr_info("test%3u "
  898. "(%5u byte blocks,%5u bytes per update,%4u updates): ",
  899. i, speed[i].blen, speed[i].plen, speed[i].blen / speed[i].plen);
  900. ahash_request_set_crypt(req, sg, output, speed[i].plen);
  901. if (secs) {
  902. ret = test_ahash_jiffies(req, speed[i].blen,
  903. speed[i].plen, output, secs);
  904. cond_resched();
  905. } else {
  906. ret = test_ahash_cycles(req, speed[i].blen,
  907. speed[i].plen, output);
  908. }
  909. if (ret) {
  910. pr_err("hashing failed ret=%d\n", ret);
  911. break;
  912. }
  913. }
  914. kfree(output);
  915. out_nomem:
  916. ahash_request_free(req);
  917. out:
  918. crypto_free_ahash(tfm);
  919. }
  920. static void test_ahash_speed(const char *algo, unsigned int secs,
  921. struct hash_speed *speed)
  922. {
  923. return test_ahash_speed_common(algo, secs, speed, 0);
  924. }
  925. static void test_hash_speed(const char *algo, unsigned int secs,
  926. struct hash_speed *speed)
  927. {
  928. return test_ahash_speed_common(algo, secs, speed, CRYPTO_ALG_ASYNC);
  929. }
  930. struct test_mb_skcipher_data {
  931. struct scatterlist sg[XBUFSIZE];
  932. struct skcipher_request *req;
  933. struct crypto_wait wait;
  934. char *xbuf[XBUFSIZE];
  935. };
  936. static int do_mult_acipher_op(struct test_mb_skcipher_data *data, int enc,
  937. u32 num_mb, int *rc)
  938. {
  939. int i, err = 0;
  940. /* Fire up a bunch of concurrent requests */
  941. for (i = 0; i < num_mb; i++) {
  942. if (enc == ENCRYPT)
  943. rc[i] = crypto_skcipher_encrypt(data[i].req);
  944. else
  945. rc[i] = crypto_skcipher_decrypt(data[i].req);
  946. }
  947. /* Wait for all requests to finish */
  948. for (i = 0; i < num_mb; i++) {
  949. rc[i] = crypto_wait_req(rc[i], &data[i].wait);
  950. if (rc[i]) {
  951. pr_info("concurrent request %d error %d\n", i, rc[i]);
  952. err = rc[i];
  953. }
  954. }
  955. return err;
  956. }
  957. static int test_mb_acipher_jiffies(struct test_mb_skcipher_data *data, int enc,
  958. int blen, int secs, u32 num_mb)
  959. {
  960. unsigned long start, end;
  961. int bcount;
  962. int ret = 0;
  963. int *rc;
  964. rc = kcalloc(num_mb, sizeof(*rc), GFP_KERNEL);
  965. if (!rc)
  966. return -ENOMEM;
  967. for (start = jiffies, end = start + secs * HZ, bcount = 0;
  968. time_before(jiffies, end); bcount++) {
  969. ret = do_mult_acipher_op(data, enc, num_mb, rc);
  970. if (ret)
  971. goto out;
  972. }
  973. pr_cont("%d operations in %d seconds (%llu bytes)\n",
  974. bcount * num_mb, secs, (u64)bcount * blen * num_mb);
  975. out:
  976. kfree(rc);
  977. return ret;
  978. }
  979. static int test_mb_acipher_cycles(struct test_mb_skcipher_data *data, int enc,
  980. int blen, u32 num_mb)
  981. {
  982. unsigned long cycles = 0;
  983. int ret = 0;
  984. int i;
  985. int *rc;
  986. rc = kcalloc(num_mb, sizeof(*rc), GFP_KERNEL);
  987. if (!rc)
  988. return -ENOMEM;
  989. /* Warm-up run. */
  990. for (i = 0; i < 4; i++) {
  991. ret = do_mult_acipher_op(data, enc, num_mb, rc);
  992. if (ret)
  993. goto out;
  994. }
  995. /* The real thing. */
  996. for (i = 0; i < 8; i++) {
  997. cycles_t start, end;
  998. start = get_cycles();
  999. ret = do_mult_acipher_op(data, enc, num_mb, rc);
  1000. end = get_cycles();
  1001. if (ret)
  1002. goto out;
  1003. cycles += end - start;
  1004. }
  1005. pr_cont("1 operation in %lu cycles (%d bytes)\n",
  1006. (cycles + 4) / (8 * num_mb), blen);
  1007. out:
  1008. kfree(rc);
  1009. return ret;
  1010. }
  1011. static void test_mb_skcipher_speed(const char *algo, int enc, int secs,
  1012. struct cipher_speed_template *template,
  1013. unsigned int tcount, u8 *keysize, u32 num_mb)
  1014. {
  1015. struct test_mb_skcipher_data *data;
  1016. struct crypto_skcipher *tfm;
  1017. unsigned int i, j, iv_len;
  1018. const char *key;
  1019. const char *e;
  1020. u32 *b_size;
  1021. char iv[128];
  1022. int ret;
  1023. if (enc == ENCRYPT)
  1024. e = "encryption";
  1025. else
  1026. e = "decryption";
  1027. data = kcalloc(num_mb, sizeof(*data), GFP_KERNEL);
  1028. if (!data)
  1029. return;
  1030. tfm = crypto_alloc_skcipher(algo, 0, 0);
  1031. if (IS_ERR(tfm)) {
  1032. pr_err("failed to load transform for %s: %ld\n",
  1033. algo, PTR_ERR(tfm));
  1034. goto out_free_data;
  1035. }
  1036. for (i = 0; i < num_mb; ++i)
  1037. if (testmgr_alloc_buf(data[i].xbuf)) {
  1038. while (i--)
  1039. testmgr_free_buf(data[i].xbuf);
  1040. goto out_free_tfm;
  1041. }
  1042. for (i = 0; i < num_mb; ++i)
  1043. if (testmgr_alloc_buf(data[i].xbuf)) {
  1044. while (i--)
  1045. testmgr_free_buf(data[i].xbuf);
  1046. goto out_free_tfm;
  1047. }
  1048. for (i = 0; i < num_mb; ++i) {
  1049. data[i].req = skcipher_request_alloc(tfm, GFP_KERNEL);
  1050. if (!data[i].req) {
  1051. pr_err("alg: skcipher: Failed to allocate request for %s\n",
  1052. algo);
  1053. while (i--)
  1054. skcipher_request_free(data[i].req);
  1055. goto out_free_xbuf;
  1056. }
  1057. }
  1058. for (i = 0; i < num_mb; ++i) {
  1059. skcipher_request_set_callback(data[i].req,
  1060. CRYPTO_TFM_REQ_MAY_BACKLOG,
  1061. crypto_req_done, &data[i].wait);
  1062. crypto_init_wait(&data[i].wait);
  1063. }
  1064. pr_info("\ntesting speed of multibuffer %s (%s) %s\n", algo,
  1065. get_driver_name(crypto_skcipher, tfm), e);
  1066. i = 0;
  1067. do {
  1068. b_size = block_sizes;
  1069. do {
  1070. if (*b_size > XBUFSIZE * PAGE_SIZE) {
  1071. pr_err("template (%u) too big for buffer (%lu)\n",
  1072. *b_size, XBUFSIZE * PAGE_SIZE);
  1073. goto out;
  1074. }
  1075. pr_info("test %u (%d bit key, %d byte blocks): ", i,
  1076. *keysize * 8, *b_size);
  1077. /* Set up tfm global state, i.e. the key */
  1078. memset(tvmem[0], 0xff, PAGE_SIZE);
  1079. key = tvmem[0];
  1080. for (j = 0; j < tcount; j++) {
  1081. if (template[j].klen == *keysize) {
  1082. key = template[j].key;
  1083. break;
  1084. }
  1085. }
  1086. crypto_skcipher_clear_flags(tfm, ~0);
  1087. ret = crypto_skcipher_setkey(tfm, key, *keysize);
  1088. if (ret) {
  1089. pr_err("setkey() failed flags=%x\n",
  1090. crypto_skcipher_get_flags(tfm));
  1091. goto out;
  1092. }
  1093. iv_len = crypto_skcipher_ivsize(tfm);
  1094. if (iv_len)
  1095. memset(&iv, 0xff, iv_len);
  1096. /* Now setup per request stuff, i.e. buffers */
  1097. for (j = 0; j < num_mb; ++j) {
  1098. struct test_mb_skcipher_data *cur = &data[j];
  1099. unsigned int k = *b_size;
  1100. unsigned int pages = DIV_ROUND_UP(k, PAGE_SIZE);
  1101. unsigned int p = 0;
  1102. sg_init_table(cur->sg, pages);
  1103. while (k > PAGE_SIZE) {
  1104. sg_set_buf(cur->sg + p, cur->xbuf[p],
  1105. PAGE_SIZE);
  1106. memset(cur->xbuf[p], 0xff, PAGE_SIZE);
  1107. p++;
  1108. k -= PAGE_SIZE;
  1109. }
  1110. sg_set_buf(cur->sg + p, cur->xbuf[p], k);
  1111. memset(cur->xbuf[p], 0xff, k);
  1112. skcipher_request_set_crypt(cur->req, cur->sg,
  1113. cur->sg, *b_size,
  1114. iv);
  1115. }
  1116. if (secs) {
  1117. ret = test_mb_acipher_jiffies(data, enc,
  1118. *b_size, secs,
  1119. num_mb);
  1120. cond_resched();
  1121. } else {
  1122. ret = test_mb_acipher_cycles(data, enc,
  1123. *b_size, num_mb);
  1124. }
  1125. if (ret) {
  1126. pr_err("%s() failed flags=%x\n", e,
  1127. crypto_skcipher_get_flags(tfm));
  1128. break;
  1129. }
  1130. b_size++;
  1131. i++;
  1132. } while (*b_size);
  1133. keysize++;
  1134. } while (*keysize);
  1135. out:
  1136. for (i = 0; i < num_mb; ++i)
  1137. skcipher_request_free(data[i].req);
  1138. out_free_xbuf:
  1139. for (i = 0; i < num_mb; ++i)
  1140. testmgr_free_buf(data[i].xbuf);
  1141. out_free_tfm:
  1142. crypto_free_skcipher(tfm);
  1143. out_free_data:
  1144. kfree(data);
  1145. }
  1146. static inline int do_one_acipher_op(struct skcipher_request *req, int ret)
  1147. {
  1148. struct crypto_wait *wait = req->base.data;
  1149. return crypto_wait_req(ret, wait);
  1150. }
  1151. static int test_acipher_jiffies(struct skcipher_request *req, int enc,
  1152. int blen, int secs)
  1153. {
  1154. unsigned long start, end;
  1155. int bcount;
  1156. int ret;
  1157. for (start = jiffies, end = start + secs * HZ, bcount = 0;
  1158. time_before(jiffies, end); bcount++) {
  1159. if (enc)
  1160. ret = do_one_acipher_op(req,
  1161. crypto_skcipher_encrypt(req));
  1162. else
  1163. ret = do_one_acipher_op(req,
  1164. crypto_skcipher_decrypt(req));
  1165. if (ret)
  1166. return ret;
  1167. }
  1168. pr_cont("%d operations in %d seconds (%llu bytes)\n",
  1169. bcount, secs, (u64)bcount * blen);
  1170. return 0;
  1171. }
  1172. static int test_acipher_cycles(struct skcipher_request *req, int enc,
  1173. int blen)
  1174. {
  1175. unsigned long cycles = 0;
  1176. int ret = 0;
  1177. int i;
  1178. /* Warm-up run. */
  1179. for (i = 0; i < 4; i++) {
  1180. if (enc)
  1181. ret = do_one_acipher_op(req,
  1182. crypto_skcipher_encrypt(req));
  1183. else
  1184. ret = do_one_acipher_op(req,
  1185. crypto_skcipher_decrypt(req));
  1186. if (ret)
  1187. goto out;
  1188. }
  1189. /* The real thing. */
  1190. for (i = 0; i < 8; i++) {
  1191. cycles_t start, end;
  1192. start = get_cycles();
  1193. if (enc)
  1194. ret = do_one_acipher_op(req,
  1195. crypto_skcipher_encrypt(req));
  1196. else
  1197. ret = do_one_acipher_op(req,
  1198. crypto_skcipher_decrypt(req));
  1199. end = get_cycles();
  1200. if (ret)
  1201. goto out;
  1202. cycles += end - start;
  1203. }
  1204. out:
  1205. if (ret == 0)
  1206. pr_cont("1 operation in %lu cycles (%d bytes)\n",
  1207. (cycles + 4) / 8, blen);
  1208. return ret;
  1209. }
  1210. static void test_skcipher_speed(const char *algo, int enc, unsigned int secs,
  1211. struct cipher_speed_template *template,
  1212. unsigned int tcount, u8 *keysize, bool async)
  1213. {
  1214. unsigned int ret, i, j, k, iv_len;
  1215. struct crypto_wait wait;
  1216. const char *key;
  1217. char iv[128];
  1218. struct skcipher_request *req;
  1219. struct crypto_skcipher *tfm;
  1220. const char *e;
  1221. u32 *b_size;
  1222. if (enc == ENCRYPT)
  1223. e = "encryption";
  1224. else
  1225. e = "decryption";
  1226. crypto_init_wait(&wait);
  1227. tfm = crypto_alloc_skcipher(algo, 0, async ? 0 : CRYPTO_ALG_ASYNC);
  1228. if (IS_ERR(tfm)) {
  1229. pr_err("failed to load transform for %s: %ld\n", algo,
  1230. PTR_ERR(tfm));
  1231. return;
  1232. }
  1233. pr_info("\ntesting speed of async %s (%s) %s\n", algo,
  1234. get_driver_name(crypto_skcipher, tfm), e);
  1235. req = skcipher_request_alloc(tfm, GFP_KERNEL);
  1236. if (!req) {
  1237. pr_err("tcrypt: skcipher: Failed to allocate request for %s\n",
  1238. algo);
  1239. goto out;
  1240. }
  1241. skcipher_request_set_callback(req, CRYPTO_TFM_REQ_MAY_BACKLOG,
  1242. crypto_req_done, &wait);
  1243. i = 0;
  1244. do {
  1245. b_size = block_sizes;
  1246. do {
  1247. struct scatterlist sg[TVMEMSIZE];
  1248. if ((*keysize + *b_size) > TVMEMSIZE * PAGE_SIZE) {
  1249. pr_err("template (%u) too big for "
  1250. "tvmem (%lu)\n", *keysize + *b_size,
  1251. TVMEMSIZE * PAGE_SIZE);
  1252. goto out_free_req;
  1253. }
  1254. pr_info("test %u (%d bit key, %d byte blocks): ", i,
  1255. *keysize * 8, *b_size);
  1256. memset(tvmem[0], 0xff, PAGE_SIZE);
  1257. /* set key, plain text and IV */
  1258. key = tvmem[0];
  1259. for (j = 0; j < tcount; j++) {
  1260. if (template[j].klen == *keysize) {
  1261. key = template[j].key;
  1262. break;
  1263. }
  1264. }
  1265. crypto_skcipher_clear_flags(tfm, ~0);
  1266. ret = crypto_skcipher_setkey(tfm, key, *keysize);
  1267. if (ret) {
  1268. pr_err("setkey() failed flags=%x\n",
  1269. crypto_skcipher_get_flags(tfm));
  1270. goto out_free_req;
  1271. }
  1272. k = *keysize + *b_size;
  1273. sg_init_table(sg, DIV_ROUND_UP(k, PAGE_SIZE));
  1274. if (k > PAGE_SIZE) {
  1275. sg_set_buf(sg, tvmem[0] + *keysize,
  1276. PAGE_SIZE - *keysize);
  1277. k -= PAGE_SIZE;
  1278. j = 1;
  1279. while (k > PAGE_SIZE) {
  1280. sg_set_buf(sg + j, tvmem[j], PAGE_SIZE);
  1281. memset(tvmem[j], 0xff, PAGE_SIZE);
  1282. j++;
  1283. k -= PAGE_SIZE;
  1284. }
  1285. sg_set_buf(sg + j, tvmem[j], k);
  1286. memset(tvmem[j], 0xff, k);
  1287. } else {
  1288. sg_set_buf(sg, tvmem[0] + *keysize, *b_size);
  1289. }
  1290. iv_len = crypto_skcipher_ivsize(tfm);
  1291. if (iv_len)
  1292. memset(&iv, 0xff, iv_len);
  1293. skcipher_request_set_crypt(req, sg, sg, *b_size, iv);
  1294. if (secs) {
  1295. ret = test_acipher_jiffies(req, enc,
  1296. *b_size, secs);
  1297. cond_resched();
  1298. } else {
  1299. ret = test_acipher_cycles(req, enc,
  1300. *b_size);
  1301. }
  1302. if (ret) {
  1303. pr_err("%s() failed flags=%x\n", e,
  1304. crypto_skcipher_get_flags(tfm));
  1305. break;
  1306. }
  1307. b_size++;
  1308. i++;
  1309. } while (*b_size);
  1310. keysize++;
  1311. } while (*keysize);
  1312. out_free_req:
  1313. skcipher_request_free(req);
  1314. out:
  1315. crypto_free_skcipher(tfm);
  1316. }
  1317. static void test_acipher_speed(const char *algo, int enc, unsigned int secs,
  1318. struct cipher_speed_template *template,
  1319. unsigned int tcount, u8 *keysize)
  1320. {
  1321. return test_skcipher_speed(algo, enc, secs, template, tcount, keysize,
  1322. true);
  1323. }
  1324. static void test_cipher_speed(const char *algo, int enc, unsigned int secs,
  1325. struct cipher_speed_template *template,
  1326. unsigned int tcount, u8 *keysize)
  1327. {
  1328. return test_skcipher_speed(algo, enc, secs, template, tcount, keysize,
  1329. false);
  1330. }
  1331. static void test_available(void)
  1332. {
  1333. char **name = check;
  1334. while (*name) {
  1335. printk("alg %s ", *name);
  1336. printk(crypto_has_alg(*name, 0, 0) ?
  1337. "found\n" : "not found\n");
  1338. name++;
  1339. }
  1340. }
  1341. static inline int tcrypt_test(const char *alg)
  1342. {
  1343. int ret;
  1344. pr_debug("testing %s\n", alg);
  1345. ret = alg_test(alg, alg, 0, 0);
  1346. /* non-fips algs return -EINVAL in fips mode */
  1347. if (fips_enabled && ret == -EINVAL)
  1348. ret = 0;
  1349. return ret;
  1350. }
  1351. static int do_test(const char *alg, u32 type, u32 mask, int m, u32 num_mb)
  1352. {
  1353. int i;
  1354. int ret = 0;
  1355. switch (m) {
  1356. case 0:
  1357. if (alg) {
  1358. if (!crypto_has_alg(alg, type,
  1359. mask ?: CRYPTO_ALG_TYPE_MASK))
  1360. ret = -ENOENT;
  1361. break;
  1362. }
  1363. for (i = 1; i < 200; i++)
  1364. ret += do_test(NULL, 0, 0, i, num_mb);
  1365. break;
  1366. case 1:
  1367. ret += tcrypt_test("md5");
  1368. break;
  1369. case 2:
  1370. ret += tcrypt_test("sha1");
  1371. break;
  1372. case 3:
  1373. ret += tcrypt_test("ecb(des)");
  1374. ret += tcrypt_test("cbc(des)");
  1375. ret += tcrypt_test("ctr(des)");
  1376. break;
  1377. case 4:
  1378. ret += tcrypt_test("ecb(des3_ede)");
  1379. ret += tcrypt_test("cbc(des3_ede)");
  1380. ret += tcrypt_test("ctr(des3_ede)");
  1381. break;
  1382. case 5:
  1383. ret += tcrypt_test("md4");
  1384. break;
  1385. case 6:
  1386. ret += tcrypt_test("sha256");
  1387. break;
  1388. case 7:
  1389. ret += tcrypt_test("ecb(blowfish)");
  1390. ret += tcrypt_test("cbc(blowfish)");
  1391. ret += tcrypt_test("ctr(blowfish)");
  1392. break;
  1393. case 8:
  1394. ret += tcrypt_test("ecb(twofish)");
  1395. ret += tcrypt_test("cbc(twofish)");
  1396. ret += tcrypt_test("ctr(twofish)");
  1397. ret += tcrypt_test("lrw(twofish)");
  1398. ret += tcrypt_test("xts(twofish)");
  1399. break;
  1400. case 9:
  1401. ret += tcrypt_test("ecb(serpent)");
  1402. ret += tcrypt_test("cbc(serpent)");
  1403. ret += tcrypt_test("ctr(serpent)");
  1404. ret += tcrypt_test("lrw(serpent)");
  1405. ret += tcrypt_test("xts(serpent)");
  1406. break;
  1407. case 10:
  1408. ret += tcrypt_test("ecb(aes)");
  1409. ret += tcrypt_test("cbc(aes)");
  1410. ret += tcrypt_test("lrw(aes)");
  1411. ret += tcrypt_test("xts(aes)");
  1412. ret += tcrypt_test("ctr(aes)");
  1413. ret += tcrypt_test("rfc3686(ctr(aes))");
  1414. ret += tcrypt_test("ofb(aes)");
  1415. ret += tcrypt_test("cfb(aes)");
  1416. break;
  1417. case 11:
  1418. ret += tcrypt_test("sha384");
  1419. break;
  1420. case 12:
  1421. ret += tcrypt_test("sha512");
  1422. break;
  1423. case 13:
  1424. ret += tcrypt_test("deflate");
  1425. break;
  1426. case 14:
  1427. ret += tcrypt_test("ecb(cast5)");
  1428. ret += tcrypt_test("cbc(cast5)");
  1429. ret += tcrypt_test("ctr(cast5)");
  1430. break;
  1431. case 15:
  1432. ret += tcrypt_test("ecb(cast6)");
  1433. ret += tcrypt_test("cbc(cast6)");
  1434. ret += tcrypt_test("ctr(cast6)");
  1435. ret += tcrypt_test("lrw(cast6)");
  1436. ret += tcrypt_test("xts(cast6)");
  1437. break;
  1438. case 16:
  1439. ret += tcrypt_test("ecb(arc4)");
  1440. break;
  1441. case 17:
  1442. ret += tcrypt_test("michael_mic");
  1443. break;
  1444. case 18:
  1445. ret += tcrypt_test("crc32c");
  1446. break;
  1447. case 19:
  1448. ret += tcrypt_test("ecb(tea)");
  1449. break;
  1450. case 20:
  1451. ret += tcrypt_test("ecb(xtea)");
  1452. break;
  1453. case 21:
  1454. ret += tcrypt_test("ecb(khazad)");
  1455. break;
  1456. case 22:
  1457. ret += tcrypt_test("wp512");
  1458. break;
  1459. case 23:
  1460. ret += tcrypt_test("wp384");
  1461. break;
  1462. case 24:
  1463. ret += tcrypt_test("wp256");
  1464. break;
  1465. case 25:
  1466. ret += tcrypt_test("ecb(tnepres)");
  1467. break;
  1468. case 26:
  1469. ret += tcrypt_test("ecb(anubis)");
  1470. ret += tcrypt_test("cbc(anubis)");
  1471. break;
  1472. case 27:
  1473. ret += tcrypt_test("tgr192");
  1474. break;
  1475. case 28:
  1476. ret += tcrypt_test("tgr160");
  1477. break;
  1478. case 29:
  1479. ret += tcrypt_test("tgr128");
  1480. break;
  1481. case 30:
  1482. ret += tcrypt_test("ecb(xeta)");
  1483. break;
  1484. case 31:
  1485. ret += tcrypt_test("pcbc(fcrypt)");
  1486. break;
  1487. case 32:
  1488. ret += tcrypt_test("ecb(camellia)");
  1489. ret += tcrypt_test("cbc(camellia)");
  1490. ret += tcrypt_test("ctr(camellia)");
  1491. ret += tcrypt_test("lrw(camellia)");
  1492. ret += tcrypt_test("xts(camellia)");
  1493. break;
  1494. case 33:
  1495. ret += tcrypt_test("sha224");
  1496. break;
  1497. case 34:
  1498. ret += tcrypt_test("salsa20");
  1499. break;
  1500. case 35:
  1501. ret += tcrypt_test("gcm(aes)");
  1502. break;
  1503. case 36:
  1504. ret += tcrypt_test("lzo");
  1505. break;
  1506. case 37:
  1507. ret += tcrypt_test("ccm(aes)");
  1508. break;
  1509. case 38:
  1510. ret += tcrypt_test("cts(cbc(aes))");
  1511. break;
  1512. case 39:
  1513. ret += tcrypt_test("rmd128");
  1514. break;
  1515. case 40:
  1516. ret += tcrypt_test("rmd160");
  1517. break;
  1518. case 41:
  1519. ret += tcrypt_test("rmd256");
  1520. break;
  1521. case 42:
  1522. ret += tcrypt_test("rmd320");
  1523. break;
  1524. case 43:
  1525. ret += tcrypt_test("ecb(seed)");
  1526. break;
  1527. case 45:
  1528. ret += tcrypt_test("rfc4309(ccm(aes))");
  1529. break;
  1530. case 46:
  1531. ret += tcrypt_test("ghash");
  1532. break;
  1533. case 47:
  1534. ret += tcrypt_test("crct10dif");
  1535. break;
  1536. case 48:
  1537. ret += tcrypt_test("sha3-224");
  1538. break;
  1539. case 49:
  1540. ret += tcrypt_test("sha3-256");
  1541. break;
  1542. case 50:
  1543. ret += tcrypt_test("sha3-384");
  1544. break;
  1545. case 51:
  1546. ret += tcrypt_test("sha3-512");
  1547. break;
  1548. case 52:
  1549. ret += tcrypt_test("sm3");
  1550. break;
  1551. case 53:
  1552. ret += tcrypt_test("streebog256");
  1553. break;
  1554. case 54:
  1555. ret += tcrypt_test("streebog512");
  1556. break;
  1557. case 100:
  1558. ret += tcrypt_test("hmac(md5)");
  1559. break;
  1560. case 101:
  1561. ret += tcrypt_test("hmac(sha1)");
  1562. break;
  1563. case 102:
  1564. ret += tcrypt_test("hmac(sha256)");
  1565. break;
  1566. case 103:
  1567. ret += tcrypt_test("hmac(sha384)");
  1568. break;
  1569. case 104:
  1570. ret += tcrypt_test("hmac(sha512)");
  1571. break;
  1572. case 105:
  1573. ret += tcrypt_test("hmac(sha224)");
  1574. break;
  1575. case 106:
  1576. ret += tcrypt_test("xcbc(aes)");
  1577. break;
  1578. case 107:
  1579. ret += tcrypt_test("hmac(rmd128)");
  1580. break;
  1581. case 108:
  1582. ret += tcrypt_test("hmac(rmd160)");
  1583. break;
  1584. case 109:
  1585. ret += tcrypt_test("vmac64(aes)");
  1586. break;
  1587. case 111:
  1588. ret += tcrypt_test("hmac(sha3-224)");
  1589. break;
  1590. case 112:
  1591. ret += tcrypt_test("hmac(sha3-256)");
  1592. break;
  1593. case 113:
  1594. ret += tcrypt_test("hmac(sha3-384)");
  1595. break;
  1596. case 114:
  1597. ret += tcrypt_test("hmac(sha3-512)");
  1598. break;
  1599. case 115:
  1600. ret += tcrypt_test("hmac(streebog256)");
  1601. break;
  1602. case 116:
  1603. ret += tcrypt_test("hmac(streebog512)");
  1604. break;
  1605. case 150:
  1606. ret += tcrypt_test("ansi_cprng");
  1607. break;
  1608. case 151:
  1609. ret += tcrypt_test("rfc4106(gcm(aes))");
  1610. break;
  1611. case 152:
  1612. ret += tcrypt_test("rfc4543(gcm(aes))");
  1613. break;
  1614. case 153:
  1615. ret += tcrypt_test("cmac(aes)");
  1616. break;
  1617. case 154:
  1618. ret += tcrypt_test("cmac(des3_ede)");
  1619. break;
  1620. case 155:
  1621. ret += tcrypt_test("authenc(hmac(sha1),cbc(aes))");
  1622. break;
  1623. case 156:
  1624. ret += tcrypt_test("authenc(hmac(md5),ecb(cipher_null))");
  1625. break;
  1626. case 157:
  1627. ret += tcrypt_test("authenc(hmac(sha1),ecb(cipher_null))");
  1628. break;
  1629. case 181:
  1630. ret += tcrypt_test("authenc(hmac(sha1),cbc(des))");
  1631. break;
  1632. case 182:
  1633. ret += tcrypt_test("authenc(hmac(sha1),cbc(des3_ede))");
  1634. break;
  1635. case 183:
  1636. ret += tcrypt_test("authenc(hmac(sha224),cbc(des))");
  1637. break;
  1638. case 184:
  1639. ret += tcrypt_test("authenc(hmac(sha224),cbc(des3_ede))");
  1640. break;
  1641. case 185:
  1642. ret += tcrypt_test("authenc(hmac(sha256),cbc(des))");
  1643. break;
  1644. case 186:
  1645. ret += tcrypt_test("authenc(hmac(sha256),cbc(des3_ede))");
  1646. break;
  1647. case 187:
  1648. ret += tcrypt_test("authenc(hmac(sha384),cbc(des))");
  1649. break;
  1650. case 188:
  1651. ret += tcrypt_test("authenc(hmac(sha384),cbc(des3_ede))");
  1652. break;
  1653. case 189:
  1654. ret += tcrypt_test("authenc(hmac(sha512),cbc(des))");
  1655. break;
  1656. case 190:
  1657. ret += tcrypt_test("authenc(hmac(sha512),cbc(des3_ede))");
  1658. break;
  1659. case 191:
  1660. ret += tcrypt_test("ecb(sm4)");
  1661. ret += tcrypt_test("cbc(sm4)");
  1662. ret += tcrypt_test("ctr(sm4)");
  1663. break;
  1664. case 200:
  1665. test_cipher_speed("ecb(aes)", ENCRYPT, sec, NULL, 0,
  1666. speed_template_16_24_32);
  1667. test_cipher_speed("ecb(aes)", DECRYPT, sec, NULL, 0,
  1668. speed_template_16_24_32);
  1669. test_cipher_speed("cbc(aes)", ENCRYPT, sec, NULL, 0,
  1670. speed_template_16_24_32);
  1671. test_cipher_speed("cbc(aes)", DECRYPT, sec, NULL, 0,
  1672. speed_template_16_24_32);
  1673. test_cipher_speed("lrw(aes)", ENCRYPT, sec, NULL, 0,
  1674. speed_template_32_40_48);
  1675. test_cipher_speed("lrw(aes)", DECRYPT, sec, NULL, 0,
  1676. speed_template_32_40_48);
  1677. test_cipher_speed("xts(aes)", ENCRYPT, sec, NULL, 0,
  1678. speed_template_32_64);
  1679. test_cipher_speed("xts(aes)", DECRYPT, sec, NULL, 0,
  1680. speed_template_32_64);
  1681. test_cipher_speed("cts(cbc(aes))", ENCRYPT, sec, NULL, 0,
  1682. speed_template_16_24_32);
  1683. test_cipher_speed("cts(cbc(aes))", DECRYPT, sec, NULL, 0,
  1684. speed_template_16_24_32);
  1685. test_cipher_speed("ctr(aes)", ENCRYPT, sec, NULL, 0,
  1686. speed_template_16_24_32);
  1687. test_cipher_speed("ctr(aes)", DECRYPT, sec, NULL, 0,
  1688. speed_template_16_24_32);
  1689. test_cipher_speed("cfb(aes)", ENCRYPT, sec, NULL, 0,
  1690. speed_template_16_24_32);
  1691. test_cipher_speed("cfb(aes)", DECRYPT, sec, NULL, 0,
  1692. speed_template_16_24_32);
  1693. break;
  1694. case 201:
  1695. test_cipher_speed("ecb(des3_ede)", ENCRYPT, sec,
  1696. des3_speed_template, DES3_SPEED_VECTORS,
  1697. speed_template_24);
  1698. test_cipher_speed("ecb(des3_ede)", DECRYPT, sec,
  1699. des3_speed_template, DES3_SPEED_VECTORS,
  1700. speed_template_24);
  1701. test_cipher_speed("cbc(des3_ede)", ENCRYPT, sec,
  1702. des3_speed_template, DES3_SPEED_VECTORS,
  1703. speed_template_24);
  1704. test_cipher_speed("cbc(des3_ede)", DECRYPT, sec,
  1705. des3_speed_template, DES3_SPEED_VECTORS,
  1706. speed_template_24);
  1707. test_cipher_speed("ctr(des3_ede)", ENCRYPT, sec,
  1708. des3_speed_template, DES3_SPEED_VECTORS,
  1709. speed_template_24);
  1710. test_cipher_speed("ctr(des3_ede)", DECRYPT, sec,
  1711. des3_speed_template, DES3_SPEED_VECTORS,
  1712. speed_template_24);
  1713. break;
  1714. case 202:
  1715. test_cipher_speed("ecb(twofish)", ENCRYPT, sec, NULL, 0,
  1716. speed_template_16_24_32);
  1717. test_cipher_speed("ecb(twofish)", DECRYPT, sec, NULL, 0,
  1718. speed_template_16_24_32);
  1719. test_cipher_speed("cbc(twofish)", ENCRYPT, sec, NULL, 0,
  1720. speed_template_16_24_32);
  1721. test_cipher_speed("cbc(twofish)", DECRYPT, sec, NULL, 0,
  1722. speed_template_16_24_32);
  1723. test_cipher_speed("ctr(twofish)", ENCRYPT, sec, NULL, 0,
  1724. speed_template_16_24_32);
  1725. test_cipher_speed("ctr(twofish)", DECRYPT, sec, NULL, 0,
  1726. speed_template_16_24_32);
  1727. test_cipher_speed("lrw(twofish)", ENCRYPT, sec, NULL, 0,
  1728. speed_template_32_40_48);
  1729. test_cipher_speed("lrw(twofish)", DECRYPT, sec, NULL, 0,
  1730. speed_template_32_40_48);
  1731. test_cipher_speed("xts(twofish)", ENCRYPT, sec, NULL, 0,
  1732. speed_template_32_48_64);
  1733. test_cipher_speed("xts(twofish)", DECRYPT, sec, NULL, 0,
  1734. speed_template_32_48_64);
  1735. break;
  1736. case 203:
  1737. test_cipher_speed("ecb(blowfish)", ENCRYPT, sec, NULL, 0,
  1738. speed_template_8_32);
  1739. test_cipher_speed("ecb(blowfish)", DECRYPT, sec, NULL, 0,
  1740. speed_template_8_32);
  1741. test_cipher_speed("cbc(blowfish)", ENCRYPT, sec, NULL, 0,
  1742. speed_template_8_32);
  1743. test_cipher_speed("cbc(blowfish)", DECRYPT, sec, NULL, 0,
  1744. speed_template_8_32);
  1745. test_cipher_speed("ctr(blowfish)", ENCRYPT, sec, NULL, 0,
  1746. speed_template_8_32);
  1747. test_cipher_speed("ctr(blowfish)", DECRYPT, sec, NULL, 0,
  1748. speed_template_8_32);
  1749. break;
  1750. case 204:
  1751. test_cipher_speed("ecb(des)", ENCRYPT, sec, NULL, 0,
  1752. speed_template_8);
  1753. test_cipher_speed("ecb(des)", DECRYPT, sec, NULL, 0,
  1754. speed_template_8);
  1755. test_cipher_speed("cbc(des)", ENCRYPT, sec, NULL, 0,
  1756. speed_template_8);
  1757. test_cipher_speed("cbc(des)", DECRYPT, sec, NULL, 0,
  1758. speed_template_8);
  1759. break;
  1760. case 205:
  1761. test_cipher_speed("ecb(camellia)", ENCRYPT, sec, NULL, 0,
  1762. speed_template_16_24_32);
  1763. test_cipher_speed("ecb(camellia)", DECRYPT, sec, NULL, 0,
  1764. speed_template_16_24_32);
  1765. test_cipher_speed("cbc(camellia)", ENCRYPT, sec, NULL, 0,
  1766. speed_template_16_24_32);
  1767. test_cipher_speed("cbc(camellia)", DECRYPT, sec, NULL, 0,
  1768. speed_template_16_24_32);
  1769. test_cipher_speed("ctr(camellia)", ENCRYPT, sec, NULL, 0,
  1770. speed_template_16_24_32);
  1771. test_cipher_speed("ctr(camellia)", DECRYPT, sec, NULL, 0,
  1772. speed_template_16_24_32);
  1773. test_cipher_speed("lrw(camellia)", ENCRYPT, sec, NULL, 0,
  1774. speed_template_32_40_48);
  1775. test_cipher_speed("lrw(camellia)", DECRYPT, sec, NULL, 0,
  1776. speed_template_32_40_48);
  1777. test_cipher_speed("xts(camellia)", ENCRYPT, sec, NULL, 0,
  1778. speed_template_32_48_64);
  1779. test_cipher_speed("xts(camellia)", DECRYPT, sec, NULL, 0,
  1780. speed_template_32_48_64);
  1781. break;
  1782. case 206:
  1783. test_cipher_speed("salsa20", ENCRYPT, sec, NULL, 0,
  1784. speed_template_16_32);
  1785. break;
  1786. case 207:
  1787. test_cipher_speed("ecb(serpent)", ENCRYPT, sec, NULL, 0,
  1788. speed_template_16_32);
  1789. test_cipher_speed("ecb(serpent)", DECRYPT, sec, NULL, 0,
  1790. speed_template_16_32);
  1791. test_cipher_speed("cbc(serpent)", ENCRYPT, sec, NULL, 0,
  1792. speed_template_16_32);
  1793. test_cipher_speed("cbc(serpent)", DECRYPT, sec, NULL, 0,
  1794. speed_template_16_32);
  1795. test_cipher_speed("ctr(serpent)", ENCRYPT, sec, NULL, 0,
  1796. speed_template_16_32);
  1797. test_cipher_speed("ctr(serpent)", DECRYPT, sec, NULL, 0,
  1798. speed_template_16_32);
  1799. test_cipher_speed("lrw(serpent)", ENCRYPT, sec, NULL, 0,
  1800. speed_template_32_48);
  1801. test_cipher_speed("lrw(serpent)", DECRYPT, sec, NULL, 0,
  1802. speed_template_32_48);
  1803. test_cipher_speed("xts(serpent)", ENCRYPT, sec, NULL, 0,
  1804. speed_template_32_64);
  1805. test_cipher_speed("xts(serpent)", DECRYPT, sec, NULL, 0,
  1806. speed_template_32_64);
  1807. break;
  1808. case 208:
  1809. test_cipher_speed("ecb(arc4)", ENCRYPT, sec, NULL, 0,
  1810. speed_template_8);
  1811. break;
  1812. case 209:
  1813. test_cipher_speed("ecb(cast5)", ENCRYPT, sec, NULL, 0,
  1814. speed_template_8_16);
  1815. test_cipher_speed("ecb(cast5)", DECRYPT, sec, NULL, 0,
  1816. speed_template_8_16);
  1817. test_cipher_speed("cbc(cast5)", ENCRYPT, sec, NULL, 0,
  1818. speed_template_8_16);
  1819. test_cipher_speed("cbc(cast5)", DECRYPT, sec, NULL, 0,
  1820. speed_template_8_16);
  1821. test_cipher_speed("ctr(cast5)", ENCRYPT, sec, NULL, 0,
  1822. speed_template_8_16);
  1823. test_cipher_speed("ctr(cast5)", DECRYPT, sec, NULL, 0,
  1824. speed_template_8_16);
  1825. break;
  1826. case 210:
  1827. test_cipher_speed("ecb(cast6)", ENCRYPT, sec, NULL, 0,
  1828. speed_template_16_32);
  1829. test_cipher_speed("ecb(cast6)", DECRYPT, sec, NULL, 0,
  1830. speed_template_16_32);
  1831. test_cipher_speed("cbc(cast6)", ENCRYPT, sec, NULL, 0,
  1832. speed_template_16_32);
  1833. test_cipher_speed("cbc(cast6)", DECRYPT, sec, NULL, 0,
  1834. speed_template_16_32);
  1835. test_cipher_speed("ctr(cast6)", ENCRYPT, sec, NULL, 0,
  1836. speed_template_16_32);
  1837. test_cipher_speed("ctr(cast6)", DECRYPT, sec, NULL, 0,
  1838. speed_template_16_32);
  1839. test_cipher_speed("lrw(cast6)", ENCRYPT, sec, NULL, 0,
  1840. speed_template_32_48);
  1841. test_cipher_speed("lrw(cast6)", DECRYPT, sec, NULL, 0,
  1842. speed_template_32_48);
  1843. test_cipher_speed("xts(cast6)", ENCRYPT, sec, NULL, 0,
  1844. speed_template_32_64);
  1845. test_cipher_speed("xts(cast6)", DECRYPT, sec, NULL, 0,
  1846. speed_template_32_64);
  1847. break;
  1848. case 211:
  1849. test_aead_speed("rfc4106(gcm(aes))", ENCRYPT, sec,
  1850. NULL, 0, 16, 16, aead_speed_template_20);
  1851. test_aead_speed("gcm(aes)", ENCRYPT, sec,
  1852. NULL, 0, 16, 8, speed_template_16_24_32);
  1853. test_aead_speed("rfc4106(gcm(aes))", DECRYPT, sec,
  1854. NULL, 0, 16, 16, aead_speed_template_20);
  1855. test_aead_speed("gcm(aes)", DECRYPT, sec,
  1856. NULL, 0, 16, 8, speed_template_16_24_32);
  1857. break;
  1858. case 212:
  1859. test_aead_speed("rfc4309(ccm(aes))", ENCRYPT, sec,
  1860. NULL, 0, 16, 16, aead_speed_template_19);
  1861. test_aead_speed("rfc4309(ccm(aes))", DECRYPT, sec,
  1862. NULL, 0, 16, 16, aead_speed_template_19);
  1863. break;
  1864. case 213:
  1865. test_aead_speed("rfc7539esp(chacha20,poly1305)", ENCRYPT, sec,
  1866. NULL, 0, 16, 8, aead_speed_template_36);
  1867. test_aead_speed("rfc7539esp(chacha20,poly1305)", DECRYPT, sec,
  1868. NULL, 0, 16, 8, aead_speed_template_36);
  1869. break;
  1870. case 214:
  1871. test_cipher_speed("chacha20", ENCRYPT, sec, NULL, 0,
  1872. speed_template_32);
  1873. break;
  1874. case 215:
  1875. test_mb_aead_speed("rfc4106(gcm(aes))", ENCRYPT, sec, NULL,
  1876. 0, 16, 16, aead_speed_template_20, num_mb);
  1877. test_mb_aead_speed("gcm(aes)", ENCRYPT, sec, NULL, 0, 16, 8,
  1878. speed_template_16_24_32, num_mb);
  1879. test_mb_aead_speed("rfc4106(gcm(aes))", DECRYPT, sec, NULL,
  1880. 0, 16, 16, aead_speed_template_20, num_mb);
  1881. test_mb_aead_speed("gcm(aes)", DECRYPT, sec, NULL, 0, 16, 8,
  1882. speed_template_16_24_32, num_mb);
  1883. break;
  1884. case 216:
  1885. test_mb_aead_speed("rfc4309(ccm(aes))", ENCRYPT, sec, NULL, 0,
  1886. 16, 16, aead_speed_template_19, num_mb);
  1887. test_mb_aead_speed("rfc4309(ccm(aes))", DECRYPT, sec, NULL, 0,
  1888. 16, 16, aead_speed_template_19, num_mb);
  1889. break;
  1890. case 217:
  1891. test_mb_aead_speed("rfc7539esp(chacha20,poly1305)", ENCRYPT,
  1892. sec, NULL, 0, 16, 8, aead_speed_template_36,
  1893. num_mb);
  1894. test_mb_aead_speed("rfc7539esp(chacha20,poly1305)", DECRYPT,
  1895. sec, NULL, 0, 16, 8, aead_speed_template_36,
  1896. num_mb);
  1897. break;
  1898. case 218:
  1899. test_cipher_speed("ecb(sm4)", ENCRYPT, sec, NULL, 0,
  1900. speed_template_16);
  1901. test_cipher_speed("ecb(sm4)", DECRYPT, sec, NULL, 0,
  1902. speed_template_16);
  1903. test_cipher_speed("cbc(sm4)", ENCRYPT, sec, NULL, 0,
  1904. speed_template_16);
  1905. test_cipher_speed("cbc(sm4)", DECRYPT, sec, NULL, 0,
  1906. speed_template_16);
  1907. test_cipher_speed("ctr(sm4)", ENCRYPT, sec, NULL, 0,
  1908. speed_template_16);
  1909. test_cipher_speed("ctr(sm4)", DECRYPT, sec, NULL, 0,
  1910. speed_template_16);
  1911. break;
  1912. case 219:
  1913. test_cipher_speed("adiantum(xchacha12,aes)", ENCRYPT, sec, NULL,
  1914. 0, speed_template_32);
  1915. test_cipher_speed("adiantum(xchacha12,aes)", DECRYPT, sec, NULL,
  1916. 0, speed_template_32);
  1917. test_cipher_speed("adiantum(xchacha20,aes)", ENCRYPT, sec, NULL,
  1918. 0, speed_template_32);
  1919. test_cipher_speed("adiantum(xchacha20,aes)", DECRYPT, sec, NULL,
  1920. 0, speed_template_32);
  1921. break;
  1922. case 220:
  1923. test_acipher_speed("essiv(cbc(aes),sha256)",
  1924. ENCRYPT, sec, NULL, 0,
  1925. speed_template_16_24_32);
  1926. test_acipher_speed("essiv(cbc(aes),sha256)",
  1927. DECRYPT, sec, NULL, 0,
  1928. speed_template_16_24_32);
  1929. break;
  1930. case 221:
  1931. test_aead_speed("aegis128", ENCRYPT, sec,
  1932. NULL, 0, 16, 8, speed_template_16);
  1933. test_aead_speed("aegis128", DECRYPT, sec,
  1934. NULL, 0, 16, 8, speed_template_16);
  1935. break;
  1936. case 300:
  1937. if (alg) {
  1938. test_hash_speed(alg, sec, generic_hash_speed_template);
  1939. break;
  1940. }
  1941. /* fall through */
  1942. case 301:
  1943. test_hash_speed("md4", sec, generic_hash_speed_template);
  1944. if (mode > 300 && mode < 400) break;
  1945. /* fall through */
  1946. case 302:
  1947. test_hash_speed("md5", sec, generic_hash_speed_template);
  1948. if (mode > 300 && mode < 400) break;
  1949. /* fall through */
  1950. case 303:
  1951. test_hash_speed("sha1", sec, generic_hash_speed_template);
  1952. if (mode > 300 && mode < 400) break;
  1953. /* fall through */
  1954. case 304:
  1955. test_hash_speed("sha256", sec, generic_hash_speed_template);
  1956. if (mode > 300 && mode < 400) break;
  1957. /* fall through */
  1958. case 305:
  1959. test_hash_speed("sha384", sec, generic_hash_speed_template);
  1960. if (mode > 300 && mode < 400) break;
  1961. /* fall through */
  1962. case 306:
  1963. test_hash_speed("sha512", sec, generic_hash_speed_template);
  1964. if (mode > 300 && mode < 400) break;
  1965. /* fall through */
  1966. case 307:
  1967. test_hash_speed("wp256", sec, generic_hash_speed_template);
  1968. if (mode > 300 && mode < 400) break;
  1969. /* fall through */
  1970. case 308:
  1971. test_hash_speed("wp384", sec, generic_hash_speed_template);
  1972. if (mode > 300 && mode < 400) break;
  1973. /* fall through */
  1974. case 309:
  1975. test_hash_speed("wp512", sec, generic_hash_speed_template);
  1976. if (mode > 300 && mode < 400) break;
  1977. /* fall through */
  1978. case 310:
  1979. test_hash_speed("tgr128", sec, generic_hash_speed_template);
  1980. if (mode > 300 && mode < 400) break;
  1981. /* fall through */
  1982. case 311:
  1983. test_hash_speed("tgr160", sec, generic_hash_speed_template);
  1984. if (mode > 300 && mode < 400) break;
  1985. /* fall through */
  1986. case 312:
  1987. test_hash_speed("tgr192", sec, generic_hash_speed_template);
  1988. if (mode > 300 && mode < 400) break;
  1989. /* fall through */
  1990. case 313:
  1991. test_hash_speed("sha224", sec, generic_hash_speed_template);
  1992. if (mode > 300 && mode < 400) break;
  1993. /* fall through */
  1994. case 314:
  1995. test_hash_speed("rmd128", sec, generic_hash_speed_template);
  1996. if (mode > 300 && mode < 400) break;
  1997. /* fall through */
  1998. case 315:
  1999. test_hash_speed("rmd160", sec, generic_hash_speed_template);
  2000. if (mode > 300 && mode < 400) break;
  2001. /* fall through */
  2002. case 316:
  2003. test_hash_speed("rmd256", sec, generic_hash_speed_template);
  2004. if (mode > 300 && mode < 400) break;
  2005. /* fall through */
  2006. case 317:
  2007. test_hash_speed("rmd320", sec, generic_hash_speed_template);
  2008. if (mode > 300 && mode < 400) break;
  2009. /* fall through */
  2010. case 318:
  2011. test_hash_speed("ghash-generic", sec, hash_speed_template_16);
  2012. if (mode > 300 && mode < 400) break;
  2013. /* fall through */
  2014. case 319:
  2015. test_hash_speed("crc32c", sec, generic_hash_speed_template);
  2016. if (mode > 300 && mode < 400) break;
  2017. /* fall through */
  2018. case 320:
  2019. test_hash_speed("crct10dif", sec, generic_hash_speed_template);
  2020. if (mode > 300 && mode < 400) break;
  2021. /* fall through */
  2022. case 321:
  2023. test_hash_speed("poly1305", sec, poly1305_speed_template);
  2024. if (mode > 300 && mode < 400) break;
  2025. /* fall through */
  2026. case 322:
  2027. test_hash_speed("sha3-224", sec, generic_hash_speed_template);
  2028. if (mode > 300 && mode < 400) break;
  2029. /* fall through */
  2030. case 323:
  2031. test_hash_speed("sha3-256", sec, generic_hash_speed_template);
  2032. if (mode > 300 && mode < 400) break;
  2033. /* fall through */
  2034. case 324:
  2035. test_hash_speed("sha3-384", sec, generic_hash_speed_template);
  2036. if (mode > 300 && mode < 400) break;
  2037. /* fall through */
  2038. case 325:
  2039. test_hash_speed("sha3-512", sec, generic_hash_speed_template);
  2040. if (mode > 300 && mode < 400) break;
  2041. /* fall through */
  2042. case 326:
  2043. test_hash_speed("sm3", sec, generic_hash_speed_template);
  2044. if (mode > 300 && mode < 400) break;
  2045. /* fall through */
  2046. case 327:
  2047. test_hash_speed("streebog256", sec,
  2048. generic_hash_speed_template);
  2049. if (mode > 300 && mode < 400) break;
  2050. /* fall through */
  2051. case 328:
  2052. test_hash_speed("streebog512", sec,
  2053. generic_hash_speed_template);
  2054. if (mode > 300 && mode < 400) break;
  2055. /* fall through */
  2056. case 399:
  2057. break;
  2058. case 400:
  2059. if (alg) {
  2060. test_ahash_speed(alg, sec, generic_hash_speed_template);
  2061. break;
  2062. }
  2063. /* fall through */
  2064. case 401:
  2065. test_ahash_speed("md4", sec, generic_hash_speed_template);
  2066. if (mode > 400 && mode < 500) break;
  2067. /* fall through */
  2068. case 402:
  2069. test_ahash_speed("md5", sec, generic_hash_speed_template);
  2070. if (mode > 400 && mode < 500) break;
  2071. /* fall through */
  2072. case 403:
  2073. test_ahash_speed("sha1", sec, generic_hash_speed_template);
  2074. if (mode > 400 && mode < 500) break;
  2075. /* fall through */
  2076. case 404:
  2077. test_ahash_speed("sha256", sec, generic_hash_speed_template);
  2078. if (mode > 400 && mode < 500) break;
  2079. /* fall through */
  2080. case 405:
  2081. test_ahash_speed("sha384", sec, generic_hash_speed_template);
  2082. if (mode > 400 && mode < 500) break;
  2083. /* fall through */
  2084. case 406:
  2085. test_ahash_speed("sha512", sec, generic_hash_speed_template);
  2086. if (mode > 400 && mode < 500) break;
  2087. /* fall through */
  2088. case 407:
  2089. test_ahash_speed("wp256", sec, generic_hash_speed_template);
  2090. if (mode > 400 && mode < 500) break;
  2091. /* fall through */
  2092. case 408:
  2093. test_ahash_speed("wp384", sec, generic_hash_speed_template);
  2094. if (mode > 400 && mode < 500) break;
  2095. /* fall through */
  2096. case 409:
  2097. test_ahash_speed("wp512", sec, generic_hash_speed_template);
  2098. if (mode > 400 && mode < 500) break;
  2099. /* fall through */
  2100. case 410:
  2101. test_ahash_speed("tgr128", sec, generic_hash_speed_template);
  2102. if (mode > 400 && mode < 500) break;
  2103. /* fall through */
  2104. case 411:
  2105. test_ahash_speed("tgr160", sec, generic_hash_speed_template);
  2106. if (mode > 400 && mode < 500) break;
  2107. /* fall through */
  2108. case 412:
  2109. test_ahash_speed("tgr192", sec, generic_hash_speed_template);
  2110. if (mode > 400 && mode < 500) break;
  2111. /* fall through */
  2112. case 413:
  2113. test_ahash_speed("sha224", sec, generic_hash_speed_template);
  2114. if (mode > 400 && mode < 500) break;
  2115. /* fall through */
  2116. case 414:
  2117. test_ahash_speed("rmd128", sec, generic_hash_speed_template);
  2118. if (mode > 400 && mode < 500) break;
  2119. /* fall through */
  2120. case 415:
  2121. test_ahash_speed("rmd160", sec, generic_hash_speed_template);
  2122. if (mode > 400 && mode < 500) break;
  2123. /* fall through */
  2124. case 416:
  2125. test_ahash_speed("rmd256", sec, generic_hash_speed_template);
  2126. if (mode > 400 && mode < 500) break;
  2127. /* fall through */
  2128. case 417:
  2129. test_ahash_speed("rmd320", sec, generic_hash_speed_template);
  2130. if (mode > 400 && mode < 500) break;
  2131. /* fall through */
  2132. case 418:
  2133. test_ahash_speed("sha3-224", sec, generic_hash_speed_template);
  2134. if (mode > 400 && mode < 500) break;
  2135. /* fall through */
  2136. case 419:
  2137. test_ahash_speed("sha3-256", sec, generic_hash_speed_template);
  2138. if (mode > 400 && mode < 500) break;
  2139. /* fall through */
  2140. case 420:
  2141. test_ahash_speed("sha3-384", sec, generic_hash_speed_template);
  2142. if (mode > 400 && mode < 500) break;
  2143. /* fall through */
  2144. case 421:
  2145. test_ahash_speed("sha3-512", sec, generic_hash_speed_template);
  2146. if (mode > 400 && mode < 500) break;
  2147. /* fall through */
  2148. case 422:
  2149. test_mb_ahash_speed("sha1", sec, generic_hash_speed_template,
  2150. num_mb);
  2151. if (mode > 400 && mode < 500) break;
  2152. /* fall through */
  2153. case 423:
  2154. test_mb_ahash_speed("sha256", sec, generic_hash_speed_template,
  2155. num_mb);
  2156. if (mode > 400 && mode < 500) break;
  2157. /* fall through */
  2158. case 424:
  2159. test_mb_ahash_speed("sha512", sec, generic_hash_speed_template,
  2160. num_mb);
  2161. if (mode > 400 && mode < 500) break;
  2162. /* fall through */
  2163. case 425:
  2164. test_mb_ahash_speed("sm3", sec, generic_hash_speed_template,
  2165. num_mb);
  2166. if (mode > 400 && mode < 500) break;
  2167. /* fall through */
  2168. case 426:
  2169. test_mb_ahash_speed("streebog256", sec,
  2170. generic_hash_speed_template, num_mb);
  2171. if (mode > 400 && mode < 500) break;
  2172. /* fall through */
  2173. case 427:
  2174. test_mb_ahash_speed("streebog512", sec,
  2175. generic_hash_speed_template, num_mb);
  2176. if (mode > 400 && mode < 500) break;
  2177. /* fall through */
  2178. case 499:
  2179. break;
  2180. case 500:
  2181. test_acipher_speed("ecb(aes)", ENCRYPT, sec, NULL, 0,
  2182. speed_template_16_24_32);
  2183. test_acipher_speed("ecb(aes)", DECRYPT, sec, NULL, 0,
  2184. speed_template_16_24_32);
  2185. test_acipher_speed("cbc(aes)", ENCRYPT, sec, NULL, 0,
  2186. speed_template_16_24_32);
  2187. test_acipher_speed("cbc(aes)", DECRYPT, sec, NULL, 0,
  2188. speed_template_16_24_32);
  2189. test_acipher_speed("lrw(aes)", ENCRYPT, sec, NULL, 0,
  2190. speed_template_32_40_48);
  2191. test_acipher_speed("lrw(aes)", DECRYPT, sec, NULL, 0,
  2192. speed_template_32_40_48);
  2193. test_acipher_speed("xts(aes)", ENCRYPT, sec, NULL, 0,
  2194. speed_template_32_64);
  2195. test_acipher_speed("xts(aes)", DECRYPT, sec, NULL, 0,
  2196. speed_template_32_64);
  2197. test_acipher_speed("cts(cbc(aes))", ENCRYPT, sec, NULL, 0,
  2198. speed_template_16_24_32);
  2199. test_acipher_speed("cts(cbc(aes))", DECRYPT, sec, NULL, 0,
  2200. speed_template_16_24_32);
  2201. test_acipher_speed("ctr(aes)", ENCRYPT, sec, NULL, 0,
  2202. speed_template_16_24_32);
  2203. test_acipher_speed("ctr(aes)", DECRYPT, sec, NULL, 0,
  2204. speed_template_16_24_32);
  2205. test_acipher_speed("cfb(aes)", ENCRYPT, sec, NULL, 0,
  2206. speed_template_16_24_32);
  2207. test_acipher_speed("cfb(aes)", DECRYPT, sec, NULL, 0,
  2208. speed_template_16_24_32);
  2209. test_acipher_speed("ofb(aes)", ENCRYPT, sec, NULL, 0,
  2210. speed_template_16_24_32);
  2211. test_acipher_speed("ofb(aes)", DECRYPT, sec, NULL, 0,
  2212. speed_template_16_24_32);
  2213. test_acipher_speed("rfc3686(ctr(aes))", ENCRYPT, sec, NULL, 0,
  2214. speed_template_20_28_36);
  2215. test_acipher_speed("rfc3686(ctr(aes))", DECRYPT, sec, NULL, 0,
  2216. speed_template_20_28_36);
  2217. break;
  2218. case 501:
  2219. test_acipher_speed("ecb(des3_ede)", ENCRYPT, sec,
  2220. des3_speed_template, DES3_SPEED_VECTORS,
  2221. speed_template_24);
  2222. test_acipher_speed("ecb(des3_ede)", DECRYPT, sec,
  2223. des3_speed_template, DES3_SPEED_VECTORS,
  2224. speed_template_24);
  2225. test_acipher_speed("cbc(des3_ede)", ENCRYPT, sec,
  2226. des3_speed_template, DES3_SPEED_VECTORS,
  2227. speed_template_24);
  2228. test_acipher_speed("cbc(des3_ede)", DECRYPT, sec,
  2229. des3_speed_template, DES3_SPEED_VECTORS,
  2230. speed_template_24);
  2231. test_acipher_speed("cfb(des3_ede)", ENCRYPT, sec,
  2232. des3_speed_template, DES3_SPEED_VECTORS,
  2233. speed_template_24);
  2234. test_acipher_speed("cfb(des3_ede)", DECRYPT, sec,
  2235. des3_speed_template, DES3_SPEED_VECTORS,
  2236. speed_template_24);
  2237. test_acipher_speed("ofb(des3_ede)", ENCRYPT, sec,
  2238. des3_speed_template, DES3_SPEED_VECTORS,
  2239. speed_template_24);
  2240. test_acipher_speed("ofb(des3_ede)", DECRYPT, sec,
  2241. des3_speed_template, DES3_SPEED_VECTORS,
  2242. speed_template_24);
  2243. break;
  2244. case 502:
  2245. test_acipher_speed("ecb(des)", ENCRYPT, sec, NULL, 0,
  2246. speed_template_8);
  2247. test_acipher_speed("ecb(des)", DECRYPT, sec, NULL, 0,
  2248. speed_template_8);
  2249. test_acipher_speed("cbc(des)", ENCRYPT, sec, NULL, 0,
  2250. speed_template_8);
  2251. test_acipher_speed("cbc(des)", DECRYPT, sec, NULL, 0,
  2252. speed_template_8);
  2253. test_acipher_speed("cfb(des)", ENCRYPT, sec, NULL, 0,
  2254. speed_template_8);
  2255. test_acipher_speed("cfb(des)", DECRYPT, sec, NULL, 0,
  2256. speed_template_8);
  2257. test_acipher_speed("ofb(des)", ENCRYPT, sec, NULL, 0,
  2258. speed_template_8);
  2259. test_acipher_speed("ofb(des)", DECRYPT, sec, NULL, 0,
  2260. speed_template_8);
  2261. break;
  2262. case 503:
  2263. test_acipher_speed("ecb(serpent)", ENCRYPT, sec, NULL, 0,
  2264. speed_template_16_32);
  2265. test_acipher_speed("ecb(serpent)", DECRYPT, sec, NULL, 0,
  2266. speed_template_16_32);
  2267. test_acipher_speed("cbc(serpent)", ENCRYPT, sec, NULL, 0,
  2268. speed_template_16_32);
  2269. test_acipher_speed("cbc(serpent)", DECRYPT, sec, NULL, 0,
  2270. speed_template_16_32);
  2271. test_acipher_speed("ctr(serpent)", ENCRYPT, sec, NULL, 0,
  2272. speed_template_16_32);
  2273. test_acipher_speed("ctr(serpent)", DECRYPT, sec, NULL, 0,
  2274. speed_template_16_32);
  2275. test_acipher_speed("lrw(serpent)", ENCRYPT, sec, NULL, 0,
  2276. speed_template_32_48);
  2277. test_acipher_speed("lrw(serpent)", DECRYPT, sec, NULL, 0,
  2278. speed_template_32_48);
  2279. test_acipher_speed("xts(serpent)", ENCRYPT, sec, NULL, 0,
  2280. speed_template_32_64);
  2281. test_acipher_speed("xts(serpent)", DECRYPT, sec, NULL, 0,
  2282. speed_template_32_64);
  2283. break;
  2284. case 504:
  2285. test_acipher_speed("ecb(twofish)", ENCRYPT, sec, NULL, 0,
  2286. speed_template_16_24_32);
  2287. test_acipher_speed("ecb(twofish)", DECRYPT, sec, NULL, 0,
  2288. speed_template_16_24_32);
  2289. test_acipher_speed("cbc(twofish)", ENCRYPT, sec, NULL, 0,
  2290. speed_template_16_24_32);
  2291. test_acipher_speed("cbc(twofish)", DECRYPT, sec, NULL, 0,
  2292. speed_template_16_24_32);
  2293. test_acipher_speed("ctr(twofish)", ENCRYPT, sec, NULL, 0,
  2294. speed_template_16_24_32);
  2295. test_acipher_speed("ctr(twofish)", DECRYPT, sec, NULL, 0,
  2296. speed_template_16_24_32);
  2297. test_acipher_speed("lrw(twofish)", ENCRYPT, sec, NULL, 0,
  2298. speed_template_32_40_48);
  2299. test_acipher_speed("lrw(twofish)", DECRYPT, sec, NULL, 0,
  2300. speed_template_32_40_48);
  2301. test_acipher_speed("xts(twofish)", ENCRYPT, sec, NULL, 0,
  2302. speed_template_32_48_64);
  2303. test_acipher_speed("xts(twofish)", DECRYPT, sec, NULL, 0,
  2304. speed_template_32_48_64);
  2305. break;
  2306. case 505:
  2307. test_acipher_speed("ecb(arc4)", ENCRYPT, sec, NULL, 0,
  2308. speed_template_8);
  2309. break;
  2310. case 506:
  2311. test_acipher_speed("ecb(cast5)", ENCRYPT, sec, NULL, 0,
  2312. speed_template_8_16);
  2313. test_acipher_speed("ecb(cast5)", DECRYPT, sec, NULL, 0,
  2314. speed_template_8_16);
  2315. test_acipher_speed("cbc(cast5)", ENCRYPT, sec, NULL, 0,
  2316. speed_template_8_16);
  2317. test_acipher_speed("cbc(cast5)", DECRYPT, sec, NULL, 0,
  2318. speed_template_8_16);
  2319. test_acipher_speed("ctr(cast5)", ENCRYPT, sec, NULL, 0,
  2320. speed_template_8_16);
  2321. test_acipher_speed("ctr(cast5)", DECRYPT, sec, NULL, 0,
  2322. speed_template_8_16);
  2323. break;
  2324. case 507:
  2325. test_acipher_speed("ecb(cast6)", ENCRYPT, sec, NULL, 0,
  2326. speed_template_16_32);
  2327. test_acipher_speed("ecb(cast6)", DECRYPT, sec, NULL, 0,
  2328. speed_template_16_32);
  2329. test_acipher_speed("cbc(cast6)", ENCRYPT, sec, NULL, 0,
  2330. speed_template_16_32);
  2331. test_acipher_speed("cbc(cast6)", DECRYPT, sec, NULL, 0,
  2332. speed_template_16_32);
  2333. test_acipher_speed("ctr(cast6)", ENCRYPT, sec, NULL, 0,
  2334. speed_template_16_32);
  2335. test_acipher_speed("ctr(cast6)", DECRYPT, sec, NULL, 0,
  2336. speed_template_16_32);
  2337. test_acipher_speed("lrw(cast6)", ENCRYPT, sec, NULL, 0,
  2338. speed_template_32_48);
  2339. test_acipher_speed("lrw(cast6)", DECRYPT, sec, NULL, 0,
  2340. speed_template_32_48);
  2341. test_acipher_speed("xts(cast6)", ENCRYPT, sec, NULL, 0,
  2342. speed_template_32_64);
  2343. test_acipher_speed("xts(cast6)", DECRYPT, sec, NULL, 0,
  2344. speed_template_32_64);
  2345. break;
  2346. case 508:
  2347. test_acipher_speed("ecb(camellia)", ENCRYPT, sec, NULL, 0,
  2348. speed_template_16_32);
  2349. test_acipher_speed("ecb(camellia)", DECRYPT, sec, NULL, 0,
  2350. speed_template_16_32);
  2351. test_acipher_speed("cbc(camellia)", ENCRYPT, sec, NULL, 0,
  2352. speed_template_16_32);
  2353. test_acipher_speed("cbc(camellia)", DECRYPT, sec, NULL, 0,
  2354. speed_template_16_32);
  2355. test_acipher_speed("ctr(camellia)", ENCRYPT, sec, NULL, 0,
  2356. speed_template_16_32);
  2357. test_acipher_speed("ctr(camellia)", DECRYPT, sec, NULL, 0,
  2358. speed_template_16_32);
  2359. test_acipher_speed("lrw(camellia)", ENCRYPT, sec, NULL, 0,
  2360. speed_template_32_48);
  2361. test_acipher_speed("lrw(camellia)", DECRYPT, sec, NULL, 0,
  2362. speed_template_32_48);
  2363. test_acipher_speed("xts(camellia)", ENCRYPT, sec, NULL, 0,
  2364. speed_template_32_64);
  2365. test_acipher_speed("xts(camellia)", DECRYPT, sec, NULL, 0,
  2366. speed_template_32_64);
  2367. break;
  2368. case 509:
  2369. test_acipher_speed("ecb(blowfish)", ENCRYPT, sec, NULL, 0,
  2370. speed_template_8_32);
  2371. test_acipher_speed("ecb(blowfish)", DECRYPT, sec, NULL, 0,
  2372. speed_template_8_32);
  2373. test_acipher_speed("cbc(blowfish)", ENCRYPT, sec, NULL, 0,
  2374. speed_template_8_32);
  2375. test_acipher_speed("cbc(blowfish)", DECRYPT, sec, NULL, 0,
  2376. speed_template_8_32);
  2377. test_acipher_speed("ctr(blowfish)", ENCRYPT, sec, NULL, 0,
  2378. speed_template_8_32);
  2379. test_acipher_speed("ctr(blowfish)", DECRYPT, sec, NULL, 0,
  2380. speed_template_8_32);
  2381. break;
  2382. case 600:
  2383. test_mb_skcipher_speed("ecb(aes)", ENCRYPT, sec, NULL, 0,
  2384. speed_template_16_24_32, num_mb);
  2385. test_mb_skcipher_speed("ecb(aes)", DECRYPT, sec, NULL, 0,
  2386. speed_template_16_24_32, num_mb);
  2387. test_mb_skcipher_speed("cbc(aes)", ENCRYPT, sec, NULL, 0,
  2388. speed_template_16_24_32, num_mb);
  2389. test_mb_skcipher_speed("cbc(aes)", DECRYPT, sec, NULL, 0,
  2390. speed_template_16_24_32, num_mb);
  2391. test_mb_skcipher_speed("lrw(aes)", ENCRYPT, sec, NULL, 0,
  2392. speed_template_32_40_48, num_mb);
  2393. test_mb_skcipher_speed("lrw(aes)", DECRYPT, sec, NULL, 0,
  2394. speed_template_32_40_48, num_mb);
  2395. test_mb_skcipher_speed("xts(aes)", ENCRYPT, sec, NULL, 0,
  2396. speed_template_32_64, num_mb);
  2397. test_mb_skcipher_speed("xts(aes)", DECRYPT, sec, NULL, 0,
  2398. speed_template_32_64, num_mb);
  2399. test_mb_skcipher_speed("cts(cbc(aes))", ENCRYPT, sec, NULL, 0,
  2400. speed_template_16_24_32, num_mb);
  2401. test_mb_skcipher_speed("cts(cbc(aes))", DECRYPT, sec, NULL, 0,
  2402. speed_template_16_24_32, num_mb);
  2403. test_mb_skcipher_speed("ctr(aes)", ENCRYPT, sec, NULL, 0,
  2404. speed_template_16_24_32, num_mb);
  2405. test_mb_skcipher_speed("ctr(aes)", DECRYPT, sec, NULL, 0,
  2406. speed_template_16_24_32, num_mb);
  2407. test_mb_skcipher_speed("cfb(aes)", ENCRYPT, sec, NULL, 0,
  2408. speed_template_16_24_32, num_mb);
  2409. test_mb_skcipher_speed("cfb(aes)", DECRYPT, sec, NULL, 0,
  2410. speed_template_16_24_32, num_mb);
  2411. test_mb_skcipher_speed("ofb(aes)", ENCRYPT, sec, NULL, 0,
  2412. speed_template_16_24_32, num_mb);
  2413. test_mb_skcipher_speed("ofb(aes)", DECRYPT, sec, NULL, 0,
  2414. speed_template_16_24_32, num_mb);
  2415. test_mb_skcipher_speed("rfc3686(ctr(aes))", ENCRYPT, sec, NULL,
  2416. 0, speed_template_20_28_36, num_mb);
  2417. test_mb_skcipher_speed("rfc3686(ctr(aes))", DECRYPT, sec, NULL,
  2418. 0, speed_template_20_28_36, num_mb);
  2419. break;
  2420. case 601:
  2421. test_mb_skcipher_speed("ecb(des3_ede)", ENCRYPT, sec,
  2422. des3_speed_template, DES3_SPEED_VECTORS,
  2423. speed_template_24, num_mb);
  2424. test_mb_skcipher_speed("ecb(des3_ede)", DECRYPT, sec,
  2425. des3_speed_template, DES3_SPEED_VECTORS,
  2426. speed_template_24, num_mb);
  2427. test_mb_skcipher_speed("cbc(des3_ede)", ENCRYPT, sec,
  2428. des3_speed_template, DES3_SPEED_VECTORS,
  2429. speed_template_24, num_mb);
  2430. test_mb_skcipher_speed("cbc(des3_ede)", DECRYPT, sec,
  2431. des3_speed_template, DES3_SPEED_VECTORS,
  2432. speed_template_24, num_mb);
  2433. test_mb_skcipher_speed("cfb(des3_ede)", ENCRYPT, sec,
  2434. des3_speed_template, DES3_SPEED_VECTORS,
  2435. speed_template_24, num_mb);
  2436. test_mb_skcipher_speed("cfb(des3_ede)", DECRYPT, sec,
  2437. des3_speed_template, DES3_SPEED_VECTORS,
  2438. speed_template_24, num_mb);
  2439. test_mb_skcipher_speed("ofb(des3_ede)", ENCRYPT, sec,
  2440. des3_speed_template, DES3_SPEED_VECTORS,
  2441. speed_template_24, num_mb);
  2442. test_mb_skcipher_speed("ofb(des3_ede)", DECRYPT, sec,
  2443. des3_speed_template, DES3_SPEED_VECTORS,
  2444. speed_template_24, num_mb);
  2445. break;
  2446. case 602:
  2447. test_mb_skcipher_speed("ecb(des)", ENCRYPT, sec, NULL, 0,
  2448. speed_template_8, num_mb);
  2449. test_mb_skcipher_speed("ecb(des)", DECRYPT, sec, NULL, 0,
  2450. speed_template_8, num_mb);
  2451. test_mb_skcipher_speed("cbc(des)", ENCRYPT, sec, NULL, 0,
  2452. speed_template_8, num_mb);
  2453. test_mb_skcipher_speed("cbc(des)", DECRYPT, sec, NULL, 0,
  2454. speed_template_8, num_mb);
  2455. test_mb_skcipher_speed("cfb(des)", ENCRYPT, sec, NULL, 0,
  2456. speed_template_8, num_mb);
  2457. test_mb_skcipher_speed("cfb(des)", DECRYPT, sec, NULL, 0,
  2458. speed_template_8, num_mb);
  2459. test_mb_skcipher_speed("ofb(des)", ENCRYPT, sec, NULL, 0,
  2460. speed_template_8, num_mb);
  2461. test_mb_skcipher_speed("ofb(des)", DECRYPT, sec, NULL, 0,
  2462. speed_template_8, num_mb);
  2463. break;
  2464. case 603:
  2465. test_mb_skcipher_speed("ecb(serpent)", ENCRYPT, sec, NULL, 0,
  2466. speed_template_16_32, num_mb);
  2467. test_mb_skcipher_speed("ecb(serpent)", DECRYPT, sec, NULL, 0,
  2468. speed_template_16_32, num_mb);
  2469. test_mb_skcipher_speed("cbc(serpent)", ENCRYPT, sec, NULL, 0,
  2470. speed_template_16_32, num_mb);
  2471. test_mb_skcipher_speed("cbc(serpent)", DECRYPT, sec, NULL, 0,
  2472. speed_template_16_32, num_mb);
  2473. test_mb_skcipher_speed("ctr(serpent)", ENCRYPT, sec, NULL, 0,
  2474. speed_template_16_32, num_mb);
  2475. test_mb_skcipher_speed("ctr(serpent)", DECRYPT, sec, NULL, 0,
  2476. speed_template_16_32, num_mb);
  2477. test_mb_skcipher_speed("lrw(serpent)", ENCRYPT, sec, NULL, 0,
  2478. speed_template_32_48, num_mb);
  2479. test_mb_skcipher_speed("lrw(serpent)", DECRYPT, sec, NULL, 0,
  2480. speed_template_32_48, num_mb);
  2481. test_mb_skcipher_speed("xts(serpent)", ENCRYPT, sec, NULL, 0,
  2482. speed_template_32_64, num_mb);
  2483. test_mb_skcipher_speed("xts(serpent)", DECRYPT, sec, NULL, 0,
  2484. speed_template_32_64, num_mb);
  2485. break;
  2486. case 604:
  2487. test_mb_skcipher_speed("ecb(twofish)", ENCRYPT, sec, NULL, 0,
  2488. speed_template_16_24_32, num_mb);
  2489. test_mb_skcipher_speed("ecb(twofish)", DECRYPT, sec, NULL, 0,
  2490. speed_template_16_24_32, num_mb);
  2491. test_mb_skcipher_speed("cbc(twofish)", ENCRYPT, sec, NULL, 0,
  2492. speed_template_16_24_32, num_mb);
  2493. test_mb_skcipher_speed("cbc(twofish)", DECRYPT, sec, NULL, 0,
  2494. speed_template_16_24_32, num_mb);
  2495. test_mb_skcipher_speed("ctr(twofish)", ENCRYPT, sec, NULL, 0,
  2496. speed_template_16_24_32, num_mb);
  2497. test_mb_skcipher_speed("ctr(twofish)", DECRYPT, sec, NULL, 0,
  2498. speed_template_16_24_32, num_mb);
  2499. test_mb_skcipher_speed("lrw(twofish)", ENCRYPT, sec, NULL, 0,
  2500. speed_template_32_40_48, num_mb);
  2501. test_mb_skcipher_speed("lrw(twofish)", DECRYPT, sec, NULL, 0,
  2502. speed_template_32_40_48, num_mb);
  2503. test_mb_skcipher_speed("xts(twofish)", ENCRYPT, sec, NULL, 0,
  2504. speed_template_32_48_64, num_mb);
  2505. test_mb_skcipher_speed("xts(twofish)", DECRYPT, sec, NULL, 0,
  2506. speed_template_32_48_64, num_mb);
  2507. break;
  2508. case 605:
  2509. test_mb_skcipher_speed("ecb(arc4)", ENCRYPT, sec, NULL, 0,
  2510. speed_template_8, num_mb);
  2511. break;
  2512. case 606:
  2513. test_mb_skcipher_speed("ecb(cast5)", ENCRYPT, sec, NULL, 0,
  2514. speed_template_8_16, num_mb);
  2515. test_mb_skcipher_speed("ecb(cast5)", DECRYPT, sec, NULL, 0,
  2516. speed_template_8_16, num_mb);
  2517. test_mb_skcipher_speed("cbc(cast5)", ENCRYPT, sec, NULL, 0,
  2518. speed_template_8_16, num_mb);
  2519. test_mb_skcipher_speed("cbc(cast5)", DECRYPT, sec, NULL, 0,
  2520. speed_template_8_16, num_mb);
  2521. test_mb_skcipher_speed("ctr(cast5)", ENCRYPT, sec, NULL, 0,
  2522. speed_template_8_16, num_mb);
  2523. test_mb_skcipher_speed("ctr(cast5)", DECRYPT, sec, NULL, 0,
  2524. speed_template_8_16, num_mb);
  2525. break;
  2526. case 607:
  2527. test_mb_skcipher_speed("ecb(cast6)", ENCRYPT, sec, NULL, 0,
  2528. speed_template_16_32, num_mb);
  2529. test_mb_skcipher_speed("ecb(cast6)", DECRYPT, sec, NULL, 0,
  2530. speed_template_16_32, num_mb);
  2531. test_mb_skcipher_speed("cbc(cast6)", ENCRYPT, sec, NULL, 0,
  2532. speed_template_16_32, num_mb);
  2533. test_mb_skcipher_speed("cbc(cast6)", DECRYPT, sec, NULL, 0,
  2534. speed_template_16_32, num_mb);
  2535. test_mb_skcipher_speed("ctr(cast6)", ENCRYPT, sec, NULL, 0,
  2536. speed_template_16_32, num_mb);
  2537. test_mb_skcipher_speed("ctr(cast6)", DECRYPT, sec, NULL, 0,
  2538. speed_template_16_32, num_mb);
  2539. test_mb_skcipher_speed("lrw(cast6)", ENCRYPT, sec, NULL, 0,
  2540. speed_template_32_48, num_mb);
  2541. test_mb_skcipher_speed("lrw(cast6)", DECRYPT, sec, NULL, 0,
  2542. speed_template_32_48, num_mb);
  2543. test_mb_skcipher_speed("xts(cast6)", ENCRYPT, sec, NULL, 0,
  2544. speed_template_32_64, num_mb);
  2545. test_mb_skcipher_speed("xts(cast6)", DECRYPT, sec, NULL, 0,
  2546. speed_template_32_64, num_mb);
  2547. break;
  2548. case 608:
  2549. test_mb_skcipher_speed("ecb(camellia)", ENCRYPT, sec, NULL, 0,
  2550. speed_template_16_32, num_mb);
  2551. test_mb_skcipher_speed("ecb(camellia)", DECRYPT, sec, NULL, 0,
  2552. speed_template_16_32, num_mb);
  2553. test_mb_skcipher_speed("cbc(camellia)", ENCRYPT, sec, NULL, 0,
  2554. speed_template_16_32, num_mb);
  2555. test_mb_skcipher_speed("cbc(camellia)", DECRYPT, sec, NULL, 0,
  2556. speed_template_16_32, num_mb);
  2557. test_mb_skcipher_speed("ctr(camellia)", ENCRYPT, sec, NULL, 0,
  2558. speed_template_16_32, num_mb);
  2559. test_mb_skcipher_speed("ctr(camellia)", DECRYPT, sec, NULL, 0,
  2560. speed_template_16_32, num_mb);
  2561. test_mb_skcipher_speed("lrw(camellia)", ENCRYPT, sec, NULL, 0,
  2562. speed_template_32_48, num_mb);
  2563. test_mb_skcipher_speed("lrw(camellia)", DECRYPT, sec, NULL, 0,
  2564. speed_template_32_48, num_mb);
  2565. test_mb_skcipher_speed("xts(camellia)", ENCRYPT, sec, NULL, 0,
  2566. speed_template_32_64, num_mb);
  2567. test_mb_skcipher_speed("xts(camellia)", DECRYPT, sec, NULL, 0,
  2568. speed_template_32_64, num_mb);
  2569. break;
  2570. case 609:
  2571. test_mb_skcipher_speed("ecb(blowfish)", ENCRYPT, sec, NULL, 0,
  2572. speed_template_8_32, num_mb);
  2573. test_mb_skcipher_speed("ecb(blowfish)", DECRYPT, sec, NULL, 0,
  2574. speed_template_8_32, num_mb);
  2575. test_mb_skcipher_speed("cbc(blowfish)", ENCRYPT, sec, NULL, 0,
  2576. speed_template_8_32, num_mb);
  2577. test_mb_skcipher_speed("cbc(blowfish)", DECRYPT, sec, NULL, 0,
  2578. speed_template_8_32, num_mb);
  2579. test_mb_skcipher_speed("ctr(blowfish)", ENCRYPT, sec, NULL, 0,
  2580. speed_template_8_32, num_mb);
  2581. test_mb_skcipher_speed("ctr(blowfish)", DECRYPT, sec, NULL, 0,
  2582. speed_template_8_32, num_mb);
  2583. break;
  2584. case 1000:
  2585. test_available();
  2586. break;
  2587. }
  2588. return ret;
  2589. }
  2590. static int __init tcrypt_mod_init(void)
  2591. {
  2592. int err = -ENOMEM;
  2593. int i;
  2594. for (i = 0; i < TVMEMSIZE; i++) {
  2595. tvmem[i] = (void *)__get_free_page(GFP_KERNEL);
  2596. if (!tvmem[i])
  2597. goto err_free_tv;
  2598. }
  2599. err = do_test(alg, type, mask, mode, num_mb);
  2600. if (err) {
  2601. printk(KERN_ERR "tcrypt: one or more tests failed!\n");
  2602. goto err_free_tv;
  2603. } else {
  2604. pr_debug("all tests passed\n");
  2605. }
  2606. /* We intentionaly return -EAGAIN to prevent keeping the module,
  2607. * unless we're running in fips mode. It does all its work from
  2608. * init() and doesn't offer any runtime functionality, but in
  2609. * the fips case, checking for a successful load is helpful.
  2610. * => we don't need it in the memory, do we?
  2611. * -- mludvig
  2612. */
  2613. if (!fips_enabled)
  2614. err = -EAGAIN;
  2615. err_free_tv:
  2616. for (i = 0; i < TVMEMSIZE && tvmem[i]; i++)
  2617. free_page((unsigned long)tvmem[i]);
  2618. return err;
  2619. }
  2620. /*
  2621. * If an init function is provided, an exit function must also be provided
  2622. * to allow module unload.
  2623. */
  2624. static void __exit tcrypt_mod_fini(void) { }
  2625. subsys_initcall(tcrypt_mod_init);
  2626. module_exit(tcrypt_mod_fini);
  2627. module_param(alg, charp, 0);
  2628. module_param(type, uint, 0);
  2629. module_param(mask, uint, 0);
  2630. module_param(mode, int, 0);
  2631. module_param(sec, uint, 0);
  2632. MODULE_PARM_DESC(sec, "Length in seconds of speed tests "
  2633. "(defaults to zero which uses CPU cycles instead)");
  2634. module_param(num_mb, uint, 0000);
  2635. MODULE_PARM_DESC(num_mb, "Number of concurrent requests to be used in mb speed tests (defaults to 8)");
  2636. MODULE_LICENSE("GPL");
  2637. MODULE_DESCRIPTION("Quick & dirty crypto testing module");
  2638. MODULE_AUTHOR("James Morris <jmorris@intercode.com.au>");