High-Speed Magnetoresistive Random-Access Memory Random Number Generator
  Using Error-Correcting Code by Tanamoto, Tetsufumi et al.
ar
X
iv
:1
60
6.
03
14
7v
1 
 [c
s.C
R]
  1
0 J
un
 20
16
High-Speed Magnetoresistive Random-Access Memory Random Number Generator Using
Error-Correcting Code
Tetsufumi Tanamoto, Naoharu Shimomura, Sumio Ikegawa, Mari Matsumoto, Shinobu Fujita, and Hiroaki Yoda1
1Corporate R & D center, Toshiba Corporation, Saiwai-ku, Kawasaki 212-8582, Japan
(Dated: October 11, 2018)
A high-speed random number generator (RNG) circuit based on magnetoresistive random-access memory
(MRAM) using an error-correcting code (ECC) post processing circuit is presented. ECC post processing
increases the quality of randomness by increasing the entropy of random number. We experimentally show
that a small error-correcting capability circuit is sufficient for this post processing. It is shown that the ECC
post processing circuit powerfully improves the quality of randomness with minimum overhead, ending up with
high-speed random number generation. We also show that coupling with a linear feedback shift resistor is
effective for improving randomness.
PACS numbers:
I. INTRODUCTION
In light of the advent of ubiquitous networks, security for
mobile applications has become more important and advanced
security systems are required. For many security systems,
random numbers are widely used to create IDs, passwords,
and so on. An on-chip random number generator (RNG) is
one of the key elements for a secure system-on-chip. Unpre-
dictability is one of the most important characteristics of ran-
dom numbers. RNGs capable of generating natural random
numbers by means of physical phenomena have recently been
investigated and have begun to replace pseudo-random num-
bers generated by software. Various kinds of on-chip RNG
using physical noise signals such as random telegraph noise
in transistors1–6, noise in diode junctions, or magnetic tunnel
junctions (MTJs)for magnetoresistive random-access memory
(MRAM)7–9 have been proposed.
Because RNGs based on physical phenomena are affected
to a greater or lesser degree by their physical environments
and manufacturing processes, for example by variation of de-
vice size, after AD-converting physical noise signals, post
processing using digital circuits is always needed to balance
‘0’ and ‘1’ to eliminate periodicity and correlation with the
original signals. The “rejection method” is most frequently
used for the post processing circuit (PPC), where two serial bit
sequences ‘01’ and ‘10’ are replaced by ‘0’ and ‘1’, whereas
‘00’ and ‘11’ are discarded. Although this method is simple
and clear, when the original physical signals fluctuate, the bal-
ance between ‘0’ and ‘1’ easily collapses and leads to a low
generation rate of random numbers after wasting a lot of bits
to create balanced random numbers. One of the more sophisti-
cated methods for PPC is to apply a data compression method
in order to increase the entropy of randomness. Lacharme10
proposed a PPC using the Bose-Chaudhuri-Hocquenghem
(BCH) error-correcting code (ECC). He proved that deriva-
tion of probability of ‘0’ and ‘1’ from 1/2, e/2, can be re-
duced to ed/2 with a minimal distance d of the ECC code.
However, it is unclear whether this PPC improves the quality
of randomness sufficiently to pass commercial-level statisti-
cal tests11,12. Moreover, compared with the noise sources, the
area of an ECC circuit is generally larger and consumes more
Data request 
Data
RN request 
RN
MRAM (RNG)Processor
Processor MRAM
FIG. 1: MRAM including ECC circuit is used to generate random
numbers with post processing ECC, when processor requests random
numbers. The ECC circuit for correcting memory bit error is shared
with the post processing circuit.
power. Consequently, the additional ECC circuit for RNGs is
inclined to dominate the area and power of the RNG.
In this paper, we present a novel MRAM-based RNG,
where, in addition to the conventional memory function of
MRAM, the memory system is also used as the physical noise
signal, and ECC circuits used for correcting MRAM memory
bit error are also converted to PPC when a random number is
required (Fig. 1). MRAM produces a random number by re-
ducing the programming current to cause writing errors inten-
tionally in the RNG mode (Fig. 2). The sharing of the memory
system including ECC circuits with RNG leads to a reduction
of circuit area and an efficient secure memory system for mo-
bile applications.
The remainder of this paper is organized as follows: in §2,
we describe our general idea of PPC using ECC circuit includ-
ing an explanation of the conventional ECC procedure. In §3,
we present our MRAM system to create RNG. In §4. we show
our experimental results and analyze the ECC PPC process.
§5 is a discussion part. Our conclusions are summarized in
§6.
2II. POST PROCESSING USING ECC CIRCUIT
A. RNG PPC circuit
The data compression by PPC using ECC increases the en-
tropy of random numbers. A block of n bits is transferred into
k bits by this circuit (n > k). Figure 1 shows a schematic of
a proposed post processing circuit shared by the conventional
error-correction linear block. The ECC circuit is usually used
for the error correction of memory bits. The key point of our
system is that we can change the role of a conventional ECC
circuit to PPC by adding only a small number of transistors
(Figs. 3 and 4). First, let us remember the conventional ECC.
A given message data stream is broken up into blocks, such
as k-symbol data block m = (m0,m1, ...,mk−1). A generating
matrix G encodes a given message m to a code c = mG. In a
simple form, G is the n× k generating matrix constituted from
a generator polynomial as
G(x) = g0 + g1x + ... + gn−k xn−k, (1)
such as
G =


