Buriedcode
Full Member level 6

Hi, I having real trouble deciding what type of microcontroller to use for my app. Heres the specs:
Read in data from a I2S bus, 32KSps, 20-24 bits.
Encode with FEC and add extra control bits.
Encode with manchester encoding, with preamble and word sync.
Output in serial, or to a DAC for pulse shaping (so we have 8 bits per actual 'bit').
OUtput datarate = 1.526MB/s - 3.072MB/s.
My original design used a simple CPLD, and it worked a treat because its pure logic, but a CPLD lacks the memory/arithmatic for complex forward error correction, pulse shaping (probably using LUTs). Also microcontrollers have many other peripheral goodies I can use to check battery status, and implement controll functions. Also, I reallly don't need that many I/O lines. Ideally a 'one-chip' solution.
A PIC is out, its just not fast enough with 5MIPS, and the faster ones are too big for my design. Maybe an Atmel chip, with 1 instruction per clock. I'm really looking at ARM micros now, maybe even a cheap DSP, since these have the speed, the data-bus width (16 bit) and low power consuption compared with the CPLD.
This was 'sparked' by the recent post about 'ARM' micro's, I did a little research and found some very cheap ones, and some cheap DSP's with ARM architecture.
So, anyone have any thoughts on the matter?
I realise it may seem over-kill, since I'm just using the chip for its speed, (one pin outputing 3mb/s) but I'd like to have room for upgrades, and I've seen similar devices (wireless digital audio) that use fast microcontrollers instead of DSP's (I'm not doing any audio compression btw). And finally, for some reason some quite powerful micro's are in fact cheaper than basic CPLD's (in the UK anyway), so cost is a factor.
Sorry for rambling on, but I'd like people's experiences with fast microcontrollers, and what their opinion is as too where they would fit in, in such an application.
Thankyou
Buriedcode.
Read in data from a I2S bus, 32KSps, 20-24 bits.
Encode with FEC and add extra control bits.
Encode with manchester encoding, with preamble and word sync.
Output in serial, or to a DAC for pulse shaping (so we have 8 bits per actual 'bit').
OUtput datarate = 1.526MB/s - 3.072MB/s.
My original design used a simple CPLD, and it worked a treat because its pure logic, but a CPLD lacks the memory/arithmatic for complex forward error correction, pulse shaping (probably using LUTs). Also microcontrollers have many other peripheral goodies I can use to check battery status, and implement controll functions. Also, I reallly don't need that many I/O lines. Ideally a 'one-chip' solution.
A PIC is out, its just not fast enough with 5MIPS, and the faster ones are too big for my design. Maybe an Atmel chip, with 1 instruction per clock. I'm really looking at ARM micros now, maybe even a cheap DSP, since these have the speed, the data-bus width (16 bit) and low power consuption compared with the CPLD.
This was 'sparked' by the recent post about 'ARM' micro's, I did a little research and found some very cheap ones, and some cheap DSP's with ARM architecture.
So, anyone have any thoughts on the matter?
I realise it may seem over-kill, since I'm just using the chip for its speed, (one pin outputing 3mb/s) but I'd like to have room for upgrades, and I've seen similar devices (wireless digital audio) that use fast microcontrollers instead of DSP's (I'm not doing any audio compression btw). And finally, for some reason some quite powerful micro's are in fact cheaper than basic CPLD's (in the UK anyway), so cost is a factor.
Sorry for rambling on, but I'd like people's experiences with fast microcontrollers, and what their opinion is as too where they would fit in, in such an application.
Thankyou
Buriedcode.