electro-music.com   Dedicated to experimental electro-acoustic
and electronic music
 
    Front Page  |  Radio
 |  Media  |  Forum  |  Wiki  |  Links
Forum with support of Syndicator RSS
 FAQFAQ   CalendarCalendar   SearchSearch   MemberlistMemberlist   UsergroupsUsergroups   LinksLinks
 RegisterRegister   ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in  Chat RoomChat Room 
 Forum index » DIY Hardware and Software » Microcontrollers and Programmable Logic
Parallella
Post new topic   Reply to topic Moderators: State Machine
Page 1 of 2 [30 Posts]
View unread posts
View new posts in the last week
Mark the topic unread :: View previous topic :: View next topic
Goto page: 1, 2 Next
Author Message
DrJustice



Joined: Sep 13, 2004
Posts: 2112
Location: Morokulien
Audio files: 4

PostPosted: Thu Mar 13, 2014 2:46 pm    Post subject: Parallella Reply with quote  Mark this post and the followings unread

I just found out about the $99 Parallella, a single board parallel computing device and thought others might be interested. It comes with :

- Xilinx XC7Z020, dual ~700MHz ARM cores, 85k gates programmable logic + 220 DSP slices, heaps of IO
- Epiphany E16G301, 16 x 1GHz RISC cores, dual issue, local and shared memory, on/off chip multiprocessing network
- GNU toolchain

This board looks ideal for a powerful synthesizer or FX processing device. The Epiphany chip is the main attraction here of course. It looks very nice with a 32 GFLOPS peak performance. While this card has a 16 core chip, 64 and more (thousands) core versions will follow.

Very tempting.. but also potentially very time consuming Smile
Back to top
View user's profile Send private message Visit poster's website
JovianPyx



Joined: Nov 20, 2007
Posts: 1988
Location: West Red Spot, Jupiter
Audio files: 224

PostPosted: Thu Mar 13, 2014 3:45 pm    Post subject: Reply with quote  Mark this post and the followings unread

It does have some powerful features, however, I don't like those expansion connectors, they look expensive and probably not easy to DIY. Why no PMODs? I also noticed it has no codec (and PMODs would make connecting one very easy). I'd actually prefer a VGA port instead of or in addition to HDMI. I also don't see a USB host port.

On the plus side is 1G of RAM (RAM goes away real fast even in an embedded Linux environment). The hardware is indeed powerful enough for a multi-voice multi-timbral synth or high quality effects processor, but several hardware items need to be added for that, namely a good quality stereo codec with input antialias filters at minimum.

Just my 2 cents worth...

_________________
FPGA, dsPIC and Fatman Synth Stuff

Time flies like a banana.
Fruit flies when you're having fun.
BTW, Do these genes make my ass look fat?
corruptio optimi pessima
Back to top
View user's profile Send private message Visit poster's website
DrJustice



Joined: Sep 13, 2004
Posts: 2112
Location: Morokulien
Audio files: 4

PostPosted: Thu Mar 13, 2014 5:42 pm    Post subject: Reply with quote  Mark this post and the followings unread

I wouldn't say you need a lot of extra hardware to use it, just the DAC (Linux -> USB?). It has an USB connector on each short end of the board (host and device). And face it, the days of VGA are gone... Smile

I agree that the expansion connectors aren't the most DIY friendly, but at least for the Epiphany multi processing network some reliable high speed connectors are needed. Anyway, the community already has breakout boards going, and if nothing else there are UART pins on the board for MIDI (yes you need an optocoupler...).

In any case it looks like a great little board with lots of synthesis power.
Back to top
View user's profile Send private message Visit poster's website
JovianPyx



Joined: Nov 20, 2007
Posts: 1988
Location: West Red Spot, Jupiter
Audio files: 224

PostPosted: Thu Mar 13, 2014 6:04 pm    Post subject: Reply with quote  Mark this post and the followings unread

You mentioned effects processor in your post - I suppose it counts if you apply an effects processor after a synthesizer, however, when I saw that, I thought of a more general effects processor, such as can be used on any external instrument or device. For that, an ADC is also required (or a codec that handles both ADC and DAC).

