[alsa-devel] [PATCH] pcm: add new 32-bit DSD sample format

Jurgen Kramer gtmkramer at xs4all.nl
Thu Nov 20 17:34:48 CET 2014


On Thu, 2014-11-20 at 10:58 +0100, Takashi Iwai wrote:
> At Wed, 19 Nov 2014 21:50:30 +0200,
> Jussi Laako wrote:
> > 
> > Hi,
> > 
> > Sorry for catching up late on this patch...
> > 
> > On 10.09.2014 10:00, Jurgen Kramer wrote:
> > > +	FORMATD(DSD_U32_LE, "Direct Stream Digital, 4-byte (x32), little endian, oldest bits in MSB"),
> > 
> > There is bug in this patch. The spec for these formats is, as above says 
> > "little endian, oldest bits in MSB", however with the iFi iDSD Nano this 
> > doesn't seem to be the case. Oldest bits are in MSB of the byte, but 
> > byte order is big endian.
> 
> Is it a bug of spec, or a bug of device?
> In the latter case, we'd need to introduce DSD_U32_BE format and apply
> a quirk, for example.
DSD is a bit odd wrt LE/BE. Both formats are allowed and used.
The device (XMOS based/Marantz+Denon) want the following order of
samples: 
L1 L2 L3 L4 R1 R2 R3 R4. Where Lx/Rx are 8-bit DSD samples, L1-L4 are
packed to 1 32-bit sample.

I do think real BE will not work.

Jurgen
> 
> Takashi
> 
> > IOW, following alone will produce incorrect 
> > output:
> > 
> > size_t N = 32;
> > uint32_t x = 0;
> > while (N--)
> > {
> > 	x <<= 1;
> > 	x |= nextbit;
> > }
> > 
> > But if you add __builtin_byteswap32(x) then the output is correct.
> > 
> > I guess this has not been caught because of just memcpy()'ing the 
> > oldest-bit-in-MSB byte stream to the sample buffer instead of 
> > constructing the words...
> > 
> > 
> > Best regards,
> > 
> > 	- Jussi
> > _______________________________________________
> > Alsa-devel mailing list
> > Alsa-devel at alsa-project.org
> > http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
> > 
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
> 




More information about the Alsa-devel mailing list