gn−k gn−k−1 · · · g0 0 · · · 0
0 gn−k gn−k−1 · · · g0
...
...
. . . 0
0 · · · 0 gn−k gn−k−1 · · · g0


. (2)
In the present case, the original raw random bit sequence y =
(y0, ..., yn) is converted into post-processed data z = (z0, ..., zk)
as z = Gy. The coefficients of the generator polynomials G(x)
for binary BCH codes for n ≤ 127 are given in Table I.
These encoding and decoding processes of cyclic linear
codes are efficiently implemented using exclusive-OR gates,
switches, and shift registers that include flip-flops (FF) con-
nected in series. Note that data compression z = Gy for ran-
dom bits y differs from c = mG for code c in terms of the
position of FFs. Thus, we implement both circuits by adding
switching transistors, as shown in Fig 3. Then, we can change
the role of the circuit between error correction of memorized
bits and that of RNG post processing by switching transistors
expressed by ECC-SW and RNG-SW in Fig. 3. Note also
that BCH codes can be chosen appropriately by controlling
Pinning 
layer
Switching current
(a) Low 
resistance
(b) High 
resistance
Free Layer
Barrier 
layer
FIG. 2: MRAM device based on perpendicular magnetic tunnel junc-
tion (MTJ). A random number is generated at a switching current
where the magnetization of the free layer changes at 50 %. To reset
the free layer, 800 mV is applied to MTJ.
TABLE I: BCH codes we used. The numbers of G(x) show coef-
ficients of generator polynomials14. For example, 45 →100,101→
G(x) = x5 + x2 + 1.
n k t G(x)
31 26 1 45
31 21 2 3551
31 16 3 107657
31 5 5 5423325
63 57 1 103
63 51 2 12471
63 45 3 1701317
63 39 4 166623567
127 120 1 211
127 113 2 141567
127 106 3 11554743
127 99 4 3447023271
ON/OFF of transistors g0,.., gn−k. Figure 4 shows an imple-
mented form of the shared decoder block in Fig. 3 [a generator
polynomial of the (7,4) code is given by G(x) = x3 + x + 1].
In a rejection method, the number of bits is reduced to about
one-fourth of the original data [compression rate is about less
than 1/4]. On the other hand, PPC using the (n, k, t) BCH code
transform n bits to k bits, and thus the compression rate is k/n
[t is an error-correcting capability].
B. Coupling with linear feedback shift resistor (LFSR)
Because physical RNGs originate from physical phenom-
ena, there are some cases where physical RNGs does not pro-
duce desirable random numbers, such as electrical breakdown
of stacked thin films. Thus, in general, some supplementary
circuits are always required for commercial use12. A linear
feedback shift resistor (LFSR) is most frequently used for the
support of physical RNGs. LFSR, which produces a sequence
of bits, is composed of a shift resistor and a feedback function
by XOR of certain bits in the resistor. N-bit LFSR, which
is constituted by N FFs, can hold 2N − 1 bit-long pseudo-
random sequences for appropriate input data13. Because each
FF includes more than 20 transistors, a smaller N-bit LFSR
is desirable for reducing circuit area. Here, we investigate
N-bit LFSR with N ≤ 8. Concretely, we try (1, 0), (2, 1, 0),
(3, 1, 0), (4, 1, 0), (7, 1, 0), and (7, 3, 0) LFSRs, where listing
(1, 0) means that a new bit is generated by XORing a shifted
bit with the next bit, and listing (7, 1, 0) means that a seven
times shifted bit and a shifted bit are XORed with the next bit,
and so on. Figure 5 shows (2, 1, 0)-LFSR and (3, 1, 0)-LFSR.
We found that small LFSR is suitable for MRAM RNG, as
shown below.
3ECC-SW RNG-SW
Input
ECC-SW
Output
RNG-SW
FF FF
g0 g1 gn-k-1 gn-k
FIG. 3: Proposed RNG post processing unit which is shared with
memory bit error-correcting block. FF is a flip-flop element. In
ECC mode, “ECC-SW” is ON and in RNG mode, “RNG-SW” is
ON. g0,...,gn−k is determined by G(x). For example, when G(x) =
x5 + x2 + 1, g0, g2, and g5 are 1 when transistors are ON states.
Syndrome computation
ECC-SW RNG-SW
Memory 
input
Memory 
output
Received word 
buffer
Syndrome 
detection
RNG 
input
RNG 
output
RNG-SW
ECC-SW
FF FF FF FF FF FF FF
LFSRFF FF FF
FIG. 4: Example of a proposed RNG post processing unit shared
with ECC decoder. ECC for RNG is easily changed by switching
RNG-SW and ECC-SW. Example for (7,4) code. We can also apply
the RNG post processing unit to the ECC encoder block.
III. MRAM RNG
MRAM cell arrays are integrated by the 130 nm front pro-
cess and 240 nm back-end process15–18 (Fig. 6). An MRAM
random number is generated by controlling the switching cur-
rent such that the probability of change of magnetism of the
free layer is 50 % (Fig. 1)7. Figure 7 shows the MRAM
switching probability Pwrite as a function of switching cur-
rent at various pulse widths17. In the present MRAM, the
slopes of the change in switching probabilities look similar
regardless of the pulse duration rate. This leads to the stable
operation of MRAM cells. A closer look at this figure, in par-
ticular at the tail parts of the slopes, reveals that the slope of
Pwrite becomes slightly smaller for a shorter pulse width twrite
(speed-up). This means a shorter pulse is favorable for pro-
ducing current fluctuation at approximately Pwrite ≈ 1/2. The
applied voltage to the MRAM cell is controlled by checking
TABLE II: Typical random numbers examined here. Data A is an
average sample. Data B is a low-quality sample. Data C is a higher-
speed sample.
Data Balance twrite (ns)
A 51.1 % ‘1’ 30
B 27.6 % ‘1’ 30
C 36.3 % ‘1’ 10
Input FF FF Input FF FF FF
(a) (2,1,0)-LFSR (b) (3,1,0)-LFSR
FIG. 5: Small size LFSRs that improve original random signal. N bit
LFSR contains N FFs. (a) 2-bit LFSR and (b) 3-bit LFSR13.
BL
Bottom electrode
Top electrode
MTJ
FIG. 6: Cross-sectional TEM image of MTJ patterned by ion-milling
method. The diameter of the element is 55 nm. MTJ contains the
capping layer / perpendicular reference layer /MgO / Fe-based L10-
alloy /underlayer.
the ‘0’ and ‘1’ balance of the random data. Here, we prepared
three typical types of data (Table II). Data A (balanced data)
is obtained after repeating the adjustment process of voltage
control and the estimation of the ‘0’ and ‘1’ balance. Data B
(unbalanced data) is obtained by slightly changing the applied
voltage of data A in order to lose the balance. Data C (slightly
unbalanced data with a higher speed) is obtained by adjusting
the applied voltage at a higher pulse generation rate.
IV. RESULTS
Figure 8-11 show the results of statistical tests of random-
ness after ECC post processing for n = 31, 63, and 127 codes
(Table I) as a function of the error-correcting capability t. For
0%
20%
40%
60%
80%
100%
-100 -50 0
Switching current (µA)
Sw
itc
hi
n
g 
Pr
ob
ab
ili
ty
10ns
30ns
100ns
1µs
10µs
Sw
itc
hi
n
g 
Pr
ob
ab
ili
ty
FIG. 7: Switching probability as a function of switching current at
various pulse durations twrite. The gentle tail part of the slope of
shorter pulse such as twrite = 10 ns is considered to be favorable
for generating random numbers, because it contributes to producing
larger current fluctuations at approximately Pwrite ≈ 1/2.
4the three types of data (Table II), a rejection method com-
presses those data to 24.8 % (data A), 20.0 % (data B), and
23.1 % (data C), respectively. In contrast to the rejection
method, for ECC post processing, for example, for t = 2, these
rates are fixed to k/n and given as 90.0 % (n = 127), 80.0 %
(n = 63), and 67.7 % (n = 31). The statistical test suite NIST
PUB SP 800-2211 that contains 16 types of tests and judges
160 test results is used for a million bits set to a P-value of
0.0120. Although there are several kinds of Pass/Fail as-
signments for this test suite, we simply count the number of
test failures and judge Pass if it is 2 or less.
Figure 8 shows results for PPC using ECC for balanced
data (data A), unbalanced data with twrite =30 ns (data B), and
slightly unbalanced with higher speed of twrite =10 ns (data
C). These results prove the improvement ability of the ECC
post processing. In particular, unbalanced data (data B and
C) are greatly improved by this method. Note that the raw
bit sequence just after MRAM unit fails in almost all these
tests. Moreover, we could not see any specific correlation be-
tween improvement and the error-correcting capability t. This
does not follow the prediction of ref.10 in which better random
numbers are obtained as t (or d) increases (d and t has a rela-
tion d > 2t). Because RNG speed decreases at rate k/n, and
n − k extra redundant memory cells are required, these results
show that a small t can be chosen.
Figures 9-11 show results of ECC post processing with
(2,1,0)- and (3,1,0)-LFSR. We examined several lengths of
LFSR and found that a length of two or three LFSRs is suffi-
cient. That is, coupling with longer bit LFSRs such as (4, 1, 0),
(7, 1, 0), etc. does not always show a greater improvement
than 2-bit and 3-bit LFSRs. This might be because LFSR it-
self does not increase the entropy of randomness and just mix
random bit sequences. If transistors can be set to adjust the
generating polynomial [eq.(1)] depending on original random
signals, the most appropriate (n,k,t) can be selected. When
results of data A are compared with those of data C, it can be
seen that the acceleration of current pulse from twrite =30 ns
to twrite=10 ns increases the quality of randomness by ECC
post processing. This is considered to be related to the slope
of switching probability (Fig. 7). Finally, we estimate the
generation speed of the present RNG. When the read time
is 10 ns and four clocks are required for outputting one-bit
random number, 25 MHz generation speed is expected for a
RNG. Table III shows that the estimated generation speeds of
MRAM-based RNGs are much faster than those of state-of-
the-art RNGs reported in ref.1 and2.
TABLE III: Comparison of generation speeds of RNGs.
RNG Speed (MHz)
Ref.1 2
Ref.2 0.2
MRAM 25
1 2 3 4
0
20
40
60
80
100
120
140 n=31
n=63
n=127
1 2 3 4
0
10
20
30 n=31
n=63
n=127
1 2 3 4
0
2
4
6
8
10 n=31
n=63
n=127
N
u
m
be
r 
of
Fa
ilu
re
s 
data A
data B data C
t t t(a) (b) (c)
6 0
1 0
4 1 5
0 0
32 4
3
2
3
5
4
28
7
FIG. 8: Result of statistical test (NIST800-22). Number of failures
after ECC post processing for (a) good original random number bits
(data A), (b) unbalanced bits (data B) and (c) slightly unbalanced
with higher speed (data C), as a function of error correcting capabil-
ity t for n = 31, 63 and 127 BCH codes. Note that raw bit sequence
just after MRAM unit fails in almost all these tests. That is, the num-
ber of failures for raw data is close to 160.
1 2 3 4
0
2
4
6
8
10 n=31
n=63
n=127
1 2 3 4
0
2
4
6
8
10 n=31
n=63
n=127
N
u
m
be
r 
of
Fa
ilu
re
s 
data A
(2,1,0)
data A 
(3,1,0)
t t(a) (b)
4 5
1 3
2
2
52
FIG. 9: Result of statistical test (NIST 800-22) for data A (balanced
bits) coupled with 2-bit LFSR (a) and 3-bit LFSR (b). Both LFSRs
improve the quality of randomness compared with Fig. 8 (a).
V. DISCUSSION
The reason why the PPC using ECC is effective for MRAM
RNG is considered to be that MTJ directly outputs discrete
two values of current. We also applied this method to RNG
based on transistor noise1,4, in which the current noise signal
is a continuous variable and should be converted to digital sig-
nals by an analog circuit. It is found that we need to apply this
PPC a couple of times for RNG based on transistor noise to
pass statistical tests. Thus, it seems that this method is less ef-
fective for RNG based on transistor noise. Thus, direct obser-
vation of two distinct physical quantities in MTJ is considered
to be related to the efficiency of the PCC using ECC.
We experimentally showed that small error-correcting ca-
pability is sufficient such as t ≤ 2. As noted in the introduc-
tion, Lacharme only showed that ECC theoretically improved
1 2 3 4
0
20
40
60
80
100 n=31
n=63
n=127
1 2 3 4
0
10
20
30
40
50 n=31
n=63
n=127
N
u
m
be
r 
of
Fa
ilu
re
s 
data B
(2,1,0)
data B 
(3,1,0)
t t(a) (b)
4 4
0 1
3 0 0
3 1
1
FIG. 10: Result of statistical test (NIST 800-22) for data B (unbal-
anced bits) coupled with 2-bit LFSR (a) and 3-bit LFSR (b). Both
LFSRs improve the quality of randomness compared with Fig. 8 (b).
51 2 3 4
0
2
4
6
8
10 n=31
n=63
n=127
1 2 3 4
0
2
4
6
8
10 n=31
n=63
n=127
N
u
m
be
r 
of
Fa
ilu
re
s 
data C
(2,1,0)
data C 
(3,1,0)
t t(a) (b)
2
4 3
2
4
3
34
FIG. 11: Result of statistical test (NIST 800-22) for data C (slightly
unbalanced bits with higher speed) coupled with 2-bit LFSR (a) and
3-bit LFSR (b). Both LFSRs improve the quality of randomness
compared with Fig. 8 (c).
the balance between ‘0’ and ‘1’10. The theoretical explanation
why a small t is sufficient to pass the various statistical tests is
a future problem.
Power consumption of widely used oscillator-based RNGs
can be estimated to be more than 1 mW/bit. From the
2009 International Technology Roadmap for Semiconductors
(ITRS)21, the write energy of MTJ is estimated as 10−13 J
for one bit. If we take 2 ns as a write time, then the power
consumption of MTJ is 0.05 mW/bit. Thus, the power con-
sumption of MRAM RNGs is lower than that of currently used
RNGs. In the near future, power consumption will be further
reduced by decreasing switching current.
In general, random data are not very large in mobile ap-
plications and are used temporarily. Thus, the coexistence of
memory data and random data is not a problem as long as each
memory address is controlled.
VI. CONCLUSIONS
We presented a novel MRAM-based RNG using ECC in
which ECC post processes random numbers in addition to ful-
filling the conventional function of correcting memory bit er-
rors. We have proven that the MRAM-based RNG using ECC
post processing efficiently increases both randomness quality
and generation speed.
Acknowledgments
The authors would like to thank A. Nishiyama, J. Koga, S.
Kawamura, K. Abe, S. Yasuda, K. Nomura, and H. Uchikawa
for fruitful discussions.
1 M. Matsumoto, S. Yasuda, R. Ohba, K. Ikegami, T. Tanamoto.
and S. Fujita: IEEE Int. Solid-State Circuits Conf., 2008, p. 414.
2 R. Brederlow, R. Prakash, C. Paulus, and R. Thewes: IEEE Int.
Solid-State Circuits Conf., 2006, p. 422.
3 C. Tokunaga, D. Blaauw and T. Mudge: IEEE Int. Solid-State
Circuits Conf., 2007, p. 404.
4 S. Fujita, K. Uchida, S. Yasuda, R. Ohba, H. Nozaki, and T.
Tanamoto: IEEE Int. Solid-State Circuits Conf., 2004, p. 294.
5 M. Matsumoto, R. Ohba, S. Yasuda, K. Uchida, T. Tanamoto, and
S. Fujita: Jpn. J. Appl. Phys. 47 (2008) 6191.
6 K. Uchida, T. Tanamoto, and S. Fujita: Solid-State Electron. 51
(2007) 1552.
7 A. Fukushima, K. Kubota, K. Yakushiji, S. Yuasa and K. Ando:
Japanese Patent P2008-310403.
8 D. D. Djayaprawira, K. Tsunekawa, M. Nagai, H. Maehara, S.
Yamagata, N. Watanabe, S. Yuasa, Y. Suzuki, and K. Ando: Appl.
Phys. Lett. 86 (2005) 092502.
9 J. Hayakawa, S. Ikeda, F. Matsukura, H. Takahashi, and H. Ohno:
Jpn. J. Appl. Phys. 44 (2005) L587.
10 P. Lacharme: Fast Software Encryption 2008 (FSE), 2008.
11 http://csrc.nist.gov/publications/
12 W. Killmann and W. Schindler, AIS 31: Functionality classes and
evaluation methodology for true (physical) random number gen-
erators, version 3.1, Bundesamt fur Sicherheit in der Information-
stechnik (BSI), Bonn, 2001.
13 B. Schneier: Applied Cryptography, Wiley, New York, 1996.
14 S. B. Wicker: Error Control Systems for Digital Communication
and Storage, Prentice Hall, New Jersey, 1995.
15 T. Kishi, H. Yoda, T. Kai, T. Nagase, E. Kitagawa, M. Yoshikawa,
K. Nishiyama, T. Daibou, M. Nagamine, M. Amano, S. Taka-
hashi, M. Nakayama, N. Shimomura, H. Aikawa, S. Ikegawa, S.
Yuasa, K. Yakushiji, H. Kubota, A. Fukushima, M. Oogane, T.
Miyazaki, K. Ando: IEDM, Tech. Dig. 2008, p. 309.
16 H. Aikawa, N. Shimomura, S. Ikegawa, T. Ueda, M. Nakayama,
M. Iwayama, T. Kai, M. Yoshikawa, K. Hosotani, M. Nagamine
and H. Yoda: Spintech IV, 2007.
17 H. Yoda, T. Kishi, T. Nagase, M. Yoshikawa, K. Nishiyama, E.
Kitagawa, T. Daibou, M. Amano, N. Shimomura, S. Takahashi,
T. Kai, M. Nakayama, H. Aikawa, S. Ikegawa, M. Nagamine, J.
Ozeki, S. Mizukami, M. Oogane, K. Yakushiji, Y. Ando, S. Uasa,
Y. Suzuki, Y. Nakatani, T. Miyazaki, and K. Ando: 2010 IEEE
Joint Intermag-MMM Conf., 2010.
18 S. Ikegawa, H. Aikawa, N. Shimomura, T. Ueda, T. Kai, M.
Nakayama, M. Iwayama, H. Yoda, M. Yoshikawa, and Y. Asao:
6th Int. Symp. on Metallic Multilayers, (IEEE, MML) 2007.
19 N. Shimomura, H. Yoda, S. Ikegawa, T. Kai, M. Amano, H.
Aikawa, T. Ueda, M. Nakayama, Y. Asao, K. Hosotani, Y.
Shimizu, and K. Tsuchida: IEEE Trans. on Magn. 42 (2006) 2757.
20 P-value is associated with a test statistic and is a probability
that a perfect random number generator would have produced a
sequence less random than the sequence that was tested, given
the kind of nonrandomness assessed by the test11. If the P-value
equals 1, the sequence appears to have perfect randomness and if
the P-value equals 0 the sequence appears to be completely non-
random.
21 International Technology Roadmap for Semiconductors (ITRS)
[Table ERD5].