As for a DAC on USB.... this is just MY OPINION - but I think that basically sucks unless you have one of those optically isolate USB things that can eliminate the USB noise. Even then, the DAC competes for time resources with other devices like a thumb drive and of course the keyboard and mouse. USB DAC also makes it much more difficult to use the FPGA fabric to have a synth that is controlled by the Linux-based ARMs. And in an FPGA environment, with all those hundreds of pins, there is really no excuse for putting a DAC on USB because you can make or get drivers for codecs or DACs/ADCs for linux. I think a more optimal solution is a codec that is connected directly to FPGA pins, especially for timing considerations. I think sample rate ranges of available parts are going to be better for direct to FPGA as well. And this isn't something that's out of comm speed range for PMOD.

As for the MIDI opto-isolator, a PMOD would be such an easy interface to make a simple little board to do that.

As for VGA, we shall agree to disagree. I think that especially QVGA has a place in the synth/effects arena. I also have 4 or 5 working VGA units here, so I, personally, am not done with VGA.

As I said previously, I think the Zynq chip is a powerful tool worthy of wonderful audio DSP experiments.

I will be interested in reading about and listening to the projects you design with the Parallela.

_________________
FPGA, dsPIC and Fatman Synth Stuff

Time flies like a banana.
Fruit flies when you're having fun.
BTW, Do these genes make my ass look fat?
corruptio optimi pessima
Back to top
View user's profile Send private message Visit poster's website
DrJustice



Joined: Sep 13, 2004
Posts: 2112
Location: Morokulien
Audio files: 4

PostPosted: Sat Mar 22, 2014 11:26 am    Post subject: Reply with quote  Mark this post and the followings unread

I agree that a USB DAC is the long way around, just mentioned it as a convenience plug-and-play possibility. I'd think that any USB DAC worth it's weight in silicon is properly isolated from USB noise though.

For the Parallella and other boards like it, something like this I2S DAC might do t he trick. In the case of the Parallella you could have a stand alone >40 GFLOPS C-programmable audio processing system for less than USD 150. That's a pretty enticing prospect...


Edit: I wanted to edit a typo and found that the "edited" message sits immediately below the last line of the posting with absolutely no air - I wonder if it didn't it sit lower down in the message previously. Anyway, I've created some air around the paragraph above by inserting this "Edited" explanation Smile

Last edited by DrJustice on Sat Mar 22, 2014 7:47 pm; edited 3 times in total
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Sat Mar 22, 2014 3:31 pm    Post subject: Reply with quote  Mark this post and the followings unread

Very interesting, I have registered my email with them and will get one. The 64 core one would be pretty nippy.
Last edited by BobTheDog on Sun Mar 23, 2014 12:37 am; edited 1 time in total
Back to top
View user's profile Send private message
jksuperstar



Joined: Aug 20, 2004
Posts: 2503
Location: Denver
Audio files: 1
G2 patch files: 18

PostPosted: Sat Mar 22, 2014 11:13 pm    Post subject: Reply with quote  Mark this post and the followings unread

This thing looks like a GPU style architecture, without the graphics, from what I can tell.

Great little development board, however. Between these new SoC/FPGAs and the return of analog synths and drum machines, I think I died and am in heaven.
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Sun Mar 23, 2014 12:43 am    Post subject: Reply with quote  Mark this post and the followings unread

They have an RC of OpenCL 1.1 as well, looks like it is not quite complete though:

Quote:
The OpenCL implementation for Parallella presently targets the 1.1 standard specification. Programmers should be aware that not all of the standard is implemented at this time and extensions have been added to expose features of the Epiphany architecture not addressed in the standard. The primary objective is to use OpenCL to provide a useful parallel programming model for Parallella programmers.
Back to top
View user's profile Send private message
DrJustice



Joined: Sep 13, 2004
Posts: 2112
Location: Morokulien
Audio files: 4

PostPosted: Sun Mar 23, 2014 9:44 am    Post subject: Reply with quote  Mark this post and the followings unread

jksuperstar wrote:
This thing looks like a GPU style architecture, without the graphics, from what I can tell.

It's quite a bit different. Each core is a complete general purpose RISC core, a bit like a small ARM. As such there are no GPU 'strangeness' and dedicated units.

