File: bitint-15.c

package info (click to toggle)
gcc-arm-none-eabi 15%3A14.2.rel1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,099,328 kB
  • sloc: cpp: 3,627,108; ansic: 2,571,498; ada: 834,230; f90: 235,082; makefile: 79,231; asm: 74,984; xml: 51,692; exp: 39,736; sh: 33,298; objc: 15,629; python: 15,069; fortran: 14,429; pascal: 7,003; awk: 5,070; perl: 3,106; ml: 285; lisp: 253; lex: 204; haskell: 135
file content (264 lines) | stat: -rw-r--r-- 16,311 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
/* PR c/102989 */
/* { dg-do run { target bitint } } */
/* { dg-options "-std=c23 -pedantic-errors" } */
/* { dg-skip-if "" { ! run_expensive_tests }  { "*" } { "-O0" "-O2" } } */
/* { dg-skip-if "" { ! run_expensive_tests } { "-flto" } { "" } } */

#if __BITINT_MAXWIDTH__ >= 192
__attribute__((noipa)) void
test135_171_192 (_BitInt(135) *p, _BitInt(171) *q, _BitInt(192) *r,
		 unsigned _BitInt(135) *s, unsigned _BitInt(171) *t,
		 unsigned _BitInt(192) *u, int n)
{
  p[5] = q[0];
  q[5] = p[0] + p[1];
  p[6] = r[0];
  r[5] = p[1];
  q[6] = r[1] + r[0];
  r[6] = q[1];
  p[7] = (unsigned _BitInt(135)) t[0] + (_BitInt(135)) t[1];
  q[7] = s[0];
  p[8] = u[0];
  r[7] = s[1];
  q[8] = u[1];
  r[8] = t[1];
  s[5] = q[2] - q[3];
  t[5] = p[2];
  s[6] = r[2];
  u[5] = p[3];
  t[6] = r[3];
  u[6] = q[3];
  s[7] = t[2];
  t[7] = s[2];
  s[8] = u[2];
  u[7] = s[3];
  t[8] = u[3];
  u[8] = t[3];
  u[9] = ((_BitInt(171)) (p[2] + p[3]) + q[2]) + u[2];
  p[9] = q[4] < p[4];
  q[9] = t[4] >= u[4];
  s[9] = ((_BitInt(171)) p[4]) << n;
  t[9] = ((_BitInt(171)) s[4]) >> n;
}
#endif

#if __BITINT_MAXWIDTH__ >= 575
__attribute__((noipa)) void
test522_547_575 (_BitInt(522) *p, _BitInt(547) *q, _BitInt(575) *r,
		 unsigned _BitInt(522) *s, unsigned _BitInt(547) *t,
		 unsigned _BitInt(575) *u, int n)
{
  p[5] = q[0];
  q[5] = p[0] + p[1];
  p[6] = r[0];
  r[5] = p[1];
  q[6] = r[1] + r[0];
  r[6] = q[1];
  p[7] = (unsigned _BitInt(522)) t[0] + (_BitInt(522)) t[1];
  q[7] = s[0];
  p[8] = u[0];
  r[7] = s[1];
  q[8] = u[1];
  r[8] = t[1];
  s[5] = q[2] - q[3];
  t[5] = p[2];
  s[6] = r[2];
  u[5] = p[3];
  t[6] = r[3];
  u[6] = q[3];
  s[7] = t[2];
  t[7] = s[2];
  s[8] = u[2];
  u[7] = s[3];
  t[8] = u[3];
  u[8] = t[3];
  u[9] = ((_BitInt(547)) (p[2] + p[3]) + q[2]) + u[2];
  p[9] = q[4] < p[4];
  q[9] = t[4] >= u[4];
  s[9] = ((_BitInt(547)) p[4]) << n;
  t[9] = ((_BitInt(547)) s[4]) >> n;
}
#endif

