You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

setparam-ref.c 57 kB

7 years ago
7 years ago
7 years ago
12 years ago
12 years ago
12 years ago
12 years ago
12 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049
  1. /*********************************************************************/
  2. /* Copyright 2009, 2010 The University of Texas at Austin. */
  3. /* Copyright 2023 The OpenBLAS Project. */
  4. /* All rights reserved. */
  5. /* */
  6. /* Redistribution and use in source and binary forms, with or */
  7. /* without modification, are permitted provided that the following */
  8. /* conditions are met: */
  9. /* */
  10. /* 1. Redistributions of source code must retain the above */
  11. /* copyright notice, this list of conditions and the following */
  12. /* disclaimer. */
  13. /* */
  14. /* 2. Redistributions in binary form must reproduce the above */
  15. /* copyright notice, this list of conditions and the following */
  16. /* disclaimer in the documentation and/or other materials */
  17. /* provided with the distribution. */
  18. /* */
  19. /* THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY OF TEXAS AT */
  20. /* AUSTIN ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, */
  21. /* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF */
  22. /* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE */
  23. /* DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY OF TEXAS AT */
  24. /* AUSTIN OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, */
  25. /* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES */
  26. /* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE */
  27. /* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR */
  28. /* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF */
  29. /* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT */
  30. /* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT */
  31. /* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE */
  32. /* POSSIBILITY OF SUCH DAMAGE. */
  33. /* */
  34. /* The views and conclusions contained in the software and */
  35. /* documentation are those of the authors and should not be */
  36. /* interpreted as representing official policies, either expressed */
  37. /* or implied, of The University of Texas at Austin. */
  38. /*********************************************************************/
  39. #include <stdio.h>
  40. #include <string.h>
  41. #include "common.h"
  42. #ifdef BUILD_KERNEL
  43. #include "kernelTS.h"
  44. #endif
  45. #undef DEBUG
  46. static void init_parameter(void);
  47. gotoblas_t TABLE_NAME = {
  48. DTB_DEFAULT_ENTRIES,
  49. SWITCH_RATIO,
  50. GEMM_DEFAULT_OFFSET_A, GEMM_DEFAULT_OFFSET_B, GEMM_DEFAULT_ALIGN,
  51. #ifdef BUILD_BFLOAT16
  52. 0, 0, 0,
  53. SBGEMM_DEFAULT_UNROLL_M, SBGEMM_DEFAULT_UNROLL_N,
  54. #ifdef SBGEMM_DEFAULT_UNROLL_MN
  55. SBGEMM_DEFAULT_UNROLL_MN,
  56. #else
  57. MAX(SBGEMM_DEFAULT_UNROLL_M, SBGEMM_DEFAULT_UNROLL_N),
  58. #endif
  59. SBGEMM_ALIGN_K,
  60. 0, // need_amxtile_permission
  61. sbstobf16_kTS, sbdtobf16_kTS, sbf16tos_kTS, dbf16tod_kTS,
  62. samax_kTS, samin_kTS, smax_kTS, smin_kTS,
  63. isamax_kTS, isamin_kTS, ismax_kTS, ismin_kTS,
  64. snrm2_kTS, sasum_kTS, ssum_kTS, scopy_kTS, sbdot_kTS,
  65. dsdot_kTS,
  66. srot_kTS, saxpy_kTS, sscal_kTS, sswap_kTS,
  67. sbgemv_nTS, sbgemv_tTS, sger_kTS,
  68. ssymv_LTS, ssymv_UTS,
  69. sbgemm_kernelTS, sbgemm_betaTS,
  70. #if SBGEMM_DEFAULT_UNROLL_M != SBGEMM_DEFAULT_UNROLL_N
  71. sbgemm_incopyTS, sbgemm_itcopyTS,
  72. #else
  73. sbgemm_oncopyTS, sbgemm_otcopyTS,
  74. #endif
  75. sbgemm_oncopyTS, sbgemm_otcopyTS,
  76. strsm_kernel_LNTS, strsm_kernel_LTTS, strsm_kernel_RNTS, strsm_kernel_RTTS,
  77. #if SGEMM_DEFAULT_UNROLL_M != SGEMM_DEFAULT_UNROLL_N
  78. strsm_iunucopyTS, strsm_iunncopyTS, strsm_iutucopyTS, strsm_iutncopyTS,
  79. strsm_ilnucopyTS, strsm_ilnncopyTS, strsm_iltucopyTS, strsm_iltncopyTS,
  80. #else
  81. strsm_ounucopyTS, strsm_ounncopyTS, strsm_outucopyTS, strsm_outncopyTS,
  82. strsm_olnucopyTS, strsm_olnncopyTS, strsm_oltucopyTS, strsm_oltncopyTS,
  83. #endif
  84. strsm_ounucopyTS, strsm_ounncopyTS, strsm_outucopyTS, strsm_outncopyTS,
  85. strsm_olnucopyTS, strsm_olnncopyTS, strsm_oltucopyTS, strsm_oltncopyTS,
  86. strmm_kernel_RNTS, strmm_kernel_RTTS, strmm_kernel_LNTS, strmm_kernel_LTTS,
  87. #if SGEMM_DEFAULT_UNROLL_M != SGEMM_DEFAULT_UNROLL_N
  88. strmm_iunucopyTS, strmm_iunncopyTS, strmm_iutucopyTS, strmm_iutncopyTS,
  89. strmm_ilnucopyTS, strmm_ilnncopyTS, strmm_iltucopyTS, strmm_iltncopyTS,
  90. #else
  91. strmm_ounucopyTS, strmm_ounncopyTS, strmm_outucopyTS, strmm_outncopyTS,
  92. strmm_olnucopyTS, strmm_olnncopyTS, strmm_oltucopyTS, strmm_oltncopyTS,
  93. #endif
  94. strmm_ounucopyTS, strmm_ounncopyTS, strmm_outucopyTS, strmm_outncopyTS,
  95. strmm_olnucopyTS, strmm_olnncopyTS, strmm_oltucopyTS, strmm_oltncopyTS,
  96. #if SGEMM_DEFAULT_UNROLL_M != SGEMM_DEFAULT_UNROLL_N
  97. ssymm_iutcopyTS, ssymm_iltcopyTS,
  98. #else
  99. ssymm_outcopyTS, ssymm_oltcopyTS,
  100. #endif
  101. ssymm_outcopyTS, ssymm_oltcopyTS,
  102. #ifndef NO_LAPACK
  103. sneg_tcopyTS, slaswp_ncopyTS,
  104. #else
  105. NULL,NULL,
  106. #endif
  107. #ifdef SMALL_MATRIX_OPT
  108. sbgemm_small_matrix_permitTS,
  109. sbgemm_small_kernel_nnTS, sbgemm_small_kernel_ntTS, sbgemm_small_kernel_tnTS, sbgemm_small_kernel_ttTS,
  110. sbgemm_small_kernel_b0_nnTS, sbgemm_small_kernel_b0_ntTS, sbgemm_small_kernel_b0_tnTS, sbgemm_small_kernel_b0_ttTS,
  111. #endif
  112. #endif
  113. #if ( BUILD_SINGLE==1) || (BUILD_DOUBLE==1) || (BUILD_COMPLEX==1) || (BUILD_COMPLEX16==1)
  114. 0, 0, 0,
  115. SGEMM_DEFAULT_UNROLL_M, SGEMM_DEFAULT_UNROLL_N,
  116. #ifdef SGEMM_DEFAULT_UNROLL_MN
  117. SGEMM_DEFAULT_UNROLL_MN,
  118. #else
  119. MAX(SGEMM_DEFAULT_UNROLL_M, SGEMM_DEFAULT_UNROLL_N),
  120. #endif
  121. #endif
  122. #ifdef HAVE_EXCLUSIVE_CACHE
  123. 1,
  124. #else
  125. 0,
  126. #endif
  127. #if (BUILD_SINGLE==1 ) || (BUILD_COMPLEX==1)
  128. samax_kTS, samin_kTS, smax_kTS, smin_kTS,
  129. #endif
  130. #if (BUILD_SINGLE==1) || (BUILD_DOUBLE==1) || (BUILD_COMPLEX==1)
  131. isamax_kTS,
  132. #endif
  133. #if (BUILD_SINGLE==1 ) || (BUILD_COMPLEX==1)
  134. isamin_kTS, ismax_kTS, ismin_kTS,
  135. snrm2_kTS, sasum_kTS,
  136. #endif
  137. #if BUILD_SINGLE == 1
  138. ssum_kTS,
  139. #endif
  140. #if (BUILD_SINGLE==1) || (BUILD_DOUBLE==1) || (BUILD_COMPLEX==1)
  141. scopy_kTS, sdot_kTS,
  142. // dsdot_kTS,
  143. srot_kTS, saxpy_kTS,
  144. #endif
  145. #if (BUILD_SINGLE==1) || (BUILD_DOUBLE==1) || (BUILD_COMPLEX==1) || (BUILD_COMPLEX16==1)
  146. sscal_kTS,
  147. #endif
  148. #if (BUILD_SINGLE==1) || (BUILD_DOUBLE==1) || (BUILD_COMPLEX==1)
  149. sswap_kTS,
  150. sgemv_nTS, sgemv_tTS,
  151. #endif
  152. #if BUILD_SINGLE == 1
  153. sger_kTS,
  154. #endif
  155. #if BUILD_SINGLE == 1
  156. ssymv_LTS, ssymv_UTS,
  157. #endif
  158. #if (BUILD_SINGLE==1) || (BUILD_DOUBLE==1) || (BUILD_COMPLEX==1)
  159. #ifdef ARCH_X86_64
  160. sgemm_directTS,
  161. sgemm_direct_performantTS,
  162. #endif
  163. sgemm_kernelTS, sgemm_betaTS,
  164. #if SGEMM_DEFAULT_UNROLL_M != SGEMM_DEFAULT_UNROLL_N
  165. sgemm_incopyTS, sgemm_itcopyTS,
  166. #else
  167. sgemm_oncopyTS, sgemm_otcopyTS,
  168. #endif
  169. sgemm_oncopyTS, sgemm_otcopyTS,
  170. #endif
  171. #if BUILD_SINGLE == 1 || BUILD_DOUBLE == 1 || BUILD_COMPLEX == 1
  172. #ifdef SMALL_MATRIX_OPT
  173. sgemm_small_matrix_permitTS,
  174. sgemm_small_kernel_nnTS, sgemm_small_kernel_ntTS, sgemm_small_kernel_tnTS, sgemm_small_kernel_ttTS,
  175. sgemm_small_kernel_b0_nnTS, sgemm_small_kernel_b0_ntTS, sgemm_small_kernel_b0_tnTS, sgemm_small_kernel_b0_ttTS,
  176. #endif
  177. #endif
  178. #if (BUILD_SINGLE==1) || (BUILD_DOUBLE==1) || (BUILD_COMPLEX == 1)
  179. strsm_kernel_LNTS, strsm_kernel_LTTS, strsm_kernel_RNTS, strsm_kernel_RTTS,
  180. #if SGEMM_DEFAULT_UNROLL_M != SGEMM_DEFAULT_UNROLL_N
  181. strsm_iunucopyTS, strsm_iunncopyTS, strsm_iutucopyTS, strsm_iutncopyTS,
  182. strsm_ilnucopyTS, strsm_ilnncopyTS, strsm_iltucopyTS, strsm_iltncopyTS,
  183. #else
  184. strsm_ounucopyTS, strsm_ounncopyTS, strsm_outucopyTS, strsm_outncopyTS,
  185. strsm_olnucopyTS, strsm_olnncopyTS, strsm_oltucopyTS, strsm_oltncopyTS,
  186. #endif
  187. strsm_ounucopyTS, strsm_ounncopyTS, strsm_outucopyTS, strsm_outncopyTS,
  188. strsm_olnucopyTS, strsm_olnncopyTS, strsm_oltucopyTS, strsm_oltncopyTS,
  189. #endif
  190. #if (BUILD_SINGLE==1)
  191. strmm_kernel_RNTS, strmm_kernel_RTTS, strmm_kernel_LNTS, strmm_kernel_LTTS,
  192. #if SGEMM_DEFAULT_UNROLL_M != SGEMM_DEFAULT_UNROLL_N
  193. strmm_iunucopyTS, strmm_iunncopyTS, strmm_iutucopyTS, strmm_iutncopyTS,
  194. strmm_ilnucopyTS, strmm_ilnncopyTS, strmm_iltucopyTS, strmm_iltncopyTS,
  195. #else
  196. strmm_ounucopyTS, strmm_ounncopyTS, strmm_outucopyTS, strmm_outncopyTS,
  197. strmm_olnucopyTS, strmm_olnncopyTS, strmm_oltucopyTS, strmm_oltncopyTS,
  198. #endif
  199. strmm_ounucopyTS, strmm_ounncopyTS, strmm_outucopyTS, strmm_outncopyTS,
  200. strmm_olnucopyTS, strmm_olnncopyTS, strmm_oltucopyTS, strmm_oltncopyTS,
  201. #if SGEMM_DEFAULT_UNROLL_M != SGEMM_DEFAULT_UNROLL_N
  202. ssymm_iutcopyTS, ssymm_iltcopyTS,
  203. #else
  204. ssymm_outcopyTS, ssymm_oltcopyTS,
  205. #endif
  206. ssymm_outcopyTS, ssymm_oltcopyTS,
  207. #ifndef NO_LAPACK
  208. sneg_tcopyTS, slaswp_ncopyTS,
  209. #else
  210. NULL,NULL,
  211. #endif
  212. #endif
  213. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  214. 0, 0, 0,
  215. DGEMM_DEFAULT_UNROLL_M, DGEMM_DEFAULT_UNROLL_N,
  216. #ifdef DGEMM_DEFAULT_UNROLL_MN
  217. DGEMM_DEFAULT_UNROLL_MN,
  218. #else
  219. MAX(DGEMM_DEFAULT_UNROLL_M, DGEMM_DEFAULT_UNROLL_N),
  220. #endif
  221. #endif
  222. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  223. damax_kTS, damin_kTS, dmax_kTS, dmin_kTS,
  224. idamax_kTS, idamin_kTS, idmax_kTS, idmin_kTS,
  225. dnrm2_kTS, dasum_kTS,
  226. #endif
  227. #if (BUILD_DOUBLE==1)
  228. dsum_kTS,
  229. #endif
  230. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  231. dcopy_kTS, ddot_kTS,
  232. #endif
  233. #if (BUILD_SINGLE==1) || (BUILD_DOUBLE==1)
  234. dsdot_kTS,
  235. #endif
  236. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  237. drot_kTS,
  238. daxpy_kTS,
  239. dscal_kTS,
  240. dswap_kTS,
  241. dgemv_nTS, dgemv_tTS,
  242. #endif
  243. #if (BUILD_DOUBLE==1)
  244. dger_kTS,
  245. dsymv_LTS, dsymv_UTS,
  246. #endif
  247. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  248. dgemm_kernelTS, dgemm_betaTS,
  249. #if DGEMM_DEFAULT_UNROLL_M != DGEMM_DEFAULT_UNROLL_N
  250. dgemm_incopyTS, dgemm_itcopyTS,
  251. #else
  252. dgemm_oncopyTS, dgemm_otcopyTS,
  253. #endif
  254. dgemm_oncopyTS, dgemm_otcopyTS,
  255. #endif
  256. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  257. #ifdef SMALL_MATRIX_OPT
  258. dgemm_small_matrix_permitTS,
  259. dgemm_small_kernel_nnTS, dgemm_small_kernel_ntTS, dgemm_small_kernel_tnTS, dgemm_small_kernel_ttTS,
  260. dgemm_small_kernel_b0_nnTS, dgemm_small_kernel_b0_ntTS, dgemm_small_kernel_b0_tnTS, dgemm_small_kernel_b0_ttTS,
  261. #endif
  262. #endif
  263. #if (BUILD_DOUBLE==1)
  264. dtrsm_kernel_LNTS, dtrsm_kernel_LTTS, dtrsm_kernel_RNTS, dtrsm_kernel_RTTS,
  265. #if DGEMM_DEFAULT_UNROLL_M != DGEMM_DEFAULT_UNROLL_N
  266. dtrsm_iunucopyTS, dtrsm_iunncopyTS, dtrsm_iutucopyTS, dtrsm_iutncopyTS,
  267. dtrsm_ilnucopyTS, dtrsm_ilnncopyTS, dtrsm_iltucopyTS, dtrsm_iltncopyTS,
  268. #else
  269. dtrsm_ounucopyTS, dtrsm_ounncopyTS, dtrsm_outucopyTS, dtrsm_outncopyTS,
  270. dtrsm_olnucopyTS, dtrsm_olnncopyTS, dtrsm_oltucopyTS, dtrsm_oltncopyTS,
  271. #endif
  272. dtrsm_ounucopyTS, dtrsm_ounncopyTS, dtrsm_outucopyTS, dtrsm_outncopyTS,
  273. dtrsm_olnucopyTS, dtrsm_olnncopyTS, dtrsm_oltucopyTS, dtrsm_oltncopyTS,
  274. dtrmm_kernel_RNTS, dtrmm_kernel_RTTS, dtrmm_kernel_LNTS, dtrmm_kernel_LTTS,
  275. #if DGEMM_DEFAULT_UNROLL_M != DGEMM_DEFAULT_UNROLL_N
  276. dtrmm_iunucopyTS, dtrmm_iunncopyTS, dtrmm_iutucopyTS, dtrmm_iutncopyTS,
  277. dtrmm_ilnucopyTS, dtrmm_ilnncopyTS, dtrmm_iltucopyTS, dtrmm_iltncopyTS,
  278. #else
  279. dtrmm_ounucopyTS, dtrmm_ounncopyTS, dtrmm_outucopyTS, dtrmm_outncopyTS,
  280. dtrmm_olnucopyTS, dtrmm_olnncopyTS, dtrmm_oltucopyTS, dtrmm_oltncopyTS,
  281. #endif
  282. dtrmm_ounucopyTS, dtrmm_ounncopyTS, dtrmm_outucopyTS, dtrmm_outncopyTS,
  283. dtrmm_olnucopyTS, dtrmm_olnncopyTS, dtrmm_oltucopyTS, dtrmm_oltncopyTS,
  284. #if DGEMM_DEFAULT_UNROLL_M != DGEMM_DEFAULT_UNROLL_N
  285. dsymm_iutcopyTS, dsymm_iltcopyTS,
  286. #else
  287. dsymm_outcopyTS, dsymm_oltcopyTS,
  288. #endif
  289. dsymm_outcopyTS, dsymm_oltcopyTS,
  290. #ifndef NO_LAPACK
  291. dneg_tcopyTS, dlaswp_ncopyTS,
  292. #else
  293. NULL, NULL,
  294. #endif
  295. #endif
  296. #ifdef EXPRECISION
  297. 0, 0, 0,
  298. QGEMM_DEFAULT_UNROLL_M, QGEMM_DEFAULT_UNROLL_N, MAX(QGEMM_DEFAULT_UNROLL_M, QGEMM_DEFAULT_UNROLL_N),
  299. qamax_kTS, qamin_kTS, qmax_kTS, qmin_kTS,
  300. iqamax_kTS, iqamin_kTS, iqmax_kTS, iqmin_kTS,
  301. qnrm2_kTS, qasum_kTS, qsum_kTS, qcopy_kTS, qdot_kTS,
  302. qrot_kTS, qaxpy_kTS, qscal_kTS, qswap_kTS,
  303. qgemv_nTS, qgemv_tTS, qger_kTS,
  304. qsymv_LTS, qsymv_UTS,
  305. qgemm_kernelTS, qgemm_betaTS,
  306. #if QGEMM_DEFAULT_UNROLL_M != QGEMM_DEFAULT_UNROLL_N
  307. qgemm_incopyTS, qgemm_itcopyTS,
  308. #else
  309. qgemm_oncopyTS, qgemm_otcopyTS,
  310. #endif
  311. qgemm_oncopyTS, qgemm_otcopyTS,
  312. qtrsm_kernel_LNTS, qtrsm_kernel_LTTS, qtrsm_kernel_RNTS, qtrsm_kernel_RTTS,
  313. #if QGEMM_DEFAULT_UNROLL_M != QGEMM_DEFAULT_UNROLL_N
  314. qtrsm_iunucopyTS, qtrsm_iunncopyTS, qtrsm_iutucopyTS, qtrsm_iutncopyTS,
  315. qtrsm_ilnucopyTS, qtrsm_ilnncopyTS, qtrsm_iltucopyTS, qtrsm_iltncopyTS,
  316. #else
  317. qtrsm_ounucopyTS, qtrsm_ounncopyTS, qtrsm_outucopyTS, qtrsm_outncopyTS,
  318. qtrsm_olnucopyTS, qtrsm_olnncopyTS, qtrsm_oltucopyTS, qtrsm_oltncopyTS,
  319. #endif
  320. qtrsm_ounucopyTS, qtrsm_ounncopyTS, qtrsm_outucopyTS, qtrsm_outncopyTS,
  321. qtrsm_olnucopyTS, qtrsm_olnncopyTS, qtrsm_oltucopyTS, qtrsm_oltncopyTS,
  322. qtrmm_kernel_RNTS, qtrmm_kernel_RTTS, qtrmm_kernel_LNTS, qtrmm_kernel_LTTS,
  323. #if QGEMM_DEFAULT_UNROLL_M != QGEMM_DEFAULT_UNROLL_N
  324. qtrmm_iunucopyTS, qtrmm_iunncopyTS, qtrmm_iutucopyTS, qtrmm_iutncopyTS,
  325. qtrmm_ilnucopyTS, qtrmm_ilnncopyTS, qtrmm_iltucopyTS, qtrmm_iltncopyTS,
  326. #else
  327. qtrmm_ounucopyTS, qtrmm_ounncopyTS, qtrmm_outucopyTS, qtrmm_outncopyTS,
  328. qtrmm_olnucopyTS, qtrmm_olnncopyTS, qtrmm_oltucopyTS, qtrmm_oltncopyTS,
  329. #endif
  330. qtrmm_ounucopyTS, qtrmm_ounncopyTS, qtrmm_outucopyTS, qtrmm_outncopyTS,
  331. qtrmm_olnucopyTS, qtrmm_olnncopyTS, qtrmm_oltucopyTS, qtrmm_oltncopyTS,
  332. #if QGEMM_DEFAULT_UNROLL_M != QGEMM_DEFAULT_UNROLL_N
  333. qsymm_iutcopyTS, qsymm_iltcopyTS,
  334. #else
  335. qsymm_outcopyTS, qsymm_oltcopyTS,
  336. #endif
  337. qsymm_outcopyTS, qsymm_oltcopyTS,
  338. #ifndef NO_LAPACK
  339. qneg_tcopyTS, qlaswp_ncopyTS,
  340. #else
  341. NULL, NULL,
  342. #endif
  343. #endif
  344. #if (BUILD_COMPLEX)
  345. 0, 0, 0,
  346. CGEMM_DEFAULT_UNROLL_M, CGEMM_DEFAULT_UNROLL_N,
  347. #ifdef CGEMM_DEFAULT_UNROLL_MN
  348. CGEMM_DEFAULT_UNROLL_MN,
  349. #else
  350. MAX(CGEMM_DEFAULT_UNROLL_M, CGEMM_DEFAULT_UNROLL_N),
  351. #endif
  352. #if (BUILD_COMPLEX)
  353. camax_kTS, camin_kTS,
  354. #endif
  355. #if (BUILD_COMPLEX)
  356. icamax_kTS,
  357. #endif
  358. #if (BUILD_COMPLEX)
  359. icamin_kTS,
  360. cnrm2_kTS, casum_kTS, csum_kTS,
  361. #endif
  362. #if (BUILD_COMPLEX)
  363. ccopy_kTS, cdotu_kTS, cdotc_kTS,
  364. #endif
  365. #if (BUILD_COMPLEX)
  366. csrot_kTS,
  367. #endif
  368. #if (BUILD_COMPLEX)
  369. caxpy_kTS,
  370. caxpyc_kTS,
  371. cscal_kTS,
  372. cswap_kTS,
  373. cgemv_nTS, cgemv_tTS, cgemv_rTS, cgemv_cTS,
  374. cgemv_oTS, cgemv_uTS, cgemv_sTS, cgemv_dTS,
  375. #endif
  376. #if (BUILD_COMPLEX)
  377. cgeru_kTS, cgerc_kTS, cgerv_kTS, cgerd_kTS,
  378. csymv_LTS, csymv_UTS,
  379. chemv_LTS, chemv_UTS, chemv_MTS, chemv_VTS,
  380. #endif
  381. #if (BUILD_COMPLEX)
  382. cgemm_kernel_nTS, cgemm_kernel_lTS, cgemm_kernel_rTS, cgemm_kernel_bTS,
  383. cgemm_betaTS,
  384. #if CGEMM_DEFAULT_UNROLL_M != CGEMM_DEFAULT_UNROLL_N
  385. cgemm_incopyTS, cgemm_itcopyTS,
  386. #else
  387. cgemm_oncopyTS, cgemm_otcopyTS,
  388. #endif
  389. cgemm_oncopyTS, cgemm_otcopyTS,
  390. #ifdef SMALL_MATRIX_OPT
  391. cgemm_small_matrix_permitTS,
  392. cgemm_small_kernel_nnTS, cgemm_small_kernel_ntTS, cgemm_small_kernel_nrTS, cgemm_small_kernel_ncTS,
  393. cgemm_small_kernel_tnTS, cgemm_small_kernel_ttTS, cgemm_small_kernel_trTS, cgemm_small_kernel_tcTS,
  394. cgemm_small_kernel_rnTS, cgemm_small_kernel_rtTS, cgemm_small_kernel_rrTS, cgemm_small_kernel_rcTS,
  395. cgemm_small_kernel_cnTS, cgemm_small_kernel_ctTS, cgemm_small_kernel_crTS, cgemm_small_kernel_ccTS,
  396. cgemm_small_kernel_b0_nnTS, cgemm_small_kernel_b0_ntTS, cgemm_small_kernel_b0_nrTS, cgemm_small_kernel_b0_ncTS,
  397. cgemm_small_kernel_b0_tnTS, cgemm_small_kernel_b0_ttTS, cgemm_small_kernel_b0_trTS, cgemm_small_kernel_b0_tcTS,
  398. cgemm_small_kernel_b0_rnTS, cgemm_small_kernel_b0_rtTS, cgemm_small_kernel_b0_rrTS, cgemm_small_kernel_b0_rcTS,
  399. cgemm_small_kernel_b0_cnTS, cgemm_small_kernel_b0_ctTS, cgemm_small_kernel_b0_crTS, cgemm_small_kernel_b0_ccTS,
  400. #endif
  401. ctrsm_kernel_LNTS, ctrsm_kernel_LTTS, ctrsm_kernel_LRTS, ctrsm_kernel_LCTS,
  402. ctrsm_kernel_RNTS, ctrsm_kernel_RTTS, ctrsm_kernel_RRTS, ctrsm_kernel_RCTS,
  403. #if CGEMM_DEFAULT_UNROLL_M != CGEMM_DEFAULT_UNROLL_N
  404. ctrsm_iunucopyTS, ctrsm_iunncopyTS, ctrsm_iutucopyTS, ctrsm_iutncopyTS,
  405. ctrsm_ilnucopyTS, ctrsm_ilnncopyTS, ctrsm_iltucopyTS, ctrsm_iltncopyTS,
  406. #else
  407. ctrsm_ounucopyTS, ctrsm_ounncopyTS, ctrsm_outucopyTS, ctrsm_outncopyTS,
  408. ctrsm_olnucopyTS, ctrsm_olnncopyTS, ctrsm_oltucopyTS, ctrsm_oltncopyTS,
  409. #endif
  410. ctrsm_ounucopyTS, ctrsm_ounncopyTS, ctrsm_outucopyTS, ctrsm_outncopyTS,
  411. ctrsm_olnucopyTS, ctrsm_olnncopyTS, ctrsm_oltucopyTS, ctrsm_oltncopyTS,
  412. #endif
  413. #endif
  414. #if (BUILD_COMPLEX)
  415. ctrmm_kernel_RNTS, ctrmm_kernel_RTTS, ctrmm_kernel_RRTS, ctrmm_kernel_RCTS,
  416. ctrmm_kernel_LNTS, ctrmm_kernel_LTTS, ctrmm_kernel_LRTS, ctrmm_kernel_LCTS,
  417. #if CGEMM_DEFAULT_UNROLL_M != CGEMM_DEFAULT_UNROLL_N
  418. ctrmm_iunucopyTS, ctrmm_iunncopyTS, ctrmm_iutucopyTS, ctrmm_iutncopyTS,
  419. ctrmm_ilnucopyTS, ctrmm_ilnncopyTS, ctrmm_iltucopyTS, ctrmm_iltncopyTS,
  420. #else
  421. ctrmm_ounucopyTS, ctrmm_ounncopyTS, ctrmm_outucopyTS, ctrmm_outncopyTS,
  422. ctrmm_olnucopyTS, ctrmm_olnncopyTS, ctrmm_oltucopyTS, ctrmm_oltncopyTS,
  423. #endif
  424. ctrmm_ounucopyTS, ctrmm_ounncopyTS, ctrmm_outucopyTS, ctrmm_outncopyTS,
  425. ctrmm_olnucopyTS, ctrmm_olnncopyTS, ctrmm_oltucopyTS, ctrmm_oltncopyTS,
  426. #if CGEMM_DEFAULT_UNROLL_M != CGEMM_DEFAULT_UNROLL_N
  427. csymm_iutcopyTS, csymm_iltcopyTS,
  428. #else
  429. csymm_outcopyTS, csymm_oltcopyTS,
  430. #endif
  431. csymm_outcopyTS, csymm_oltcopyTS,
  432. #if CGEMM_DEFAULT_UNROLL_M != CGEMM_DEFAULT_UNROLL_N
  433. chemm_iutcopyTS, chemm_iltcopyTS,
  434. #else
  435. chemm_outcopyTS, chemm_oltcopyTS,
  436. #endif
  437. chemm_outcopyTS, chemm_oltcopyTS,
  438. 0, 0, 0,
  439. #if (USE_GEMM3M)
  440. #ifdef CGEMM3M_DEFAULT_UNROLL_M
  441. CGEMM3M_DEFAULT_UNROLL_M, CGEMM3M_DEFAULT_UNROLL_N, MAX(CGEMM3M_DEFAULT_UNROLL_M, CGEMM3M_DEFAULT_UNROLL_N),
  442. #else
  443. SGEMM_DEFAULT_UNROLL_M, SGEMM_DEFAULT_UNROLL_N, MAX(SGEMM_DEFAULT_UNROLL_M, SGEMM_DEFAULT_UNROLL_N),
  444. #endif
  445. cgemm3m_kernelTS,
  446. cgemm3m_incopybTS, cgemm3m_incopyrTS,
  447. cgemm3m_incopyiTS, cgemm3m_itcopybTS,
  448. cgemm3m_itcopyrTS, cgemm3m_itcopyiTS,
  449. cgemm3m_oncopybTS, cgemm3m_oncopyrTS,
  450. cgemm3m_oncopyiTS, cgemm3m_otcopybTS,
  451. cgemm3m_otcopyrTS, cgemm3m_otcopyiTS,
  452. csymm3m_iucopybTS, csymm3m_ilcopybTS,
  453. csymm3m_iucopyrTS, csymm3m_ilcopyrTS,
  454. csymm3m_iucopyiTS, csymm3m_ilcopyiTS,
  455. csymm3m_oucopybTS, csymm3m_olcopybTS,
  456. csymm3m_oucopyrTS, csymm3m_olcopyrTS,
  457. csymm3m_oucopyiTS, csymm3m_olcopyiTS,
  458. chemm3m_iucopybTS, chemm3m_ilcopybTS,
  459. chemm3m_iucopyrTS, chemm3m_ilcopyrTS,
  460. chemm3m_iucopyiTS, chemm3m_ilcopyiTS,
  461. chemm3m_oucopybTS, chemm3m_olcopybTS,
  462. chemm3m_oucopyrTS, chemm3m_olcopyrTS,
  463. chemm3m_oucopyiTS, chemm3m_olcopyiTS,
  464. #else
  465. 0, 0, 0,
  466. NULL,
  467. NULL, NULL,
  468. NULL, NULL,
  469. NULL, NULL,
  470. NULL, NULL,
  471. NULL, NULL,
  472. NULL, NULL,
  473. NULL, NULL,
  474. NULL, NULL,
  475. NULL, NULL,
  476. NULL, NULL,
  477. NULL, NULL,
  478. NULL, NULL,
  479. NULL, NULL,
  480. NULL, NULL,
  481. NULL, NULL,
  482. NULL, NULL,
  483. NULL, NULL,
  484. NULL, NULL,
  485. #endif
  486. #endif
  487. #if (BUILD_COMPLEX)
  488. #ifndef NO_LAPACK
  489. cneg_tcopyTS,
  490. claswp_ncopyTS,
  491. #else
  492. NULL, NULL,
  493. #endif
  494. #endif
  495. #if BUILD_COMPLEX16 == 1
  496. 0, 0, 0,
  497. ZGEMM_DEFAULT_UNROLL_M, ZGEMM_DEFAULT_UNROLL_N,
  498. #ifdef ZGEMM_DEFAULT_UNROLL_MN
  499. ZGEMM_DEFAULT_UNROLL_MN,
  500. #else
  501. MAX(ZGEMM_DEFAULT_UNROLL_M, ZGEMM_DEFAULT_UNROLL_N),
  502. #endif
  503. zamax_kTS, zamin_kTS, izamax_kTS, izamin_kTS,
  504. znrm2_kTS, zasum_kTS, zsum_kTS, zcopy_kTS,
  505. zdotu_kTS, zdotc_kTS, zdrot_kTS,
  506. zaxpy_kTS, zaxpyc_kTS, zscal_kTS, zswap_kTS,
  507. zgemv_nTS, zgemv_tTS, zgemv_rTS, zgemv_cTS,
  508. zgemv_oTS, zgemv_uTS, zgemv_sTS, zgemv_dTS,
  509. zgeru_kTS, zgerc_kTS, zgerv_kTS, zgerd_kTS,
  510. zsymv_LTS, zsymv_UTS,
  511. zhemv_LTS, zhemv_UTS, zhemv_MTS, zhemv_VTS,
  512. zgemm_kernel_nTS, zgemm_kernel_lTS, zgemm_kernel_rTS, zgemm_kernel_bTS,
  513. zgemm_betaTS,
  514. #if ZGEMM_DEFAULT_UNROLL_M != ZGEMM_DEFAULT_UNROLL_N
  515. zgemm_incopyTS, zgemm_itcopyTS,
  516. #else
  517. zgemm_oncopyTS, zgemm_otcopyTS,
  518. #endif
  519. zgemm_oncopyTS, zgemm_otcopyTS,
  520. #ifdef SMALL_MATRIX_OPT
  521. zgemm_small_matrix_permitTS,
  522. zgemm_small_kernel_nnTS, zgemm_small_kernel_ntTS, zgemm_small_kernel_nrTS, zgemm_small_kernel_ncTS,
  523. zgemm_small_kernel_tnTS, zgemm_small_kernel_ttTS, zgemm_small_kernel_trTS, zgemm_small_kernel_tcTS,
  524. zgemm_small_kernel_rnTS, zgemm_small_kernel_rtTS, zgemm_small_kernel_rrTS, zgemm_small_kernel_rcTS,
  525. zgemm_small_kernel_cnTS, zgemm_small_kernel_ctTS, zgemm_small_kernel_crTS, zgemm_small_kernel_ccTS,
  526. zgemm_small_kernel_b0_nnTS, zgemm_small_kernel_b0_ntTS, zgemm_small_kernel_b0_nrTS, zgemm_small_kernel_b0_ncTS,
  527. zgemm_small_kernel_b0_tnTS, zgemm_small_kernel_b0_ttTS, zgemm_small_kernel_b0_trTS, zgemm_small_kernel_b0_tcTS,
  528. zgemm_small_kernel_b0_rnTS, zgemm_small_kernel_b0_rtTS, zgemm_small_kernel_b0_rrTS, zgemm_small_kernel_b0_rcTS,
  529. zgemm_small_kernel_b0_cnTS, zgemm_small_kernel_b0_ctTS, zgemm_small_kernel_b0_crTS, zgemm_small_kernel_b0_ccTS,
  530. #endif
  531. ztrsm_kernel_LNTS, ztrsm_kernel_LTTS, ztrsm_kernel_LRTS, ztrsm_kernel_LCTS,
  532. ztrsm_kernel_RNTS, ztrsm_kernel_RTTS, ztrsm_kernel_RRTS, ztrsm_kernel_RCTS,
  533. #if ZGEMM_DEFAULT_UNROLL_M != ZGEMM_DEFAULT_UNROLL_N
  534. ztrsm_iunucopyTS, ztrsm_iunncopyTS, ztrsm_iutucopyTS, ztrsm_iutncopyTS,
  535. ztrsm_ilnucopyTS, ztrsm_ilnncopyTS, ztrsm_iltucopyTS, ztrsm_iltncopyTS,
  536. #else
  537. ztrsm_ounucopyTS, ztrsm_ounncopyTS, ztrsm_outucopyTS, ztrsm_outncopyTS,
  538. ztrsm_olnucopyTS, ztrsm_olnncopyTS, ztrsm_oltucopyTS, ztrsm_oltncopyTS,
  539. #endif
  540. ztrsm_ounucopyTS, ztrsm_ounncopyTS, ztrsm_outucopyTS, ztrsm_outncopyTS,
  541. ztrsm_olnucopyTS, ztrsm_olnncopyTS, ztrsm_oltucopyTS, ztrsm_oltncopyTS,
  542. ztrmm_kernel_RNTS, ztrmm_kernel_RTTS, ztrmm_kernel_RRTS, ztrmm_kernel_RCTS,
  543. ztrmm_kernel_LNTS, ztrmm_kernel_LTTS, ztrmm_kernel_LRTS, ztrmm_kernel_LCTS,
  544. #if ZGEMM_DEFAULT_UNROLL_M != ZGEMM_DEFAULT_UNROLL_N
  545. ztrmm_iunucopyTS, ztrmm_iunncopyTS, ztrmm_iutucopyTS, ztrmm_iutncopyTS,
  546. ztrmm_ilnucopyTS, ztrmm_ilnncopyTS, ztrmm_iltucopyTS, ztrmm_iltncopyTS,
  547. #else
  548. ztrmm_ounucopyTS, ztrmm_ounncopyTS, ztrmm_outucopyTS, ztrmm_outncopyTS,
  549. ztrmm_olnucopyTS, ztrmm_olnncopyTS, ztrmm_oltucopyTS, ztrmm_oltncopyTS,
  550. #endif
  551. ztrmm_ounucopyTS, ztrmm_ounncopyTS, ztrmm_outucopyTS, ztrmm_outncopyTS,
  552. ztrmm_olnucopyTS, ztrmm_olnncopyTS, ztrmm_oltucopyTS, ztrmm_oltncopyTS,
  553. #if ZGEMM_DEFAULT_UNROLL_M != ZGEMM_DEFAULT_UNROLL_N
  554. zsymm_iutcopyTS, zsymm_iltcopyTS,
  555. #else
  556. zsymm_outcopyTS, zsymm_oltcopyTS,
  557. #endif
  558. zsymm_outcopyTS, zsymm_oltcopyTS,
  559. #if ZGEMM_DEFAULT_UNROLL_M != ZGEMM_DEFAULT_UNROLL_N
  560. zhemm_iutcopyTS, zhemm_iltcopyTS,
  561. #else
  562. zhemm_outcopyTS, zhemm_oltcopyTS,
  563. #endif
  564. zhemm_outcopyTS, zhemm_oltcopyTS,
  565. 0, 0, 0,
  566. #if (USE_GEMM3M)
  567. #ifdef ZGEMM3M_DEFAULT_UNROLL_M
  568. ZGEMM3M_DEFAULT_UNROLL_M, ZGEMM3M_DEFAULT_UNROLL_N, MAX(ZGEMM3M_DEFAULT_UNROLL_M, ZGEMM3M_DEFAULT_UNROLL_N),
  569. #else
  570. DGEMM_DEFAULT_UNROLL_M, DGEMM_DEFAULT_UNROLL_N, MAX(DGEMM_DEFAULT_UNROLL_M, DGEMM_DEFAULT_UNROLL_N),
  571. #endif
  572. zgemm3m_kernelTS,
  573. zgemm3m_incopybTS, zgemm3m_incopyrTS,
  574. zgemm3m_incopyiTS, zgemm3m_itcopybTS,
  575. zgemm3m_itcopyrTS, zgemm3m_itcopyiTS,
  576. zgemm3m_oncopybTS, zgemm3m_oncopyrTS,
  577. zgemm3m_oncopyiTS, zgemm3m_otcopybTS,
  578. zgemm3m_otcopyrTS, zgemm3m_otcopyiTS,
  579. zsymm3m_iucopybTS, zsymm3m_ilcopybTS,
  580. zsymm3m_iucopyrTS, zsymm3m_ilcopyrTS,
  581. zsymm3m_iucopyiTS, zsymm3m_ilcopyiTS,
  582. zsymm3m_oucopybTS, zsymm3m_olcopybTS,
  583. zsymm3m_oucopyrTS, zsymm3m_olcopyrTS,
  584. zsymm3m_oucopyiTS, zsymm3m_olcopyiTS,
  585. zhemm3m_iucopybTS, zhemm3m_ilcopybTS,
  586. zhemm3m_iucopyrTS, zhemm3m_ilcopyrTS,
  587. zhemm3m_iucopyiTS, zhemm3m_ilcopyiTS,
  588. zhemm3m_oucopybTS, zhemm3m_olcopybTS,
  589. zhemm3m_oucopyrTS, zhemm3m_olcopyrTS,
  590. zhemm3m_oucopyiTS, zhemm3m_olcopyiTS,
  591. #else
  592. 0, 0, 0,
  593. NULL,
  594. NULL, NULL,
  595. NULL, NULL,
  596. NULL, NULL,
  597. NULL, NULL,
  598. NULL, NULL,
  599. NULL, NULL,
  600. NULL, NULL,
  601. NULL, NULL,
  602. NULL, NULL,
  603. NULL, NULL,
  604. NULL, NULL,
  605. NULL, NULL,
  606. NULL, NULL,
  607. NULL, NULL,
  608. NULL, NULL,
  609. NULL, NULL,
  610. NULL, NULL,
  611. NULL, NULL,
  612. #endif
  613. #ifndef NO_LAPACK
  614. zneg_tcopyTS, zlaswp_ncopyTS,
  615. #else
  616. NULL, NULL,
  617. #endif
  618. #endif
  619. #ifdef EXPRECISION
  620. 0, 0, 0,
  621. XGEMM_DEFAULT_UNROLL_M, XGEMM_DEFAULT_UNROLL_N, MAX(XGEMM_DEFAULT_UNROLL_M, XGEMM_DEFAULT_UNROLL_N),
  622. xamax_kTS, xamin_kTS, ixamax_kTS, ixamin_kTS,
  623. xnrm2_kTS, xasum_kTS, xsum_kTS, xcopy_kTS,
  624. xdotu_kTS, xdotc_kTS, xqrot_kTS,
  625. xaxpy_kTS, xaxpyc_kTS, xscal_kTS, xswap_kTS,
  626. xgemv_nTS, xgemv_tTS, xgemv_rTS, xgemv_cTS,
  627. xgemv_oTS, xgemv_uTS, xgemv_sTS, xgemv_dTS,
  628. xgeru_kTS, xgerc_kTS, xgerv_kTS, xgerd_kTS,
  629. xsymv_LTS, xsymv_UTS,
  630. xhemv_LTS, xhemv_UTS, xhemv_MTS, xhemv_VTS,
  631. xgemm_kernel_nTS, xgemm_kernel_lTS, xgemm_kernel_rTS, xgemm_kernel_bTS,
  632. xgemm_betaTS,
  633. #if XGEMM_DEFAULT_UNROLL_M != XGEMM_DEFAULT_UNROLL_N
  634. xgemm_incopyTS, xgemm_itcopyTS,
  635. #else
  636. xgemm_oncopyTS, xgemm_otcopyTS,
  637. #endif
  638. xgemm_oncopyTS, xgemm_otcopyTS,
  639. xtrsm_kernel_LNTS, xtrsm_kernel_LTTS, xtrsm_kernel_LRTS, xtrsm_kernel_LCTS,
  640. xtrsm_kernel_RNTS, xtrsm_kernel_RTTS, xtrsm_kernel_RRTS, xtrsm_kernel_RCTS,
  641. #if XGEMM_DEFAULT_UNROLL_M != XGEMM_DEFAULT_UNROLL_N
  642. xtrsm_iunucopyTS, xtrsm_iunncopyTS, xtrsm_iutucopyTS, xtrsm_iutncopyTS,
  643. xtrsm_ilnucopyTS, xtrsm_ilnncopyTS, xtrsm_iltucopyTS, xtrsm_iltncopyTS,
  644. #else
  645. xtrsm_ounucopyTS, xtrsm_ounncopyTS, xtrsm_outucopyTS, xtrsm_outncopyTS,
  646. xtrsm_olnucopyTS, xtrsm_olnncopyTS, xtrsm_oltucopyTS, xtrsm_oltncopyTS,
  647. #endif
  648. xtrsm_ounucopyTS, xtrsm_ounncopyTS, xtrsm_outucopyTS, xtrsm_outncopyTS,
  649. xtrsm_olnucopyTS, xtrsm_olnncopyTS, xtrsm_oltucopyTS, xtrsm_oltncopyTS,
  650. xtrmm_kernel_RNTS, xtrmm_kernel_RTTS, xtrmm_kernel_RRTS, xtrmm_kernel_RCTS,
  651. xtrmm_kernel_LNTS, xtrmm_kernel_LTTS, xtrmm_kernel_LRTS, xtrmm_kernel_LCTS,
  652. #if XGEMM_DEFAULT_UNROLL_M != XGEMM_DEFAULT_UNROLL_N
  653. xtrmm_iunucopyTS, xtrmm_iunncopyTS, xtrmm_iutucopyTS, xtrmm_iutncopyTS,
  654. xtrmm_ilnucopyTS, xtrmm_ilnncopyTS, xtrmm_iltucopyTS, xtrmm_iltncopyTS,
  655. #else
  656. xtrmm_ounucopyTS, xtrmm_ounncopyTS, xtrmm_outucopyTS, xtrmm_outncopyTS,
  657. xtrmm_olnucopyTS, xtrmm_olnncopyTS, xtrmm_oltucopyTS, xtrmm_oltncopyTS,
  658. #endif
  659. xtrmm_ounucopyTS, xtrmm_ounncopyTS, xtrmm_outucopyTS, xtrmm_outncopyTS,
  660. xtrmm_olnucopyTS, xtrmm_olnncopyTS, xtrmm_oltucopyTS, xtrmm_oltncopyTS,
  661. #if XGEMM_DEFAULT_UNROLL_M != XGEMM_DEFAULT_UNROLL_N
  662. xsymm_iutcopyTS, xsymm_iltcopyTS,
  663. #else
  664. xsymm_outcopyTS, xsymm_oltcopyTS,
  665. #endif
  666. xsymm_outcopyTS, xsymm_oltcopyTS,
  667. #if XGEMM_DEFAULT_UNROLL_M != XGEMM_DEFAULT_UNROLL_N
  668. xhemm_iutcopyTS, xhemm_iltcopyTS,
  669. #else
  670. xhemm_outcopyTS, xhemm_oltcopyTS,
  671. #endif
  672. xhemm_outcopyTS, xhemm_oltcopyTS,
  673. 0, 0, 0,
  674. #if (USE_GEMM3M)
  675. QGEMM_DEFAULT_UNROLL_M, QGEMM_DEFAULT_UNROLL_N, MAX(QGEMM_DEFAULT_UNROLL_M, QGEMM_DEFAULT_UNROLL_N),
  676. xgemm3m_kernelTS,
  677. xgemm3m_incopybTS, xgemm3m_incopyrTS,
  678. xgemm3m_incopyiTS, xgemm3m_itcopybTS,
  679. xgemm3m_itcopyrTS, xgemm3m_itcopyiTS,
  680. xgemm3m_oncopybTS, xgemm3m_oncopyrTS,
  681. xgemm3m_oncopyiTS, xgemm3m_otcopybTS,
  682. xgemm3m_otcopyrTS, xgemm3m_otcopyiTS,
  683. xsymm3m_iucopybTS, xsymm3m_ilcopybTS,
  684. xsymm3m_iucopyrTS, xsymm3m_ilcopyrTS,
  685. xsymm3m_iucopyiTS, xsymm3m_ilcopyiTS,
  686. xsymm3m_oucopybTS, xsymm3m_olcopybTS,
  687. xsymm3m_oucopyrTS, xsymm3m_olcopyrTS,
  688. xsymm3m_oucopyiTS, xsymm3m_olcopyiTS,
  689. xhemm3m_iucopybTS, xhemm3m_ilcopybTS,
  690. xhemm3m_iucopyrTS, xhemm3m_ilcopyrTS,
  691. xhemm3m_iucopyiTS, xhemm3m_ilcopyiTS,
  692. xhemm3m_oucopybTS, xhemm3m_olcopybTS,
  693. xhemm3m_oucopyrTS, xhemm3m_olcopyrTS,
  694. xhemm3m_oucopyiTS, xhemm3m_olcopyiTS,
  695. #else
  696. 0, 0, 0,
  697. NULL,
  698. NULL, NULL,
  699. NULL, NULL,
  700. NULL, NULL,
  701. NULL, NULL,
  702. NULL, NULL,
  703. NULL, NULL,
  704. NULL, NULL,
  705. NULL, NULL,
  706. NULL, NULL,
  707. NULL, NULL,
  708. NULL, NULL,
  709. NULL, NULL,
  710. NULL, NULL,
  711. NULL, NULL,
  712. NULL, NULL,
  713. NULL, NULL,
  714. NULL, NULL,
  715. NULL, NULL,
  716. #endif
  717. #ifndef NO_LAPACK
  718. xneg_tcopyTS, xlaswp_ncopyTS,
  719. #else
  720. NULL, NULL,
  721. #endif
  722. #endif
  723. init_parameter,
  724. SNUMOPT, DNUMOPT, QNUMOPT,
  725. #if BUILD_SINGLE == 1
  726. saxpby_kTS,
  727. #endif
  728. #if BUILD_DOUBLE == 1
  729. daxpby_kTS,
  730. #endif
  731. #if BUILD_COMPLEX == 1
  732. caxpby_kTS,
  733. #endif
  734. #if BUILD_COMPLEX16== 1
  735. zaxpby_kTS,
  736. #endif
  737. #if BUILD_SINGLE == 1
  738. somatcopy_k_cnTS, somatcopy_k_ctTS, somatcopy_k_rnTS, somatcopy_k_rtTS,
  739. #endif
  740. #if BUILD_DOUBLE== 1
  741. domatcopy_k_cnTS, domatcopy_k_ctTS, domatcopy_k_rnTS, domatcopy_k_rtTS,
  742. #endif
  743. #if BUILD_COMPLEX == 1
  744. comatcopy_k_cnTS, comatcopy_k_ctTS, comatcopy_k_rnTS, comatcopy_k_rtTS,
  745. comatcopy_k_cncTS, comatcopy_k_ctcTS, comatcopy_k_rncTS, comatcopy_k_rtcTS,
  746. #endif
  747. #if BUILD_COMPLEX16 == 1
  748. zomatcopy_k_cnTS, zomatcopy_k_ctTS, zomatcopy_k_rnTS, zomatcopy_k_rtTS,
  749. zomatcopy_k_cncTS, zomatcopy_k_ctcTS, zomatcopy_k_rncTS, zomatcopy_k_rtcTS,
  750. #endif
  751. #if BUILD_SINGLE == 1
  752. simatcopy_k_cnTS, simatcopy_k_ctTS, simatcopy_k_rnTS, simatcopy_k_rtTS,
  753. #endif
  754. #if BUILD_DOUBLE== 1
  755. dimatcopy_k_cnTS, dimatcopy_k_ctTS, dimatcopy_k_rnTS, dimatcopy_k_rtTS,
  756. #endif
  757. #if BUILD_COMPLEX== 1
  758. cimatcopy_k_cnTS, cimatcopy_k_ctTS, cimatcopy_k_rnTS, cimatcopy_k_rtTS,
  759. cimatcopy_k_cncTS, cimatcopy_k_ctcTS, cimatcopy_k_rncTS, cimatcopy_k_rtcTS,
  760. #endif
  761. #if BUILD_COMPLEX16==1
  762. zimatcopy_k_cnTS, zimatcopy_k_ctTS, zimatcopy_k_rnTS, zimatcopy_k_rtTS,
  763. zimatcopy_k_cncTS, zimatcopy_k_ctcTS, zimatcopy_k_rncTS, zimatcopy_k_rtcTS,
  764. #endif
  765. #if BUILD_SINGLE == 1
  766. sgeadd_kTS,
  767. #endif
  768. #if BUILD_DOUBLE==1
  769. dgeadd_kTS,
  770. #endif
  771. #if BUILD_COMPLEX==1
  772. cgeadd_kTS,
  773. #endif
  774. #if BUILD_COMPLEX16==1
  775. zgeadd_kTS,
  776. #endif
  777. };
  778. #if (ARCH_ARM64)
  779. static void init_parameter(void) {
  780. #if (BUILD_BFLOAT16)
  781. TABLE_NAME.sbgemm_p = SBGEMM_DEFAULT_P;
  782. #endif
  783. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  784. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  785. #endif
  786. #if BUILD_DOUBLE == 1 || (BUILD_COMPLEX16==1)
  787. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  788. #endif
  789. #if BUILD_COMPLEX==1
  790. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  791. #endif
  792. #if BUILD_COMPLEX16==1
  793. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  794. #endif
  795. #if (BUILD_BFLOAT16)
  796. TABLE_NAME.sbgemm_q = SBGEMM_DEFAULT_Q;
  797. #endif
  798. #if BUILD_SINGLE == 1 || (BUILD_COMPLEX==1)
  799. TABLE_NAME.sgemm_q = SGEMM_DEFAULT_Q;
  800. #endif
  801. #if BUILD_DOUBLE== 1 || (BUILD_COMPLEX16==1)
  802. TABLE_NAME.dgemm_q = DGEMM_DEFAULT_Q;
  803. #endif
  804. #if BUILD_COMPLEX== 1
  805. TABLE_NAME.cgemm_q = CGEMM_DEFAULT_Q;
  806. #endif
  807. #if BUILD_COMPLEX16==1
  808. TABLE_NAME.zgemm_q = ZGEMM_DEFAULT_Q;
  809. #endif
  810. #if (BUILD_BFLOAT16)
  811. TABLE_NAME.sbgemm_r = SBGEMM_DEFAULT_R;
  812. #endif
  813. #if BUILD_SINGLE == 1 || (BUILD_COMPLEX==1)
  814. TABLE_NAME.sgemm_r = SGEMM_DEFAULT_R;
  815. #endif
  816. #if BUILD_DOUBLE==1 || (BUILD_COMPLEX16==1)
  817. TABLE_NAME.dgemm_r = DGEMM_DEFAULT_R;
  818. #endif
  819. #if BUILD_COMPLEX==1
  820. TABLE_NAME.cgemm_r = CGEMM_DEFAULT_R;
  821. #endif
  822. #if BUILD_COMPLEX16==1
  823. TABLE_NAME.zgemm_r = ZGEMM_DEFAULT_R;
  824. #endif
  825. #ifdef EXPRECISION
  826. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  827. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  828. TABLE_NAME.qgemm_q = QGEMM_DEFAULT_Q;
  829. TABLE_NAME.xgemm_q = XGEMM_DEFAULT_Q;
  830. TABLE_NAME.qgemm_r = QGEMM_DEFAULT_R;
  831. TABLE_NAME.xgemm_r = XGEMM_DEFAULT_R;
  832. #endif
  833. #if (USE_GEMM3M)
  834. #ifdef CGEMM3M_DEFAULT_P
  835. TABLE_NAME.cgemm3m_p = CGEMM3M_DEFAULT_P;
  836. #else
  837. TABLE_NAME.cgemm3m_p = TABLE_NAME.sgemm_p;
  838. #endif
  839. #ifdef ZGEMM3M_DEFAULT_P
  840. TABLE_NAME.zgemm3m_p = ZGEMM3M_DEFAULT_P;
  841. #else
  842. TABLE_NAME.zgemm3m_p = TABLE_NAME.dgemm_p;
  843. #endif
  844. #ifdef CGEMM3M_DEFAULT_Q
  845. TABLE_NAME.cgemm3m_q = CGEMM3M_DEFAULT_Q;
  846. #else
  847. TABLE_NAME.cgemm3m_q = TABLE_NAME.sgemm_q;
  848. #endif
  849. #ifdef ZGEMM3M_DEFAULT_Q
  850. TABLE_NAME.zgemm3m_q = ZGEMM3M_DEFAULT_Q;
  851. #else
  852. TABLE_NAME.zgemm3m_q = TABLE_NAME.dgemm_q;
  853. #endif
  854. #ifdef CGEMM3M_DEFAULT_R
  855. TABLE_NAME.cgemm3m_r = CGEMM3M_DEFAULT_R;
  856. #else
  857. TABLE_NAME.cgemm3m_r = TABLE_NAME.sgemm_r;
  858. #endif
  859. #ifdef ZGEMM3M_DEFAULT_R
  860. TABLE_NAME.zgemm3m_r = ZGEMM3M_DEFAULT_R;
  861. #else
  862. TABLE_NAME.zgemm3m_r = TABLE_NAME.dgemm_r;
  863. #endif
  864. #ifdef EXPRECISION
  865. TABLE_NAME.xgemm3m_p = TABLE_NAME.qgemm_p;
  866. TABLE_NAME.xgemm3m_q = TABLE_NAME.qgemm_q;
  867. TABLE_NAME.xgemm3m_r = TABLE_NAME.qgemm_r;
  868. #endif
  869. #endif
  870. }
  871. #else // (ARCH_ARM64)
  872. #if defined(ARCH_MIPS64)
  873. static void init_parameter(void) {
  874. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  875. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  876. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  877. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  878. TABLE_NAME.sgemm_q = SGEMM_DEFAULT_Q;
  879. TABLE_NAME.dgemm_q = DGEMM_DEFAULT_Q;
  880. TABLE_NAME.cgemm_q = CGEMM_DEFAULT_Q;
  881. TABLE_NAME.zgemm_q = ZGEMM_DEFAULT_Q;
  882. TABLE_NAME.sgemm_r = SGEMM_DEFAULT_R;
  883. TABLE_NAME.dgemm_r = 640;
  884. TABLE_NAME.cgemm_r = CGEMM_DEFAULT_R;
  885. TABLE_NAME.zgemm_r = ZGEMM_DEFAULT_R;
  886. #ifdef EXPRECISION
  887. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  888. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  889. TABLE_NAME.qgemm_q = QGEMM_DEFAULT_Q;
  890. TABLE_NAME.xgemm_q = XGEMM_DEFAULT_Q;
  891. TABLE_NAME.qgemm_r = QGEMM_DEFAULT_R;
  892. TABLE_NAME.xgemm_r = XGEMM_DEFAULT_R;
  893. #endif
  894. #if defined(USE_GEMM3M)
  895. #ifdef CGEMM3M_DEFAULT_P
  896. TABLE_NAME.cgemm3m_p = CGEMM3M_DEFAULT_P;
  897. #else
  898. TABLE_NAME.cgemm3m_p = TABLE_NAME.sgemm_p;
  899. #endif
  900. #ifdef ZGEMM3M_DEFAULT_P
  901. TABLE_NAME.zgemm3m_p = ZGEMM3M_DEFAULT_P;
  902. #else
  903. TABLE_NAME.zgemm3m_p = TABLE_NAME.dgemm_p;
  904. #endif
  905. #ifdef CGEMM3M_DEFAULT_Q
  906. TABLE_NAME.cgemm3m_q = CGEMM3M_DEFAULT_Q;
  907. #else
  908. TABLE_NAME.cgemm3m_q = TABLE_NAME.sgemm_q;
  909. #endif
  910. #ifdef ZGEMM3M_DEFAULT_Q
  911. TABLE_NAME.zgemm3m_q = ZGEMM3M_DEFAULT_Q;
  912. #else
  913. TABLE_NAME.zgemm3m_q = TABLE_NAME.dgemm_q;
  914. #endif
  915. #ifdef CGEMM3M_DEFAULT_R
  916. TABLE_NAME.cgemm3m_r = CGEMM3M_DEFAULT_R;
  917. #else
  918. TABLE_NAME.cgemm3m_r = TABLE_NAME.sgemm_r;
  919. #endif
  920. #ifdef ZGEMM3M_DEFAULT_R
  921. TABLE_NAME.zgemm3m_r = ZGEMM3M_DEFAULT_R;
  922. #else
  923. TABLE_NAME.zgemm3m_r = TABLE_NAME.dgemm_r;
  924. #endif
  925. #ifdef EXPRECISION
  926. TABLE_NAME.xgemm3m_p = TABLE_NAME.qgemm_p;
  927. TABLE_NAME.xgemm3m_q = TABLE_NAME.qgemm_q;
  928. TABLE_NAME.xgemm3m_r = TABLE_NAME.qgemm_r;
  929. #endif
  930. #endif
  931. }
  932. #else // (ARCH_MIPS64)
  933. #if (ARCH_LOONGARCH64)
  934. static int get_L3_size() {
  935. int ret = 0, id = 0x14;
  936. __asm__ volatile (
  937. "cpucfg %[ret], %[id]"
  938. : [ret]"=r"(ret)
  939. : [id]"r"(id)
  940. : "memory"
  941. );
  942. return ((ret & 0xffff) + 1) * pow(2, ((ret >> 16) & 0xff)) * pow(2, ((ret >> 24) & 0x7f)) / 1024 / 1024; // MB
  943. }
  944. static void init_parameter(void) {
  945. #ifdef BUILD_BFLOAT16
  946. TABLE_NAME.sbgemm_p = SBGEMM_DEFAULT_P;
  947. #endif
  948. #ifdef BUILD_BFLOAT16
  949. TABLE_NAME.sbgemm_r = SBGEMM_DEFAULT_R;
  950. #endif
  951. #if defined(LOONGSON3R5)
  952. int L3_size = get_L3_size();
  953. #ifdef SMP
  954. if(blas_num_threads == 1){
  955. #endif
  956. //single thread
  957. if (L3_size == 32){ // 3C5000 and 3D5000
  958. TABLE_NAME.sgemm_p = 256;
  959. TABLE_NAME.sgemm_q = 384;
  960. TABLE_NAME.sgemm_r = 8192;
  961. TABLE_NAME.dgemm_p = 112;
  962. TABLE_NAME.dgemm_q = 289;
  963. TABLE_NAME.dgemm_r = 4096;
  964. TABLE_NAME.cgemm_p = 128;
  965. TABLE_NAME.cgemm_q = 256;
  966. TABLE_NAME.cgemm_r = 4096;
  967. TABLE_NAME.zgemm_p = 128;
  968. TABLE_NAME.zgemm_q = 128;
  969. TABLE_NAME.zgemm_r = 2048;
  970. } else { // 3A5000 and 3C5000L
  971. TABLE_NAME.sgemm_p = 256;
  972. TABLE_NAME.sgemm_q = 384;
  973. TABLE_NAME.sgemm_r = 4096;
  974. TABLE_NAME.dgemm_p = 112;
  975. TABLE_NAME.dgemm_q = 300;
  976. TABLE_NAME.dgemm_r = 3024;
  977. TABLE_NAME.cgemm_p = 128;
  978. TABLE_NAME.cgemm_q = 256;
  979. TABLE_NAME.cgemm_r = 2048;
  980. TABLE_NAME.zgemm_p = 128;
  981. TABLE_NAME.zgemm_q = 128;
  982. TABLE_NAME.zgemm_r = 1024;
  983. }
  984. #ifdef SMP
  985. }else{
  986. //multi thread
  987. if (L3_size == 32){ // 3C5000 and 3D5000
  988. TABLE_NAME.sgemm_p = 256;
  989. TABLE_NAME.sgemm_q = 384;
  990. TABLE_NAME.sgemm_r = 1024;
  991. TABLE_NAME.dgemm_p = 112;
  992. TABLE_NAME.dgemm_q = 289;
  993. TABLE_NAME.dgemm_r = 342;
  994. TABLE_NAME.cgemm_p = 128;
  995. TABLE_NAME.cgemm_q = 256;
  996. TABLE_NAME.cgemm_r = 512;
  997. TABLE_NAME.zgemm_p = 128;
  998. TABLE_NAME.zgemm_q = 128;
  999. TABLE_NAME.zgemm_r = 512;
  1000. } else { // 3A5000 and 3C5000L
  1001. TABLE_NAME.sgemm_p = 256;
  1002. TABLE_NAME.sgemm_q = 384;
  1003. TABLE_NAME.sgemm_r = 2048;
  1004. TABLE_NAME.dgemm_p = 112;
  1005. TABLE_NAME.dgemm_q = 300;
  1006. TABLE_NAME.dgemm_r = 738;
  1007. TABLE_NAME.cgemm_p = 128;
  1008. TABLE_NAME.cgemm_q = 256;
  1009. TABLE_NAME.cgemm_r = 1024;
  1010. TABLE_NAME.zgemm_p = 128;
  1011. TABLE_NAME.zgemm_q = 128;
  1012. TABLE_NAME.zgemm_r = 1024;
  1013. }
  1014. }
  1015. #endif
  1016. #else
  1017. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1018. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1019. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1020. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1021. TABLE_NAME.sgemm_q = SGEMM_DEFAULT_Q;
  1022. TABLE_NAME.dgemm_q = DGEMM_DEFAULT_Q;
  1023. TABLE_NAME.cgemm_q = CGEMM_DEFAULT_Q;
  1024. TABLE_NAME.zgemm_q = ZGEMM_DEFAULT_Q;
  1025. TABLE_NAME.sgemm_r = SGEMM_DEFAULT_R;
  1026. TABLE_NAME.dgemm_r = DGEMM_DEFAULT_R;
  1027. TABLE_NAME.cgemm_r = CGEMM_DEFAULT_R;
  1028. TABLE_NAME.zgemm_r = ZGEMM_DEFAULT_R;
  1029. #endif
  1030. #ifdef BUILD_BFLOAT16
  1031. TABLE_NAME.sbgemm_q = SBGEMM_DEFAULT_Q;
  1032. #endif
  1033. }
  1034. #else // (ARCH_LOONGARCH64)
  1035. #if (ARCH_POWER)
  1036. static void init_parameter(void) {
  1037. #ifdef BUILD_BFLOAT16
  1038. TABLE_NAME.sbgemm_p = SBGEMM_DEFAULT_P;
  1039. #endif
  1040. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1041. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1042. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1043. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1044. #ifdef BUILD_BFLOAT16
  1045. TABLE_NAME.sbgemm_r = SBGEMM_DEFAULT_R;
  1046. #endif
  1047. TABLE_NAME.sgemm_r = SGEMM_DEFAULT_R;
  1048. TABLE_NAME.dgemm_r = DGEMM_DEFAULT_R;
  1049. TABLE_NAME.cgemm_r = CGEMM_DEFAULT_R;
  1050. TABLE_NAME.zgemm_r = ZGEMM_DEFAULT_R;
  1051. #ifdef BUILD_BFLOAT16
  1052. TABLE_NAME.sbgemm_q = SBGEMM_DEFAULT_Q;
  1053. #endif
  1054. TABLE_NAME.sgemm_q = SGEMM_DEFAULT_Q;
  1055. TABLE_NAME.dgemm_q = DGEMM_DEFAULT_Q;
  1056. TABLE_NAME.cgemm_q = CGEMM_DEFAULT_Q;
  1057. TABLE_NAME.zgemm_q = ZGEMM_DEFAULT_Q;
  1058. }
  1059. #else //POWER
  1060. #if (ARCH_ZARCH)
  1061. static void init_parameter(void) {
  1062. #ifdef BUILD_BFLOAT16
  1063. TABLE_NAME.sbgemm_p = SBGEMM_DEFAULT_P;
  1064. #endif
  1065. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1066. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1067. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1068. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1069. #ifdef BUILD_BFLOAT16
  1070. TABLE_NAME.sbgemm_r = SBGEMM_DEFAULT_R;
  1071. #endif
  1072. TABLE_NAME.sgemm_r = SGEMM_DEFAULT_R;
  1073. TABLE_NAME.dgemm_r = DGEMM_DEFAULT_R;
  1074. TABLE_NAME.cgemm_r = CGEMM_DEFAULT_R;
  1075. TABLE_NAME.zgemm_r = ZGEMM_DEFAULT_R;
  1076. #ifdef BUILD_BFLOAT16
  1077. TABLE_NAME.sbgemm_q = SBGEMM_DEFAULT_Q;
  1078. #endif
  1079. TABLE_NAME.sgemm_q = SGEMM_DEFAULT_Q;
  1080. TABLE_NAME.dgemm_q = DGEMM_DEFAULT_Q;
  1081. TABLE_NAME.cgemm_q = CGEMM_DEFAULT_Q;
  1082. TABLE_NAME.zgemm_q = ZGEMM_DEFAULT_Q;
  1083. }
  1084. #else //ZARCH
  1085. #ifdef ARCH_X86
  1086. static int get_l2_size_old(void){
  1087. int i, eax, ebx, ecx, edx, cpuid_level;
  1088. int info[15];
  1089. cpuid(2, &eax, &ebx, &ecx, &edx);
  1090. info[ 0] = BITMASK(eax, 8, 0xff);
  1091. info[ 1] = BITMASK(eax, 16, 0xff);
  1092. info[ 2] = BITMASK(eax, 24, 0xff);
  1093. info[ 3] = BITMASK(ebx, 0, 0xff);
  1094. info[ 4] = BITMASK(ebx, 8, 0xff);
  1095. info[ 5] = BITMASK(ebx, 16, 0xff);
  1096. info[ 6] = BITMASK(ebx, 24, 0xff);
  1097. info[ 7] = BITMASK(ecx, 0, 0xff);
  1098. info[ 8] = BITMASK(ecx, 8, 0xff);
  1099. info[ 9] = BITMASK(ecx, 16, 0xff);
  1100. info[10] = BITMASK(ecx, 24, 0xff);
  1101. info[11] = BITMASK(edx, 0, 0xff);
  1102. info[12] = BITMASK(edx, 8, 0xff);
  1103. info[13] = BITMASK(edx, 16, 0xff);
  1104. info[14] = BITMASK(edx, 24, 0xff);
  1105. for (i = 0; i < 15; i++){
  1106. switch (info[i]){
  1107. /* This table is from http://www.sandpile.org/ia32/cpuid.htm */
  1108. case 0x1a :
  1109. return 96;
  1110. case 0x39 :
  1111. case 0x3b :
  1112. case 0x41 :
  1113. case 0x79 :
  1114. case 0x81 :
  1115. return 128;
  1116. case 0x3a :
  1117. return 192;
  1118. case 0x21 :
  1119. case 0x3c :
  1120. case 0x42 :
  1121. case 0x7a :
  1122. case 0x7e :
  1123. case 0x82 :
  1124. return 256;
  1125. case 0x3d :
  1126. return 384;
  1127. case 0x3e :
  1128. case 0x43 :
  1129. case 0x7b :
  1130. case 0x7f :
  1131. case 0x83 :
  1132. case 0x86 :
  1133. return 512;
  1134. case 0x44 :
  1135. case 0x78 :
  1136. case 0x7c :
  1137. case 0x84 :
  1138. case 0x87 :
  1139. return 1024;
  1140. case 0x45 :
  1141. case 0x7d :
  1142. case 0x85 :
  1143. return 2048;
  1144. case 0x48 :
  1145. return 3184;
  1146. case 0x49 :
  1147. return 4096;
  1148. case 0x4e :
  1149. return 6144;
  1150. }
  1151. }
  1152. // return 0;
  1153. fprintf (stderr,"OpenBLAS WARNING - could not determine the L2 cache size on this system, assuming 256k\n");
  1154. return 256;
  1155. }
  1156. #endif
  1157. static __inline__ int get_l2_size(void){
  1158. int eax, ebx, ecx, edx, l2;
  1159. cpuid(0x80000006, &eax, &ebx, &ecx, &edx);
  1160. l2 = BITMASK(ecx, 16, 0xffff);
  1161. #ifndef ARCH_X86
  1162. if (l2 <= 0) {
  1163. fprintf (stderr,"OpenBLAS WARNING - could not determine the L2 cache size on this system, assuming 256k\n");
  1164. return 256;
  1165. }
  1166. return l2;
  1167. #else
  1168. if (l2 > 0) return l2;
  1169. return get_l2_size_old();
  1170. #endif
  1171. }
  1172. static __inline__ int get_l3_size(void){
  1173. int eax, ebx, ecx, edx;
  1174. cpuid(0x80000006, &eax, &ebx, &ecx, &edx);
  1175. return BITMASK(edx, 18, 0x3fff) * 512;
  1176. }
  1177. static void init_parameter(void) {
  1178. int l2 = get_l2_size();
  1179. (void) l2; /* dirty trick to suppress unused variable warning for targets */
  1180. /* where the GEMM unrolling parameters do not depend on l2 */
  1181. #ifdef BUILD_BFLOAT16
  1182. TABLE_NAME.sbgemm_p = SBGEMM_DEFAULT_P;
  1183. TABLE_NAME.sbgemm_q = SBGEMM_DEFAULT_Q;
  1184. #endif
  1185. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1186. TABLE_NAME.sgemm_q = SGEMM_DEFAULT_Q;
  1187. #endif
  1188. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16)
  1189. TABLE_NAME.dgemm_q = DGEMM_DEFAULT_Q;
  1190. #endif
  1191. #if BUILD_COMPLEX == 1
  1192. TABLE_NAME.cgemm_q = CGEMM_DEFAULT_Q;
  1193. #endif
  1194. #if BUILD_COMPLEX16==1
  1195. TABLE_NAME.zgemm_q = ZGEMM_DEFAULT_Q;
  1196. #endif
  1197. #if BUILD_COMPLEX == 1
  1198. #ifdef CGEMM3M_DEFAULT_Q
  1199. TABLE_NAME.cgemm3m_q = CGEMM3M_DEFAULT_Q;
  1200. #else
  1201. TABLE_NAME.cgemm3m_q = SGEMM_DEFAULT_Q;
  1202. #endif
  1203. #endif
  1204. #if BUILD_COMPLEX16 == 1
  1205. #ifdef ZGEMM3M_DEFAULT_Q
  1206. TABLE_NAME.zgemm3m_q = ZGEMM3M_DEFAULT_Q;
  1207. #else
  1208. TABLE_NAME.zgemm3m_q = DGEMM_DEFAULT_Q;
  1209. #endif
  1210. #endif
  1211. #ifdef EXPRECISION
  1212. TABLE_NAME.qgemm_q = QGEMM_DEFAULT_Q;
  1213. TABLE_NAME.xgemm_q = XGEMM_DEFAULT_Q;
  1214. TABLE_NAME.xgemm3m_q = QGEMM_DEFAULT_Q;
  1215. #endif
  1216. #if defined(CORE_KATMAI) || defined(CORE_COPPERMINE) || defined(CORE_BANIAS) || defined(CORE_YONAH) || defined(CORE_ATHLON)
  1217. #ifdef DEBUG
  1218. fprintf(stderr, "Katmai, Coppermine, Banias, Athlon\n");
  1219. #endif
  1220. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1221. TABLE_NAME.sgemm_p = 64 * (l2 >> 7);
  1222. #endif
  1223. #if BUILD_DOUBLE == 1 || (BUILD_COMPLEX16==1)
  1224. TABLE_NAME.dgemm_p = 32 * (l2 >> 7);
  1225. #endif
  1226. #if BUILD_COMPLEX==1
  1227. TABLE_NAME.cgemm_p = 32 * (l2 >> 7);
  1228. #endif
  1229. #if BUILD_COMPLEX16==1
  1230. TABLE_NAME.zgemm_p = 16 * (l2 >> 7);
  1231. #endif
  1232. #ifdef EXPRECISION
  1233. TABLE_NAME.qgemm_p = 16 * (l2 >> 7);
  1234. TABLE_NAME.xgemm_p = 8 * (l2 >> 7);
  1235. #endif
  1236. #endif
  1237. #ifdef CORE_NORTHWOOD
  1238. #ifdef DEBUG
  1239. fprintf(stderr, "Northwood\n");
  1240. #endif
  1241. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1242. TABLE_NAME.sgemm_p = 96 * (l2 >> 7);
  1243. #endif
  1244. #if BUILD_DOUBLE == 1 || (BUILD_COMPLEX16==1)
  1245. TABLE_NAME.dgemm_p = 48 * (l2 >> 7);
  1246. #endif
  1247. #if BUILD_COMPLEX==1
  1248. TABLE_NAME.cgemm_p = 48 * (l2 >> 7);
  1249. #endif
  1250. #if BUILD_COMPLEX16==1
  1251. TABLE_NAME.zgemm_p = 24 * (l2 >> 7);
  1252. #endif
  1253. #ifdef EXPRECISION
  1254. TABLE_NAME.qgemm_p = 24 * (l2 >> 7);
  1255. TABLE_NAME.xgemm_p = 12 * (l2 >> 7);
  1256. #endif
  1257. #endif
  1258. #ifdef ATOM
  1259. #ifdef DEBUG
  1260. fprintf(stderr, "Atom\n");
  1261. #endif
  1262. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1263. TABLE_NAME.sgemm_p = 256;
  1264. #endif
  1265. #if BUILD_DOUBLE ==1 || (BUILD_COMPLEX16==1)
  1266. TABLE_NAME.dgemm_p = 128;
  1267. #endif
  1268. #if BUILD_COMPLEX==1
  1269. TABLE_NAME.cgemm_p = 128;
  1270. #endif
  1271. #if BUILD_COMPLEX16==1
  1272. TABLE_NAME.zgemm_p = 64;
  1273. #endif
  1274. #ifdef EXPRECISION
  1275. TABLE_NAME.qgemm_p = 64;
  1276. TABLE_NAME.xgemm_p = 32;
  1277. #endif
  1278. #endif
  1279. #ifdef CORE_PRESCOTT
  1280. #ifdef DEBUG
  1281. fprintf(stderr, "Prescott\n");
  1282. #endif
  1283. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1284. TABLE_NAME.sgemm_p = 56 * (l2 >> 7);
  1285. #endif
  1286. #if BUILD_DOUBLE ==1 || (BUILD_COMPLEX16==1)
  1287. TABLE_NAME.dgemm_p = 28 * (l2 >> 7);
  1288. #endif
  1289. #if BUILD_COMPLEX==1
  1290. TABLE_NAME.cgemm_p = 28 * (l2 >> 7);
  1291. #endif
  1292. #if BUILD_COMPLEX16 == 1
  1293. TABLE_NAME.zgemm_p = 14 * (l2 >> 7);
  1294. #endif
  1295. #ifdef EXPRECISION
  1296. TABLE_NAME.qgemm_p = 14 * (l2 >> 7);
  1297. TABLE_NAME.xgemm_p = 7 * (l2 >> 7);
  1298. #endif
  1299. #endif
  1300. #ifdef CORE2
  1301. #ifdef DEBUG
  1302. fprintf(stderr, "Core2\n");
  1303. #endif
  1304. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1305. TABLE_NAME.sgemm_p = 92 * (l2 >> 9) + 8;
  1306. #endif
  1307. #if BUILD_DOUBLE==1 || (BUILD_COMPLEX16==1)
  1308. TABLE_NAME.dgemm_p = 46 * (l2 >> 9) + 8;
  1309. #endif
  1310. #if BUILD_COMPLEX==1
  1311. TABLE_NAME.cgemm_p = 46 * (l2 >> 9) + 4;
  1312. #endif
  1313. #if BUILD_COMPLEX16==1
  1314. TABLE_NAME.zgemm_p = 23 * (l2 >> 9) + 4;
  1315. #endif
  1316. #ifdef EXPRECISION
  1317. TABLE_NAME.qgemm_p = 92 * (l2 >> 9) + 8;
  1318. TABLE_NAME.xgemm_p = 46 * (l2 >> 9) + 4;
  1319. #endif
  1320. #endif
  1321. #ifdef PENRYN
  1322. #ifdef DEBUG
  1323. fprintf(stderr, "Penryn\n");
  1324. #endif
  1325. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1326. TABLE_NAME.sgemm_p = 42 * (l2 >> 9) + 8;
  1327. #endif
  1328. #if BUILD_DOUBLE == 1 || (BUILD_COMPLEX16==1)
  1329. TABLE_NAME.dgemm_p = 42 * (l2 >> 9) + 8;
  1330. #endif
  1331. #if BUILD_COMPLEX==1
  1332. TABLE_NAME.cgemm_p = 21 * (l2 >> 9) + 4;
  1333. #endif
  1334. #if BUILD_COMPLEX16==1
  1335. TABLE_NAME.zgemm_p = 21 * (l2 >> 9) + 4;
  1336. #endif
  1337. #ifdef EXPRECISION
  1338. TABLE_NAME.qgemm_p = 42 * (l2 >> 9) + 8;
  1339. TABLE_NAME.xgemm_p = 21 * (l2 >> 9) + 4;
  1340. #endif
  1341. #endif
  1342. #ifdef DUNNINGTON
  1343. #ifdef DEBUG
  1344. fprintf(stderr, "Dunnington\n");
  1345. #endif
  1346. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1347. TABLE_NAME.sgemm_p = 42 * (l2 >> 9) + 8;
  1348. #endif
  1349. #if BUILD_DOUBLE ==1 || (BUILD_COMPLEX16==1)
  1350. TABLE_NAME.dgemm_p = 42 * (l2 >> 9) + 8;
  1351. #endif
  1352. #if BUILD_COMPLEX==1
  1353. TABLE_NAME.cgemm_p = 21 * (l2 >> 9) + 4;
  1354. #endif
  1355. #if BUILD_COMPLEX16==1
  1356. TABLE_NAME.zgemm_p = 21 * (l2 >> 9) + 4;
  1357. #endif
  1358. #ifdef EXPRECISION
  1359. TABLE_NAME.qgemm_p = 42 * (l2 >> 9) + 8;
  1360. TABLE_NAME.xgemm_p = 21 * (l2 >> 9) + 4;
  1361. #endif
  1362. #endif
  1363. #ifdef NEHALEM
  1364. #ifdef DEBUG
  1365. fprintf(stderr, "Nehalem\n");
  1366. #endif
  1367. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1368. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1369. #endif
  1370. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1371. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1372. #endif
  1373. #if BUILD_COMPLEX
  1374. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1375. #endif
  1376. #if BUILD_COMPLEX16
  1377. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1378. #endif
  1379. #ifdef EXPRECISION
  1380. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1381. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1382. #endif
  1383. #endif
  1384. #ifdef SANDYBRIDGE
  1385. #ifdef DEBUG
  1386. fprintf(stderr, "Sandybridge\n");
  1387. #endif
  1388. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1389. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1390. #endif
  1391. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1392. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1393. #endif
  1394. #if BUILD_COMPLEX
  1395. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1396. #endif
  1397. #if BUILD_COMPLEX16
  1398. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1399. #endif
  1400. #ifdef EXPRECISION
  1401. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1402. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1403. #endif
  1404. #endif
  1405. #ifdef HASWELL
  1406. #ifdef DEBUG
  1407. fprintf(stderr, "Haswell\n");
  1408. #endif
  1409. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1410. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1411. #endif
  1412. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16)
  1413. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1414. #endif
  1415. #if BUILD_COMPLEX
  1416. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1417. #endif
  1418. #if BUILD_COMPLEX16
  1419. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1420. #endif
  1421. #ifdef EXPRECISION
  1422. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1423. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1424. #endif
  1425. #endif
  1426. #if defined(SKYLAKEX) || defined(COOPERLAKE) || defined(SAPPHIRERAPIDS)
  1427. #ifdef DEBUG
  1428. fprintf(stderr, "SkylakeX\n");
  1429. #endif
  1430. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1431. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1432. #endif
  1433. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1434. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1435. #endif
  1436. #if BUILD_COMPLEX
  1437. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1438. #endif
  1439. #if BUILD_COMPLEX16
  1440. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1441. #endif
  1442. #ifdef EXPRECISION
  1443. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1444. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1445. #endif
  1446. #endif
  1447. #ifdef OPTERON
  1448. #ifdef DEBUG
  1449. fprintf(stderr, "Opteron\n");
  1450. #endif
  1451. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1452. TABLE_NAME.sgemm_p = 224 + 56 * (l2 >> 7);
  1453. #endif
  1454. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1455. TABLE_NAME.dgemm_p = 112 + 28 * (l2 >> 7);
  1456. #endif
  1457. #if BUILD_COMPLEX
  1458. TABLE_NAME.cgemm_p = 112 + 28 * (l2 >> 7);
  1459. #endif
  1460. #if BUILD_COMPLEX16
  1461. TABLE_NAME.zgemm_p = 56 + 14 * (l2 >> 7);
  1462. #endif
  1463. #ifdef EXPRECISION
  1464. TABLE_NAME.qgemm_p = 56 + 14 * (l2 >> 7);
  1465. TABLE_NAME.xgemm_p = 28 + 7 * (l2 >> 7);
  1466. #endif
  1467. #endif
  1468. #ifdef BARCELONA
  1469. #ifdef DEBUG
  1470. fprintf(stderr, "Barcelona\n");
  1471. #endif
  1472. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1473. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1474. #endif
  1475. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1476. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1477. #endif
  1478. #if BUILD_COMPLEX
  1479. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1480. #endif
  1481. #if BUILD_COMPLEX16
  1482. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1483. #endif
  1484. #ifdef EXPRECISION
  1485. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1486. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1487. #endif
  1488. #endif
  1489. #ifdef BOBCAT
  1490. #ifdef DEBUG
  1491. fprintf(stderr, "Bobcate\n");
  1492. #endif
  1493. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1494. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1495. #endif
  1496. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1497. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1498. #endif
  1499. #if BUILD_COMPLEX
  1500. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1501. #endif
  1502. #if BUILD_COMPLEX16
  1503. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1504. #endif
  1505. #ifdef EXPRECISION
  1506. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1507. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1508. #endif
  1509. #endif
  1510. #ifdef BULLDOZER
  1511. #ifdef DEBUG
  1512. fprintf(stderr, "Bulldozer\n");
  1513. #endif
  1514. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1515. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1516. #endif
  1517. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1518. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1519. #endif
  1520. #if BUILD_COMPLEX
  1521. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1522. #endif
  1523. #if BUILD_COMPLEX16
  1524. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1525. #endif
  1526. #ifdef EXPRECISION
  1527. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1528. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1529. #endif
  1530. #endif
  1531. #ifdef EXCAVATOR
  1532. #ifdef DEBUG
  1533. fprintf(stderr, "Excavator\n");
  1534. #endif
  1535. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1536. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1537. #endif
  1538. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1539. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1540. #endif
  1541. #if BUILD_COMPLEX
  1542. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1543. #endif
  1544. #if BUILD_COMPLEX16
  1545. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1546. #endif
  1547. #ifdef EXPRECISION
  1548. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1549. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1550. #endif
  1551. #endif
  1552. #ifdef PILEDRIVER
  1553. #ifdef DEBUG
  1554. fprintf(stderr, "Piledriver\n");
  1555. #endif
  1556. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1557. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1558. #endif
  1559. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1560. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1561. #endif
  1562. #if BUILD_COMPLEX
  1563. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1564. #endif
  1565. #if BUILD_COMPLEX16
  1566. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1567. #endif
  1568. #ifdef EXPRECISION
  1569. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1570. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1571. #endif
  1572. #endif
  1573. #ifdef STEAMROLLER
  1574. #ifdef DEBUG
  1575. fprintf(stderr, "Steamroller\n");
  1576. #endif
  1577. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1578. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1579. #endif
  1580. #if BUILD_DOUBLE || (BUILD_COMPLEX16==1)
  1581. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1582. #endif
  1583. #if BUILD_COMPLEX
  1584. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1585. #endif
  1586. #if BUILD_COMPLEX16
  1587. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1588. #endif
  1589. #ifdef EXPRECISION
  1590. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1591. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1592. #endif
  1593. #endif
  1594. #ifdef ZEN
  1595. #ifdef DEBUG
  1596. fprintf(stderr, "Zen\n");
  1597. #endif
  1598. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1599. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1600. #endif
  1601. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  1602. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1603. #endif
  1604. #if BUILD_COMPLEX
  1605. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1606. #endif
  1607. #if BUILD_COMPLEX16
  1608. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1609. #endif
  1610. #ifdef EXPRECISION
  1611. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1612. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1613. #endif
  1614. #endif
  1615. #ifdef NANO
  1616. #ifdef DEBUG
  1617. fprintf(stderr, "NANO\n");
  1618. #endif
  1619. #if (BUILD_SINGLE==1) || (BUILD_COMPLEX==1)
  1620. TABLE_NAME.sgemm_p = SGEMM_DEFAULT_P;
  1621. #endif
  1622. #if (BUILD_DOUBLE==1) || (BUILD_COMPLEX16==1)
  1623. TABLE_NAME.dgemm_p = DGEMM_DEFAULT_P;
  1624. #endif
  1625. #if (BUILD_COMPLEX==1)
  1626. TABLE_NAME.cgemm_p = CGEMM_DEFAULT_P;
  1627. #endif
  1628. #if (BUILD_COMPLEX16==1)
  1629. TABLE_NAME.zgemm_p = ZGEMM_DEFAULT_P;
  1630. #endif
  1631. #ifdef EXPRECISION
  1632. TABLE_NAME.qgemm_p = QGEMM_DEFAULT_P;
  1633. TABLE_NAME.xgemm_p = XGEMM_DEFAULT_P;
  1634. #endif
  1635. #endif
  1636. #ifdef SAPPHIRERAPIDS
  1637. #if (BUILD_BFLOAT16 == 1)
  1638. TABLE_NAME.need_amxtile_permission = 1;
  1639. #endif
  1640. #endif
  1641. #if BUILD_COMPLEX==1
  1642. #ifdef CGEMM3M_DEFAULT_P
  1643. TABLE_NAME.cgemm3m_p = CGEMM3M_DEFAULT_P;
  1644. #else
  1645. TABLE_NAME.cgemm3m_p = TABLE_NAME.sgemm_p;
  1646. #endif
  1647. #endif
  1648. #if BUILD_COMPLEX16==1
  1649. #ifdef ZGEMM3M_DEFAULT_P
  1650. TABLE_NAME.zgemm3m_p = ZGEMM3M_DEFAULT_P;
  1651. #else
  1652. TABLE_NAME.zgemm3m_p = TABLE_NAME.dgemm_p;
  1653. #endif
  1654. #endif
  1655. #ifdef EXPRECISION
  1656. TABLE_NAME.xgemm3m_p = TABLE_NAME.qgemm_p;
  1657. #endif
  1658. #if BUILD_SINGLE == 1
  1659. TABLE_NAME.sgemm_p = ((TABLE_NAME.sgemm_p + SGEMM_DEFAULT_UNROLL_M - 1)/SGEMM_DEFAULT_UNROLL_M) * SGEMM_DEFAULT_UNROLL_M;
  1660. #endif
  1661. #if BUILD_DOUBLE== 1
  1662. TABLE_NAME.dgemm_p = ((TABLE_NAME.dgemm_p + DGEMM_DEFAULT_UNROLL_M - 1)/DGEMM_DEFAULT_UNROLL_M) * DGEMM_DEFAULT_UNROLL_M;
  1663. #endif
  1664. #if BUILD_COMPLEX==1
  1665. TABLE_NAME.cgemm_p = ((TABLE_NAME.cgemm_p + CGEMM_DEFAULT_UNROLL_M - 1)/CGEMM_DEFAULT_UNROLL_M) * CGEMM_DEFAULT_UNROLL_M;
  1666. #endif
  1667. #if BUILD_COMPLEX16==1
  1668. TABLE_NAME.zgemm_p = ((TABLE_NAME.zgemm_p + ZGEMM_DEFAULT_UNROLL_M - 1)/ZGEMM_DEFAULT_UNROLL_M) * ZGEMM_DEFAULT_UNROLL_M;
  1669. #endif
  1670. #if BUILD_COMPLEX==1
  1671. #ifdef CGEMM3M_DEFAULT_UNROLL_M
  1672. TABLE_NAME.cgemm3m_p = ((TABLE_NAME.cgemm3m_p + CGEMM3M_DEFAULT_UNROLL_M - 1)/CGEMM3M_DEFAULT_UNROLL_M) * CGEMM3M_DEFAULT_UNROLL_M;
  1673. #else
  1674. TABLE_NAME.cgemm3m_p = ((TABLE_NAME.cgemm3m_p + SGEMM_DEFAULT_UNROLL_M - 1)/SGEMM_DEFAULT_UNROLL_M) * SGEMM_DEFAULT_UNROLL_M;
  1675. #endif
  1676. #endif
  1677. #if BUILD_COMPLEX16==1
  1678. #ifdef ZGEMM3M_DEFAULT_UNROLL_M
  1679. TABLE_NAME.zgemm3m_p = ((TABLE_NAME.zgemm3m_p + ZGEMM3M_DEFAULT_UNROLL_M - 1)/ZGEMM3M_DEFAULT_UNROLL_M) * ZGEMM3M_DEFAULT_UNROLL_M;
  1680. #else
  1681. TABLE_NAME.zgemm3m_p = ((TABLE_NAME.zgemm3m_p + DGEMM_DEFAULT_UNROLL_M - 1)/DGEMM_DEFAULT_UNROLL_M) * DGEMM_DEFAULT_UNROLL_M;
  1682. #endif
  1683. #endif
  1684. #ifdef QUAD_PRECISION
  1685. TABLE_NAME.qgemm_p = ((TABLE_NAME.qgemm_p + QGEMM_DEFAULT_UNROLL_M - 1)/QGEMM_DEFAULT_UNROLL_M) * QGEMM_DEFAULT_UNROLL_M;
  1686. TABLE_NAME.xgemm_p = ((TABLE_NAME.xgemm_p + XGEMM_DEFAULT_UNROLL_M - 1)/XGEMM_DEFAULT_UNROLL_M) * XGEMM_DEFAULT_UNROLL_M;
  1687. TABLE_NAME.xgemm3m_p = ((TABLE_NAME.xgemm3m_p + QGEMM_DEFAULT_UNROLL_M - 1)/QGEMM_DEFAULT_UNROLL_M) * QGEMM_DEFAULT_UNROLL_M;
  1688. #endif
  1689. #ifdef DEBUG
  1690. fprintf(stderr, "L2 = %8d DGEMM_P .. %d\n", l2, TABLE_NAME.dgemm_p);
  1691. #endif
  1692. #if BUILD_BFLOAT16==1
  1693. TABLE_NAME.sbgemm_r = (((BUFFER_SIZE -
  1694. ((TABLE_NAME.sbgemm_p * TABLE_NAME.sbgemm_q * 4 + TABLE_NAME.offsetA
  1695. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1696. ) / (TABLE_NAME.sbgemm_q * 4) - 15) & ~15);
  1697. #endif
  1698. #if BUILD_SINGLE==1
  1699. TABLE_NAME.sgemm_r = (((BUFFER_SIZE -
  1700. ((TABLE_NAME.sgemm_p * TABLE_NAME.sgemm_q * 4 + TABLE_NAME.offsetA
  1701. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1702. ) / (TABLE_NAME.sgemm_q * 4) - 15) & ~15);
  1703. #endif
  1704. #if BUILD_DOUBLE==1
  1705. TABLE_NAME.dgemm_r = (((BUFFER_SIZE -
  1706. ((TABLE_NAME.dgemm_p * TABLE_NAME.dgemm_q * 8 + TABLE_NAME.offsetA
  1707. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1708. ) / (TABLE_NAME.dgemm_q * 8) - 15) & ~15);
  1709. #endif
  1710. #ifdef EXPRECISION
  1711. TABLE_NAME.qgemm_r = (((BUFFER_SIZE -
  1712. ((TABLE_NAME.qgemm_p * TABLE_NAME.qgemm_q * 16 + TABLE_NAME.offsetA
  1713. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1714. ) / (TABLE_NAME.qgemm_q * 16) - 15) & ~15);
  1715. #endif
  1716. #if BUILD_COMPLEX ==1
  1717. TABLE_NAME.cgemm_r = (((BUFFER_SIZE -
  1718. ((TABLE_NAME.cgemm_p * TABLE_NAME.cgemm_q * 8 + TABLE_NAME.offsetA
  1719. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1720. ) / (TABLE_NAME.cgemm_q * 8) - 15) & ~15);
  1721. #endif
  1722. #if BUILD_COMPLEX16 ==1
  1723. TABLE_NAME.zgemm_r = (((BUFFER_SIZE -
  1724. ((TABLE_NAME.zgemm_p * TABLE_NAME.zgemm_q * 16 + TABLE_NAME.offsetA
  1725. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1726. ) / (TABLE_NAME.zgemm_q * 16) - 15) & ~15);
  1727. #endif
  1728. #if BUILD_COMPLEX == 1
  1729. TABLE_NAME.cgemm3m_r = (((BUFFER_SIZE -
  1730. ((TABLE_NAME.cgemm3m_p * TABLE_NAME.cgemm3m_q * 8 + TABLE_NAME.offsetA
  1731. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1732. ) / (TABLE_NAME.cgemm3m_q * 8) - 15) & ~15);
  1733. #endif
  1734. #if BUILD_COMPLEX16 == 1
  1735. TABLE_NAME.zgemm3m_r = (((BUFFER_SIZE -
  1736. ((TABLE_NAME.zgemm3m_p * TABLE_NAME.zgemm3m_q * 16 + TABLE_NAME.offsetA
  1737. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1738. ) / (TABLE_NAME.zgemm3m_q * 16) - 15) & ~15);
  1739. #endif
  1740. #ifdef EXPRECISION
  1741. TABLE_NAME.xgemm_r = (((BUFFER_SIZE -
  1742. ((TABLE_NAME.xgemm_p * TABLE_NAME.xgemm_q * 32 + TABLE_NAME.offsetA
  1743. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1744. ) / (TABLE_NAME.xgemm_q * 32) - 15) & ~15);
  1745. TABLE_NAME.xgemm3m_r = (((BUFFER_SIZE -
  1746. ((TABLE_NAME.xgemm3m_p * TABLE_NAME.xgemm3m_q * 32 + TABLE_NAME.offsetA
  1747. + TABLE_NAME.align) & ~TABLE_NAME.align)
  1748. ) / (TABLE_NAME.xgemm3m_q * 32) - 15) & ~15);
  1749. #endif
  1750. }
  1751. #endif //POWER
  1752. #endif //ZARCH
  1753. #endif //(ARCH_LOONGARCH64)
  1754. #endif //(ARCH_MIPS64)
  1755. #endif //(ARCH_ARM64)