Some cool things: The on and off chip multiprocessing network has a hardware supported messaging protocol, where any core can send a message to any other core(s), also as multicatsts. Each node can access the local memory of any other node, and each node can access the off chip shared memory.

All in all, programming the Epiphany efficiently should be very straightforward. I haven't tried it, but I have read large parts of the docs. Here is the Epiphany Architecture Reference manual, with the programming model explained. It's a bit tight now, but come better times, I'll be getting a Parallella.

@ Andy: What kind of CODEC and hook up will you use? If the community would come up with a "standard" CODEC arrangement, that would lower the threshold for getting audio projects running on the Parallella...
Back to top
View user's profile Send private message Visit poster's website
jksuperstar



Joined: Aug 20, 2004
Posts: 2503
Location: Denver
Audio files: 1
G2 patch files: 18

PostPosted: Mon Mar 24, 2014 11:18 am    Post subject: Reply with quote  Mark this post and the followings unread

I did find the reference docs, and can see each unit has a floating point processor, too. I'm trying to grok what the total delay time would/could be from cores to I/O through the eMesh.

An ADAT codec is fairly simple, and fully digital for experimentation (with optical isolation!). The FPGA could easily do all the heavy lifting, even if heavy is pretty lite in this case. Pure audio is good, too Wink
Back to top
View user's profile Send private message Visit poster's website
engineer



Joined: Mar 31, 2014
Posts: 11
Location: Frankfurt / Germay

PostPosted: Mon Mar 31, 2014 10:07 am    Post subject: FPGA Parallella for sound Reply with quote  Mark this post and the followings unread

I am really impressed about this board which is really incredibly priced. Hard to understand.

Well the FPGA is too small for my needs but there is a strong need for ARM processing for sound because of MIDI and random Arpeggios.

I have a similar board running during my main business (video) it is a former Zynq from Digilent, so I have no idea about this Epiphany CPU. I will have to inspect that the detailled way.
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Thu Sep 11, 2014 2:11 pm    Post subject: Reply with quote  Mark this post and the followings unread

Well I have had one a couple of weeks, like most of these things it is a pain in the arse.

The epiphany processor is pretty quick as long as you keep everything in on core ram which is 32K per core. There is no hardware divide though so you need to keep away from divides.

The Arm dual core is also pretty quick.

Getting data from the arm ram to the epiphany core ram is extremely slow though.

The Zynq chip runs very hot, even with a large heatsink it was operating over it temp limits so I had to attach a 6" fan to it!

I managed to get some filter code running on the epiphany cores and set it up using network jack to send audio from my Mac to the arm over TCP/IP then piped into the epiphany for processing and then back again. The main speed issue is the R/W speed between the arm and epiphany though, with a 32 float buffer it takes around 1.5ms.

I ended up having to buy a expansion board to get at the GPIO pins from the fpga, those samtec connectors are mad. I did get some samples but there is no way I could solder them up, they are absolutely tiny.

The GPIO is very slow though running through Linux, about 70k. Also there is no SPI interface available, the Zynq SPI is disabled as all main pins are used so I am currently trying to get one built into the FPGA bitstream to replace some of the GPIOs.

Once I have an SPI module setup and have shoehorned it into the Linux kernel I might be able to get some of my DACs going......


parallella.jpg
 Description:
 Filesize:  80.69 KB
 Viewed:  29204 Time(s)

parallella.jpg


Back to top
View user's profile Send private message
JovianPyx



Joined: Nov 20, 2007
Posts: 1988
Location: West Red Spot, Jupiter
Audio files: 224

PostPosted: Thu Sep 11, 2014 4:38 pm    Post subject: Reply with quote  Mark this post and the followings unread

Interesting remark about the Zynq getting hot. The Zynq chip on my ZyBo barely ever gets warm - but I've not had it packed, just a small synthesizer. Maybe it will heat up if I fill it with active logic.

Which Zynq part number is it? The ZyBo has a "small" one... small in quotes because looking at the ISE data when I program it, it's actually quite a large FPGA compared to others I've used (500K gates as found in a Spartan-3E)

_________________
FPGA, dsPIC and Fatman Synth Stuff