int
main ()
{
#if __BITINT_MAXWIDTH__ >= 192
  static _BitInt(135) p135[15] = {
    -21017626881393060962682831099345275646127wb,
    3694296893212130938499913614460066245857wb,
    -346978153630491292366720842786572608600wb,
    -12051883812785324688960115817645360041052wb,
    894554736479161756765856528934783wb,
    0, 0, 0, 0, 0,
    -10126751695395432170173641758862456728384wb,
    5972941260331487493885375988782293547456wb,
    1994359513041991206938472369666304432410wb,
    -6563811307898601259032789037472160962572wb,
    0wb
  };
  static _BitInt(171) q171[15] = {
    -625366993761622480400669212262678861717858330946368wb,
    824211109381944261174032176940659654188131012437179wb,
    546292738086463798921197562372110173424343217923278wb,
    511148834019524346739032507408677732131367119592267wb,
    347611384453999342493570524785293850801864814800614wb,
    0, 0, 0, 0, 0,
    -17323329988180930024182917484885209400270wb,
    -1427703038865092853121951937517407564490420667866520wb,
    38147269358417182782171905780014948953272wb,
    467958077036848086326034408503276340843337835865495wb,
    0wb
  };
  static _BitInt(192) r192[15] = {
    1392184189278706283348529493736576751111606618688367065536wb,
    1141852629791713898948497335488732622599274881068663548072wb,
    -2714462128387415582772926191122594432964111301268533078042wb,
    2425769388758313376333650042373508250767256770936531653671wb,
    2720431110756499648348639705956093809255126267584967484234wb,
    0, 0, 0, 0, 0,
    3694296893212130938499913614460066245857wb,
    824211109381944261174032176940659654188131012437179wb,
    24158489198104933635096197097903724015499wb,
    606766803137851050688065717544996275384988908585315wb,
    0wb
  };
  static unsigned _BitInt(135) s135[15] = {
    38147269358417182782171905780014948953272uwb,
    24158489198104933635096197097903724015499uwb,
    15056704170354189252536066857287800623071uwb,
    25206995790075003034339862074263410882988uwb,
    19207954769547491779143235037830592504231uwb,
    0, 0, 0, 0, 0,
    31754930256886813275958100253331871451523uwb,
    15245728220153286789447947809930478163942uwb,
    9156112246512545688879043617340759142722uwb,
    40264644850602433398431024975343109499285uwb,
    41168227647461841063600478959378800574464uwb
  };
  static unsigned _BitInt(171) t171[15] = {
    485349495244621624686447991535899196145754495768503uwb,
    606766803137851050688065717544996275384988908585315uwb,
    333199438528630292656855934377866394553406065406274uwb,
    2139385105954223838532102833374805075850015235549769uwb,
    1678008128571185237771726930519720682651619103697237uwb,
    0, 0, 0, 0, 0,
    2993155353253342198327516046110580903412563275406248uwb,
    2550578100027524622604893738184060999550811074270247uwb,
    15056704170354189252536066857287800623071uwb,
    699234106698292061166730462199993896682394735156989uwb,
    4367383273699372643737486905uwb
  };
  static unsigned _BitInt(192) u192[15] = {
    4671639464410605725298192070070307015392908693211956881396uwb,
    715636974522854835742140132808616653707176693849553888663uwb,
    457579096729186368426895847730802215502050535098936945045uwb,
    1103175995161405903311011421434916994075193954478175624957uwb,
    5439093776557462873830329048469734037495210381156250832820uwb,
    0, 0, 0, 0, 0,
    6277101735386680751783905610422341727142239626818674471844uwb,
    511148834019524346739032507408677732131367119592267uwb,
    25206995790075003034339862074263410882988uwb,
    2139385105954223838532102833374805075850015235549769uwb,
    457579643021924442491832802512548606285387299010222218671uwb
  };
  test135_171_192 (p135, q171, r192, s135, t171, u192, 42);
  for (int i = 5; i < 10; ++i)
    if (p135[i] != p135[i + 5]
	|| q171[i] != q171[i + 5]
	|| r192[i] != r192[i + 5]
	|| s135[i] != s135[i + 5]
	|| t171[i] != t171[i + 5]
	|| u192[i] != u192[i + 5])
      __builtin_abort ();
#endif
#if __BITINT_MAXWIDTH__ >= 575
  static _BitInt(522) p522[15] = {
    1688583697238081957015024340932764748327491668109158685467058555721380506305071231550264349039164029945469865795968233973631543964236809100573066960995245177wb,
    150663282285775450662414365350419405945541820765219523130929531002923088277160545114254251148525286476983773283235468282002045173141196158353616014355287094wb,
    -479060863800931266429781304885104017131749664329186246406335179483194313801808166262041921602861985862332756318078499039394820190197870580545316549380449074wb,
    1359131269843466711194682581441372588504604777186075559309941421522168913086212721229905012023237380094986736934464910421922092415050027946837562847761546642wb,
    38005189198839309539384162035472227153066377585338581102543574055575777451369497515143095968263424053357137645031423561696064649082930963wb,
    0, 0, 0, 0, 0,
    1911076617401423887269840833410267237705130466676958152037861477885277722749139605040038160132075189228439111066941630564324402605816835862488337890450123441wb,
    2143747820933189266943449152733920616973804237879618575235243631855378946947754007625444647681930476713800905339559157073740302180956472245149919774437085550wb,
    3020328738802050781697314194154464021447637901030508296205170033161531452424686777206896481266404991349073132253866303142608091273541629412071886412132279688wb,
    3548552946267883916132218767540000478942702862442658213517298532968411704728913569849574500607350293984423898514369017381981825383513090204371793724097677500wb,
    0wb
  };
  static _BitInt(547) q547[15] = {
    -165353820935998006231385303476800492106677276950834360813262262140867129737290132086107434762098834639119492256272880571578714556242252134191835397505691625332102479wb,
    183695555784071631934553514377048200879108759149452364923958570648444896373196632060114376244737698247102365620343713172199496472928539579603161884440477984840044187wb,
    139975743565335456314316356647588328869546947948448304225648231332737456493208842047425843515598984558359834966436458515450535075922755618635258426884425597017306862wb,
    -68977268331926408936317559581002324220146009615687701127254186456806021645364222184642001923334926042747842307638529875034306779796443629804024646337944171607895438wb,
    91932189605038085807227077574075596679601857184786010334359253878486168031464536332131456527844457578512045265477412819469725001337530261064906167819503147594853366wb,
    0, 0, 0, 0, 0,
    1839246979523857407677438706283184154273033488874378208597988086724303594582231776664518600187689316422453639079203702255633589137378005258926682975350532271wb,
    49151230401218799957130323446282917069028231656715550463945235235623430774823230155689924560414670278246826717504404635655151576036315823360722825188858286217308439wb,
    9553161692302515408090681902990032962274757557255101236499698228392460650767938620693069133770230123184487473131034348424915457011452743114281594442529356918wb,
    148466349169509850971880825885649862512888667929683428885486286008574376924695036417770580112507292038258577594242665019379719515779240480203475588034326681778827837wb,
    0wb
  };
  static _BitInt(575) r575[15] = {
    26826731245669206245461391126964073367685598786847623620556904941634299886033194729072082303506281733460775551098898854360334228479162479457887049265892154734615530822766958wb,
    -17252637235610200065109317402231975926530699783926188946291304643884915080832768297094963378392971235218154081350840664198841060114648240981027529664968282740385246545569879wb,
    -52927846040946009564438022882734367309063070035915874157090678963969555482365010516321242268874731309847996546526357803037049653154886399755465425844249799943139498370138356wb,
    43797192926762436278400269352553576566711887692587698009480808423919842536790683665562833898774167035902777714908510813261288364232387952547718429572231820909634939092793538wb,
    20234448725793738746286884524404371396011280587539411448314107254021820060093226611203035940379115510914907477160212849326875709895927134019157662749025851187493640146044781wb,
    0, 0, 0, 0, 0,
    150663282285775450662414365350419405945541820765219523130929531002923088277160545114254251148525286476983773283235468282002045173141196158353616014355287094wb,
    183695555784071631934553514377048200879108759149452364923958570648444896373196632060114376244737698247102365620343713172199496472928539579603161884440477984840044187wb,
    4851258619379431619519122339214063398230494067942295987016754503060997355109186638667322723996572842157209194651881355085513631695628096402419719096882984119wb,
    270940858229872855030935066513853051367534588484589172383739756326100509416298021769516239928911004114519037087137992976731526127660469862578530915810061315551592797wb,
    0wb
  };
  static unsigned _BitInt(522) s522[15] = {
    9553161692302515408090681902990032962274757557255101236499698228392460650767938620693069133770230123184487473131034348424915457011452743114281594442529356918uwb,
    4851258619379431619519122339214063398230494067942295987016754503060997355109186638667322723996572842157209194651881355085513631695628096402419719096882984119uwb,
    6042770678215430693640419990277820504092375118859355031950453294245655804901016852383090438332300632578629742514358616423826815593825261808316937209844323511uwb,
    12051208019451501933403724997574202861308205865422702777923943166771946439789370797531339169859679650622650974816793351928749417853531441599839154382248843947uwb,
    4221662083598509731422820533439331938122897651286500598721158769592271101088973546986107452648130743363570867708770978567950497328105753210259754199339698436uwb,
    0, 0, 0, 0, 0,
    7875787883122370015751284313157111317906983827437747001268058546750891954500439966161560575930887369730973089278944338386239832138713121400371960426603537532uwb,
    1744137654875073805109882450938570695232931878270397801451971688045434401366666192926859108662009962657770297731676696275736871955838688525022864084574797580uwb,
    1384759081458967898144776881134701550216992364037761109180860974761009009582780990796335747812536429464522433496147744197656107248393986692577240524935263967uwb,
    5124843933530741349702512002787631405197501632531242713014934699385673582868823319052853705098680028945536856890553829308345383420583019490169170519445809329uwb,
    167148589759802650246016819120863239719632156514525854640607511535259699817887971573240690630534000867480233158226351195963838422746014594980644913152uwb
  };
  static unsigned _BitInt(547) t547[15] = {
    118704181285368794475444886856018739380810770111464325340905883331118179085356913273672350794295633026214255802587734669771992302197074150034392332589894477800891435uwb,
    270940858229872855030935066513853051367534588484589172383739756326100509416298021769516239928911004114519037087137992976731526127660469862578530915810061315551592797uwb,
    148318595435099152643319192673870560615622574014851374282185242873863044665507345404380126683143560616100080924441878075099797842853873146415865873849906128482858719uwb,
    400009336874533540769201404797235801738671871521831649835366524748844548359672560304665337919920648881530376390480880285772783211641574132727624581374918623770667162uwb,
    312402853341542293879363014443999872603984243465217297921316340174779530859340793778010030453656373118302384722907441723040044092150534190429029290814183834885671793uwb,
    0, 0, 0, 0, 0,
    460688772082162445798867876757263237463152967782366598900331124229116988777566044118861599994996502169289915386539783342538027404687796097956601373975276229385346254uwb,
    110154623692678850196652173379922527637463658741605878515537649114990721104784513051339522805651918716345423521491055109328010793688754512750702811781309047768676546uwb,
    6042770678215430693640419990277820504092375118859355031950453294245655804901016852383090438332300632578629742514358616423826815593825261808316937209844323511uwb,
    399932168246430744543441055162559648552560119213629719844739099564504242321283467689573394637126627461985951275205392441444721842415628268892060247464270805433239423uwb,
    959894824427126361893629230835206712554940543506404673899205310952372906533349475236288402049497277258426690357003048704416527773015730692863997uwb
  };
  static unsigned _BitInt(575) u575[15] = {
    99465403292080375994166564143758974423715332054535509951564765439354460753284837794651681099567775806058182781885452212314717097157170419602135858778485292072068230160566460uwb,
    88608049883790202897201248133818379667781926476953929504091250051759382873398323059272759974739854128718622623196375150866798266503497028016169226040920220555730755500552765uwb,
    109996629797150279215121425420517668082012320009431263010584742106213909329388552729870453505045429145144806346761163201752908500506299217142569716987778685190706093716744369uwb,
    79085012468256116329498575277619682348270018511342269619476165669326091481750859826134218624634485255862979362030324907252864643018828592244764325998135532395602379128096639uwb,
    66159275290347502690275324386397674256469688848451250551469155682688473691401346605236603803735518810344975633814051516285290687587632060625865757225821322257077271128705141uwb,
    0, 0, 0, 0, 0,
    1359131269843466711194682581441372588504604777186075559309941421522168913086212721229905012023237380094986736934464910421922092415050027946837562847761546642uwb,
    123665200667574998698324851573506035436563350330459910341343826919194426096459911939793978345979520571463909670260227362037152642119068825187329447746921937620359214466454130uwb,
    12051208019451501933403724997574202861308205865422702777923943166771946439789370797531339169859679650622650974816793351928749417853531441599839154382248843947uwb,
    400009336874533540769201404797235801738671871521831649835366524748844548359672560304665337919920648881530376390480880285772783211641574132727624581374918623770667162uwb,
    109996629937126023660527287777369469494501925435246782331888159188751453565732251262053894836875827628606881325496392400843347632343245675592597560475194478367377989115148799uwb
  };
  test522_547_575 (p522, q547, r575, s522, t547, u575, 42);
  for (int i = 5; i < 10; ++i)
    if (p522[i] != p522[i + 5]
	|| q547[i] != q547[i + 5]
	|| r575[i] != r575[i + 5]
	|| s522[i] != s522[i + 5]
	|| t547[i] != t547[i + 5]
	|| u575[i] != u575[i + 5])
      __builtin_abort ();
#endif
}