Implement health tests
[gnuk/neug.git] / ChangeLog
1 2012-09-11  Niibe Yutaka  <gniibe@fsij.org>
2
3         Health tests (SP 800-90b).
4         * src/random.c (repetition_count_test)
5         (adaptive_proportion_64_test, adaptive_proportion_4096_test): New.
6
7 2012-09-10  Niibe Yutaka  <gniibe@fsij.org>
8
9         * NEUG_USB_DEVICE_ID: New file.
10
11         * src/main.c: Include usb-vid-pid-ver.c.inc and usb-strings.c.inc.
12
13         * src/configure (vidpid): New.
14
15 2012-08-30  Niibe Yutaka  <gniibe@fsij.org>
16
17         * Version 0.02.
18
19 2012-08-27  Niibe Yutaka  <gniibe@fsij.org>
20
21         Use WELL random number generator to whiten noise input.
22         * src/random.c (NUM_NOISE_INPUTS): Now, it's 6.
23         (tmt_init, tmt_one_step, tmt_value): Remove.
24         (well512a_step): New function.  WELL random number generator.
25         (neug_prng_reseed): Remove.
26
27         * src/main.c (main): Call neug_flash with time interval 2500ms,
28         while disconnected.
29         Don't call neug_prng_reseed.
30         More blinks.
31
32         * src/neug.h (NEUG_PRE_LOOP): It's 64 now (was: 32).
33
34 2012-08-13  Niibe Yutaka  <gniibe@fsij.org>
35
36         * src/main.c (RANDOM_BYTES_LENGTH): It's now 60 (was: 32).
37         (neug_device_reset, neug_ctrl_write_finish)
38         (vcom_port_data_setup, neug_setup, neug_get_descriptor)
39         (neug_setup_endpoints_for_interface, neug_usb_event)
40         (neug_interface, Vector90, EP1_IN_Callback, EP2_IN_Callback)
41         (EP3_OUT_Callback): New.
42         (main): Now use usb_lld_* functions (was: ChibiOS SDU driver).
43
44         * boards/*/board.c (USB_Cable_Config, set_led): Remove.
45         , boards/*/board.h (SET_USB_CONDITION, SET_LED_CONDITION)
46         (GPIO_USB, IOPORT_USB, GPIO_LED, IOPORT_LED): Define.
47
48         * boards/common/board-common.c [DFU_SUPPORT] (__early_init): Don't
49         set SCB->VTOR here (it's done in reset in src/sys.c).
50
51         * src/halconf.h (HAL_USE_SERIAL_USB, HAL_USE_USB): Not define.
52         * src/Makefile.in (CSRC): Add sys.c and usb_lld.c
53         * src/sys.h, src/sys.c: New files (from Gnuk).
54         * src/usb_lld.h, src/usb_lld.c: New files (from Gnuk).
55
56 2011-11-14  Niibe Yutaka  <gniibe@fsij.org>
57
58         * Version 0.01.
59
60         * src/Makefile.in (MCFLAGS): Override MCFLAGS option for newer
61         GCC of summon-arm-toolchain to add -mfix-cortex-m3-ldrd.
62         NOTE: This should not be needed (as -mcpu=cortex-m3 defaults
63         to -mfix-cortex-m3-ldrd for GCC-proper), but it is needed
64         to select arm-none-eabi/lib/thumb2/libc.a correctly.
65
66         * boards/common/board-common.c (__early_init): Revert change of
67         2011-10-05.
68
69         * boards/FST_01/{mcuconf.h,board.h,board.c}: New.
70
71         * src/main.c (my_sduRequestsHook): New.
72         (LED_ONESHOT_SHORT, LED_ONESHOT_LONG): New.
73         (led_blinker): Support LED_ONESHOT_SHORT and LED_ONESHOT_LONG.
74         (main): Call neug_prng_reseed for each new connection.
75
76 2011-10-07  NIIBE Yutaka  <gniibe@fsij.org>
77
78         * src/random.c (neug_wait_full): New (from Gnuk).
79
80 2011-10-06  NIIBE Yutaka  <gniibe@fsij.org>
81
82         * src/random.c (neug_flush): New.
83         (neug_prng_reseed): Call neug_flush.
84
85 2011-10-05  NIIBE Yutaka  <gniibe@fsij.org>
86
87         * boards/common/board-common.c (__early_init): Set MSP register
88         in case of DFU.
89
90 2011-10-04  NIIBE Yutaka  <gniibe@fsij.org>
91
92         * src/chconf.h (THREAD_CONTEXT_SWITCH_HOOK): New.
93
94         * src/Makefile.in: Follow the change of ChibiOS 2.3.3 (new
95         directory structure of platforms/STM32F1xx).
96
97         * src/main.c (vcom_configuration_descriptor_data, usb_event):
98         Follow the change of ChibiOS 2.3.3 (USB_CDC_*).
99         (vcom_string3): Version 0.01.
100
101         * src/configure (MEMORY_SIZE): New.
102
103         * src/neug.ld.in (@MEMORY_SIZE@): New (for HD device like STBEE).
104         (.stacks): New in newer ChibiOS (>= 2.3.3).
105
106         * src/random.c (adccb_err): New.
107         (adcgrpcfg): Add adccb_err.
108
109         * chibios: Updated to trunk of 2.3.3.
110
111 2011-09-27  NIIBE Yutaka  <gniibe@fsij.org>
112
113         * src/random.c (adcgrpcfg): Fix configuration value (had old
114         values by old example).
115
116 2011-09-22  NIIBE Yutaka  <gniibe@fsij.org>
117
118         * src/random.c  (ROTATE): Remove.
119         (SHIFT_RIGHT): New.
120         (ep_add): Use SHIFT_RIGHT.
121
122 2011-09-21  NIIBE Yutaka  <gniibe@fsij.org>
123
124         * src/random.c (ep_output): Bug fix for second argument of
125         fnv32_hash, and change the way to place values into the buffer.
126         (ep_add): Feedback byte always shift 1-bit, entropy_bit sometimes.
127
128 2011-09-20  NIIBE Yutaka  <gniibe@fsij.org>
129
130         * boards/STBEE/mcuconf.h, boards/STBEE/board.h: New.
131         * boards/STBEE/board.c: New.
132         * boards/common/board-common.c (pal_default_config): Add case for
133         STM32F10X_HD.
134         * src/configure: Support STBEE.
135
136         * src/random.c (PROBABILITY_50_BY_TICK): New.
137         (ep_add): Use ROTATE for final feedback only.
138         (fnv32_hash): New.
139         (ep_output): Rename (was: ep_value).  Use fnv32_hash.
140
141 2011-08-29  NIIBE Yutaka  <gniibe@fsij.org>
142
143         * src/random.c (ep_add): New argument another_random_bit.
144         (crc32_top_bit, crc32_add_bit): Delete.
145         (tmt_init): New.
146         (rng_gen): Call ep_add with SysTick->VAL shake.
147         Don't shake PRNG by interrupt timing.
148         (neug_prng_reseed): New.
149
150         * src/main.c (main): Call neug_prng_reseed after new connection.
151
152         * src/neug.h (neug_prng_reseed): New.
153
154 2011-08-19  NIIBE Yutaka  <gniibe@fsij.org>
155
156         * src/random.c (tmt_one_step): No argument.
157         (crc32_top_bit, crc32_add_bit): New.
158         (rng_gen): Have return value.  Put interrupt timing entropy
159         to CRC32 shift register, and use the top bit of CRC32 to
160         shake the steps of TMT.
161
162 2011-08-10  NIIBE Yutaka  <gniibe@fsij.org>
163
164         * boards/STM8S_DISCOVERY/mcuconf.h: New.
165         * boards/STM8S_DISCOVERY/board.h: New.
166         * boards/STM8S_DISCOVERY/board.c: New.
167
168 2011-07-22  NIIBE Yutaka  <gniibe@fsij.org>
169
170         * boards/OLIMEX_STM32_H103/mcuconf.h (STM32_USBPRE): Add.
171
172         * src/main.c (main): Fix one shot logic.
173
174 2011-07-21  NIIBE Yutaka  <gniibe@fsij.org>
175
176         * src/neug.h (NEUG_PRE_LOOP): New.
177
178         * src/main.c (led_blinker): New.
179         (main): Use led_blinker.
180         (main): Call neug_get before USB configuration at least
181         NEUG_PRE_LOOP times.
182
183 2011-07-14  NIIBE Yutaka  <gniibe@fsij.org>
184
185         * src/configure: Support CQ_STARM.
186         * boards/CQ_STARM: Added.
187
188         * Version 0.00.
189