Time flies like a banana.
Fruit flies when you're having fun.
BTW, Do these genes make my ass look fat?
corruptio optimi pessima
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Fri Sep 12, 2014 12:20 am    Post subject: Reply with quote  Mark this post and the followings unread

The one I have is the 7020. You can also get a Parallella with the 7010.

I have included a pic showing the large heatsink, using this alone mine 'idles' at 80C, recommended max is 70C although the 7020 is rated at 75C.

With the fan running at 5V it brings it down to 56C.

This is running without the HDMI core on the FPGA, most of the FPGA is empty on the 7020 without HDMI.


HeatSink.jpg
 Description:
 Filesize:  104.62 KB
 Viewed:  29134 Time(s)

HeatSink.jpg


Back to top
View user's profile Send private message
JovianPyx



Joined: Nov 20, 2007
Posts: 1988
Location: West Red Spot, Jupiter
Audio files: 224

PostPosted: Fri Sep 12, 2014 5:00 am    Post subject: Reply with quote  Mark this post and the followings unread

That's a bit warm then. The Zybo uses the 7010, there's no heat sink on it. I wonder if all Parallellas run that hot...
_________________
FPGA, dsPIC and Fatman Synth Stuff

Time flies like a banana.
Fruit flies when you're having fun.
BTW, Do these genes make my ass look fat?
corruptio optimi pessima
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Fri Sep 12, 2014 6:45 am    Post subject: Reply with quote  Mark this post and the followings unread

JovianPyx wrote:
That's a bit warm then. The Zybo uses the 7010, there's no heat sink on it. I wonder if all Parallellas run that hot...


Reports form the forum say the 7010s do as well, you basically need a heatsink and fan to use one.

Are you sure it is a 7010 in the Zybo as it seems strange that the parallellas runs this hot and the zybo doesn't!
Back to top
View user's profile Send private message
JovianPyx



Joined: Nov 20, 2007
Posts: 1988
Location: West Red Spot, Jupiter
Audio files: 224

PostPosted: Fri Sep 12, 2014 7:02 am    Post subject: Reply with quote  Mark this post and the followings unread

BobTheDog wrote:
Reports form the forum say the 7010s do as well, you basically need a heatsink and fan to use one.

Are you sure it is a 7010 in the Zybo as it seems strange that the parallellas runs this hot and the zybo doesn't!


ZYNQ XC7Z2010-1CLG400C is the full part number for the Zynq on the Zybo

http://www.digilentinc.com/Products/Detail.cfm?NavPath=2,400,1198&Prod=ZYBO

From the website: "The ZYBO (Zynq Board) is a feature-rich, ready-to-use, entry-level embedded software and digital circuit development platform built around the smallest member of the Xilinx Zynq-7000 family, the Z-7010."

The ARM cores run at 650 MHz. I've never run the PL with a clock faster than 125 MHz. The Zybo Zynq runs at a temperature that is barely above room temp.

If all of the boards do that, it's hard to believe that the mfr would release the product that way (running 10C over max temp). And you had to add a heatsink and fan! I'd would be good to hear from other users.

_________________
FPGA, dsPIC and Fatman Synth Stuff

Time flies like a banana.
Fruit flies when you're having fun.
BTW, Do these genes make my ass look fat?
corruptio optimi pessima
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Fri Sep 12, 2014 11:11 am    Post subject: Reply with quote  Mark this post and the followings unread

It comes with the heatsink. Everyone adds a fan though.

I will post on their site about it....
Back to top
View user's profile Send private message
jksuperstar



Joined: Aug 20, 2004
Posts: 2503
Location: Denver
Audio files: 1
G2 patch files: 18

PostPosted: Fri Sep 12, 2014 12:57 pm    Post subject: Reply with quote  Mark this post and the followings unread

I can confirm my ZyBo (7010) pretty much runs at room temp, also.

In fact, I've done a lot of even large FPGAs (virtex-7) that are highly utilized, and they don't require a heatsink either.

I would bet the base config for the FPGA on the Parallela board is wrong, and the I/Os are burning through a ton a wasted power. The cores run at 1 volts or so, and it would take a lot of simultaneous switching, high clock rates, and a fast process corner to generate that much heat.

