Audio Interface for the Zedboard by Scholl, Stefan (Dipl.-Ing.)
Audio Interface for the Zedboard
Stefan Scholl, DC9ST
Microelectronic Systems Design Research Group
TU Kaiserslautern, Germany
March 2015
1 Overview
This interface connects the ADAU1761 audio codec on the Zedboard to the Zynq PL. Audio signals can
be received in stereo from the line in jack and/or transmitted to the headphone out jack. The design has
originally been developed by Mike Field (alias hamster). In his design it is part of a system for ﬁltering
audio signals with the Zedboard (http://hamsterworks.co.nz/mediawiki/index.php/Zedboard_Audio).
We have extracted, modiﬁed and extended the audio interface part to provide an easy to use
standalone IP core for using the audio capabilities on the Zedboard. The main diﬀerences to hamster's
design are:
• ready to use, standalone IP block (ﬁlters and switches removed, new top level ﬁle)
• improved interface (synchronized to 100 MHz system clock)
• ported to Vivado
• added testbench to test line in and headphone out
• improved documentation
The source ﬁles can be downloaded from Git Hub:
https://github.com/ems-kl/zedboard_audio
ADAU
1761
Zedboard
Zynq PL Zynq PS
This
Audio 
Interface
from/to
other logic
line_in_l
line_in_r
hphone_l
hphone_r
clock_100
(100 MHz)
new_sample
sample_clk_48k
(control signals)
Line in
Fig. 1: The audio interface
1
2 How to use the audio interface 2
2 How to use the audio interface
24 bit audio samples are read from the blue line in jack and are provided by line_in_l and _r to the
FPGA logic. Audio samples can be passed to the ADAU1761 for output on the black headphone jack
via the hphone_l and _r input signals. New samples (from line in) are signalized by new_sample = 1
or the rising edge of sample_clk_48k. Note, that after a new sample from line in has been signalized,
the design accepts a sample for output at the headphone within nearly one sample period (i.e. within
approx. 2000 clock cycles).
Headphone input signals hphone_l and _r are simultaneously sampled on valid signal of channel l
(hphone_l_valid). The valid signal of channel r (hphone_r_valid_dummy) is discarded and is only
there to be able to easily form an AXIS interface in the Vivado Packager. For mono operation use
channel l. Detailed waveforms are shown in Fig. 3.
Interface signals summary:
• clk_100: apply a 100 MHz clock
• line_in_l and _r: provide 24 bit data from the line in for left and right channel
• hphone_l and _r: input for 24 bit headphone data, valid data is signalized by
hphone_l_valid = 1
• new_sample: high for one clock cycle, if a new sample has arrived (on rising edge of sam-
ple_clk_48)
• sample_clk_48k: clock synchronous to sample rate (48kHz), useful e.g. for sample rate
conversion
A testbench is provided (audio_testbench.vhd), which can be used for testing or as a top level module
for a reference design. Two tests are available: a simple loopback, which routes the line in signal
directly to the headphone and a sawtooth generator for headphone output. To switch between the
testmodes the corresponding code block has to be commented out in audio_testbench.vhd.
Furthermore two bitstream ﬁles are available (one for each testbench mode) for quick evaluation
(generated with Vivado 2013.4). The applied board settings are shown below in Fig. 2.
Fig. 2: Zedboard jumper settings
2 How to use the audio interface 3
Fig. 3: Waveforms to clarify the usage of the IP core
3 Implementation Details 4
3 Implementation Details
Conﬁguration data for the ADAU1761 is provided via I2C by a small controller. Transmission of audio
data to the ADAU1761 is accomplished by I2S. The interface to the FPGA logic is provided at 100
MHz (clk_100). Since the interior clock of the original Hamsterworks design works at 48 MHz, clock
domain crossing (CDC) is required. The ADAU1761 chip is clocked by this design at 48MHz/2 = 24
MHz.
Block Diagram for Zedboard Audio Interface 
(block names directly correspond to vhdl files)
ADAU 1761 Audio Chip
line in
(blue jack)
headphone out
(black jack)
Zynq PL
Clocking
converts 100 MHz to
48 MHz using
MMCME2_ADV
ADAU1761
_interface
divides 48 MHz clock
to 24 MHz
i2s_data_interface 
receives and sends audio samples
(I2S format)
i2c
I3c2
a controller to send the
configuration data (I2C)
adau1761_
configuraiton_data
(contains config data)
clk_100
(100 MHz clock)
AC_MCLK
24 MHz
AC_GPIO0 MISOAC_GPIO1 MOSI
AC_GPIO2 BCLK
AC_GPIO3 LR
AC_SDAAC_ADR0
AC_ADR1
AC_SCK
audio_top.vhd
line_in_l
line_in_r
hphone_l
hphone_r
hphone_l_valid
new_sample
sample_clk_48k
adau1761_izedboard.vhd
48 MHz
clock signal
Clock domain crossing
Fig. 4: Block diagram overview (block names correspond to vhdl ﬁle names)
3 Implementation Details 5
C
lo
ck
 D
o
m
ai
n
 C
ro
ss
in
g 
b
et
w
ee
n
 4
8
 M
H
z 
an
d
 1
0
0
 M
H
z 
im
p
le
m
e
n
te
d
 in
 a
u
d
io
_t
o
p
.v
h
d
4
8
 M
H
z 
(c
lk
o
u
t0
o
r 
cl
k_
4
8
)
1
0
0
 M
H
z 
(c
lk
_1
0
0
)
en
h
p
h
o
n
e_
l&
 _
r
h
p
h
o
n
e_
va
lid
h
p
h
o
n
e_
x_
fr
ee
ze
_
1
0
0
en
Im
p
le
m
en
te
d
 in
su
b
m
o
d
u
le
fo
r 
I2
S
n
ew
_s
am
p
le
A
C
_G
P
IO
3
(l
/r
 s
el
ec
t 
(“
cl
o
ck
”)
)
en
en
sa
m
p
le
_c
lk
_
4
8
k_
d
1
_4
8
sa
m
p
le
_c
lk
_
4
8
k_
d
2
_4
8
sa
m
p
le
_c
lk
_
4
8
k_
d
3
_4
8
en
en
en
en
en
sa
m
p
le
_c
lk
_
4
8
k_
d
4
_1
0
0
sa
m
p
le
_c
lk
_
4
8
k_
d
5
_1
0
0
sa
m
p
le
_c
lk
_
4
8
k_
d
6
_1
0
0
sa
m
p
le
_c
lk
_
4
8
k
sa
m
p
le
_
cl
k_
4
8
k
R
is
in
g 
ed
ge
 
d
et
ec
ti
o
n
n
ew
_s
am
p
le
&
n
ew
_s
am
p
le
_
1
0
0
lin
e_
in
_x
_f
re
ez
e_
4
8
(s
ig
n
al
 is
 k
ep
t 
st
ab
le
 f
o
r 
n
ea
rl
y
o
n
e 
sa
m
p
le
 p
er
io
d
 b
y 
I2
S
m
o
d
u
le
)
en
lin
e_
in
_l
&
lin
e_
in
_r
St
ef
an
 S
ch
o
ll,
 D
C
9S
T,
TU
K
ai
se
rs
la
u
te
rn
, G
er
m
an
y
2
01
4
Fig. 5: Clock domain crossing between audio (48 MHz) and interface (100 MHz) clock domain
