Output save_alt Download

Operation
crypto_hash
Primitive
nasha512
Implementation
opt
Compiler options
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv
Host
venus
1 error 0
2 342e1943486c366e620b31243181cdbb5664935bede537be1b37a4982e1532d3 6612501 71123369 4300000000 crypto_hash/nasha512/opt
3 ==20519== Memcheck, a memory error detector
4 ==20519== Copyright (C) 2002-2017, and GNU GPL'd, by Julian Seward et al.
5 ==20519== Using Valgrind-3.15.0.GIT and LibVEX; rerun with -h for copyright info
6 ==20519== Command: ./try
7 ==20519==
8 ==20519== Use of uninitialised value of size 8
9 ==20519== at 0x10AA2F: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
10 ==20519== by 0x10AD92: Nasha512_Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
11 ==20519== by 0x10B200: Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
12 ==20519== by 0x10B2C6: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
13 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
14 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
15 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
16 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
17 ==20519== Uninitialised value was created by a client request
18 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
19 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
20 ==20519==
21 ==20519== Use of uninitialised value of size 8
22 ==20519== at 0x10AA45: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
23 ==20519== by 0x10AD92: Nasha512_Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
24 ==20519== by 0x10B200: Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
25 ==20519== by 0x10B2C6: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
26 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
27 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
28 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
29 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
30 ==20519== Uninitialised value was created by a client request
31 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
32 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
33 ==20519==
34 ==20519== Use of uninitialised value of size 8
35 ==20519== at 0x10AA7F: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
36 ==20519== by 0x10AD92: Nasha512_Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
37 ==20519== by 0x10B200: Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
38 ==20519== by 0x10B2C6: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
39 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
40 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
41 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
42 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
43 ==20519== Uninitialised value was created by a client request
44 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
45 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
46 ==20519==
47 ==20519== Use of uninitialised value of size 8
48 ==20519== at 0x10AB93: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
49 ==20519== by 0x10AD92: Nasha512_Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
50 ==20519== by 0x10B200: Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
51 ==20519== by 0x10B2C6: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
52 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
53 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
54 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
55 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
56 ==20519== Uninitialised value was created by a client request
57 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
58 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
59 ==20519==
60 ==20519== Use of uninitialised value of size 8
61 ==20519== at 0x10ABA9: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
62 ==20519== by 0x10AD92: Nasha512_Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
63 ==20519== by 0x10B200: Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
64 ==20519== by 0x10B2C6: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
65 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
66 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
67 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
68 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
69 ==20519== Uninitialised value was created by a client request
70 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
71 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
72 ==20519==
73 ==20519== Use of uninitialised value of size 8
74 ==20519== at 0x10ABE3: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
75 ==20519== by 0x10AD92: Nasha512_Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
76 ==20519== by 0x10B200: Update (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
77 ==20519== by 0x10B2C6: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
78 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
79 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
80 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
81 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
82 ==20519== Uninitialised value was created by a client request
83 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
84 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
85 ==20519==
86 ==20519== Use of uninitialised value of size 8
87 ==20519== at 0x10AA2F: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
88 ==20519== by 0x10AE84: Nasha_Final2 (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
89 ==20519== by 0x10B24D: Final (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
90 ==20519== by 0x10B2D1: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
91 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
92 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
93 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
94 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
95 ==20519== Uninitialised value was created by a client request
96 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
97 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
98 ==20519==
99 ==20519== Use of uninitialised value of size 8
100 ==20519== at 0x10AA45: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
101 ==20519== by 0x10AE84: Nasha_Final2 (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
102 ==20519== by 0x10B24D: Final (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
103 ==20519== by 0x10B2D1: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
104 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
105 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
106 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
107 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
108 ==20519== Uninitialised value was created by a client request
109 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
110 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
111 ==20519==
112 ==20519== Use of uninitialised value of size 8
113 ==20519== at 0x10AA7F: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
114 ==20519== by 0x10AE84: Nasha_Final2 (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
115 ==20519== by 0x10B24D: Final (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
116 ==20519== by 0x10B2D1: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
117 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
118 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
119 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
120 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
121 ==20519== Uninitialised value was created by a client request
122 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
123 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
124 ==20519==
125 ==20519== Use of uninitialised value of size 8
126 ==20519== at 0x10AB93: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
127 ==20519== by 0x10AE84: Nasha_Final2 (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
128 ==20519== by 0x10B24D: Final (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
129 ==20519== by 0x10B2D1: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
130 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
131 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
132 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
133 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
134 ==20519== Uninitialised value was created by a client request
135 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
136 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
137 ==20519==
138 ==20519== Use of uninitialised value of size 8
139 ==20519== at 0x10ABA9: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
140 ==20519== by 0x10AE84: Nasha_Final2 (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
141 ==20519== by 0x10B24D: Final (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
142 ==20519== by 0x10B2D1: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
143 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
144 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
145 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
146 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
147 ==20519== Uninitialised value was created by a client request
148 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
149 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
150 ==20519==
151 ==20519== Use of uninitialised value of size 8
152 ==20519== at 0x10ABE3: Nasha512_compile (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
153 ==20519== by 0x10AE84: Nasha_Final2 (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
154 ==20519== by 0x10B24D: Final (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
155 ==20519== by 0x10B2D1: Hash (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
156 ==20519== by 0x109A18: crypto_hash_nasha512_opt (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
157 ==20519== by 0x108D8A: doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
158 ==20519== by 0x108DF8: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
159 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
160 ==20519== Uninitialised value was created by a client request
161 ==20519== at 0x108DEA: timecop_doit (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
162 ==20519== by 0x10991D: main (in /home/moritz/Uni/2015-2016/research-internship/letstrythisagain/supercop-20181113/bench/venus/work/compile/try)
163 ==20519==
164 ==20519==
165 ==20519== HEAP SUMMARY:
166 ==20519== in use at exit: 17,408 bytes in 4 blocks
167 ==20519== total heap usage: 10 allocs, 6 frees, 31,352 bytes allocated
168 ==20519==
169 ==20519== LEAK SUMMARY:
170 ==20519== definitely lost: 0 bytes in 0 blocks
171 ==20519== indirectly lost: 0 bytes in 0 blocks
172 ==20519== possibly lost: 17,408 bytes in 4 blocks
173 ==20519== still reachable: 0 bytes in 0 blocks
174 ==20519== suppressed: 0 bytes in 0 blocks
175 ==20519== Rerun with --leak-check=full to see details of leaked memory
176 ==20519==
177 ==20519== For lists of detected and suppressed errors, rerun with: -s
178 ==20519== ERROR SUMMARY: 4992 errors from 12 contexts (suppressed: 0 from 0)