(I forgot to mention the board can run pretty well off just USB power!)
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Sat Sep 13, 2014 5:00 am    Post subject: Reply with quote  Mark this post and the followings unread

Well here is the reply I got when I asked why it runs so hot compared to the Zybo:

Quote:
Because it's a small and densely populated board. My guess is that their board is bigger and possibly has a smaller BOM. If you take the ZedBoard, for example, it's much larger and has a fair bit of space around the Zynq.
Back to top
View user's profile Send private message
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Sat Sep 13, 2014 5:03 am    Post subject: Reply with quote  Mark this post and the followings unread

With those Zybos can you reprogram the fpga while running Linux without having to rewrite the bitstream and reboot?
Back to top
View user's profile Send private message
JovianPyx



Joined: Nov 20, 2007
Posts: 1988
Location: West Red Spot, Jupiter
Audio files: 224

PostPosted: Sat Sep 13, 2014 5:10 am    Post subject: Reply with quote  Mark this post and the followings unread

BobTheDog wrote:
With those Zybos can you reprogram the fpga while running Linux without having to rewrite the bitstream and reboot?


Yes (to the reboot part), there is a device /dev/xdevcfg that can be used to send data to the PL (FPGA) from Linux as a stream. In fact, If there is already a bitstream sent to the FPGA at boot time it's very small and primitive.

Used this way: cat system.bit > /dev/xdevcfg

Linux remains running after this is done. This is what I use to test experiments with AXI4lite interfaces between PS and PL. It's a fairly simple/easy process to change the IP address of the board and one can use scp to get the files from a PC to the Zybo.

Of course, if the only thing you need is the PL, then you can also use iMPACT to send the file directly from a PC to the FPGA. In this case, I don't know if PetaLinux remains running, I've never checked.

_________________
FPGA, dsPIC and Fatman Synth Stuff

Time flies like a banana.
Fruit flies when you're having fun.
BTW, Do these genes make my ass look fat?
corruptio optimi pessima
Back to top
View user's profile Send private message Visit poster's website
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Sat Sep 13, 2014 5:43 am    Post subject: Reply with quote  Mark this post and the followings unread

Thanks, I think I will try to get hold of a zybo although this doesn't seem that easy in Euroland.

It doesn't seem so easy on the parallella, the fgpa code is loaded at boot.
Back to top
View user's profile Send private message
alcofribas



Joined: Oct 03, 2008
Posts: 22
Location: Eastern France

PostPosted: Wed Sep 17, 2014 6:02 am    Post subject: Reply with quote  Mark this post and the followings unread

The Zybo is available from Trenz

[url]
http://shop.trenz-electronic.de/catalog/product_info.php?cPath=1_114_119&products_id=1412
[/url]

This is the page for the commercial-price unit. An academic-price version is also available, but you have to jump through some hoops to get the discount.

Hope this is useful

Alcofribas
Back to top
View user's profile Send private message
BobTheDog



Joined: Feb 28, 2005
Posts: 4044
Location: England
Audio files: 32
G2 patch files: 15

PostPosted: Sat Sep 20, 2014 12:21 am    Post subject: Reply with quote  Mark this post and the followings unread

BobTheDog wrote:
Thanks, I think I will try to get hold of a zybo although this doesn't seem that easy in Euroland.

It doesn't seem so easy on the parallella, the fgpa code is loaded at boot.


In fact it is easy, first you need to create a xdevcfg device:

Code:

mknod /dev/xdevcfg c 250 0


Then you can copy the bit file to it:

Code:

cat bit.bin > /dev/xdevcfg
cat /sys/devices/amba.1/f8007000.devcfg/prog_done


the prig_done contains 1 if all goes well.
Back to top
View user's profile Send private message
Display posts from previous:   
Post new topic   Reply to topic Moderators: State Machine
Page 1 of 2 [30 Posts]
View unread posts
View new posts in the last week
Goto page: 1, 2 Next
Mark the topic unread :: View previous topic :: View next topic
 Forum index » DIY Hardware and Software » Microcontrollers and Programmable Logic
Jump to:  

You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum


Forum with support of Syndicator RSS
Powered by phpBB © 2001, 2005 phpBB Group
Copyright © 2003 through 2009 by electro-music.com - Conditions Of Use