ofs | hex dump | ascii |
---|
0000 | 46 72 6f 6d 3a 20 22 42 65 6e 6e 6f 20 53 65 6e 6f 6e 65 72 22 20 3c 73 62 65 6e 6e 6f 40 67 61 | From:."Benno.Senoner".<sbenno@ga |
0020 | 72 64 65 6e 61 2e 6e 65 74 3e 0a 54 6f 3a 20 3c 6d 75 73 69 63 2d 64 73 70 40 73 68 6f 6b 6f 2e | rdena.net>.To:.<music-dsp@shoko. |
0040 | 63 61 6c 61 72 74 73 2e 65 64 75 3e 0a 53 75 62 6a 65 63 74 3a 20 52 65 3a 20 5b 6d 75 73 69 63 | calarts.edu>.Subject:.Re:.[music |
0060 | 2d 64 73 70 5d 20 63 6f 64 69 6e 67 20 72 65 61 6c 74 69 6d 65 20 67 75 69 74 61 72 20 65 66 78 | -dsp].coding.realtime.guitar.efx |
0080 | 20 6f 6e 20 61 20 22 70 63 22 0a 44 61 74 65 3a 20 53 61 74 75 72 64 61 79 2c 20 4a 75 6e 65 20 | .on.a."pc".Date:.Saturday,.June. |
00a0 | 33 30 2c 20 32 30 30 31 20 38 3a 31 39 20 41 4d 0a 0a 0a 41 6e 64 72 e8 2c 0a 79 6f 75 20 61 72 | 30,.2001.8:19.AM...Andr.,.you.ar |
00c0 | 65 20 73 6f 6c 76 69 6e 67 20 79 6f 75 72 20 70 72 6f 62 6c 65 6d 20 74 68 65 20 77 72 6f 6e 67 | e.solving.your.problem.the.wrong |
00e0 | 20 77 61 79 3a 0a 79 6f 75 20 6e 65 65 64 20 74 6f 20 75 73 65 20 61 20 73 69 6e 67 6c 65 20 74 | .way:.you.need.to.use.a.single.t |
0100 | 68 72 65 61 64 65 64 20 73 6f 6c 75 74 69 6f 6e 20 77 68 69 63 68 20 64 6f 65 73 20 74 68 69 73 | hreaded.solution.which.does.this |
0120 | 3a 0a 0a 2d 20 73 65 74 20 74 68 65 20 61 75 64 69 6f 20 49 2f 4f 20 70 61 72 61 6d 65 74 65 72 | :..-.set.the.audio.I/O.parameter |
0140 | 73 20 74 6f 20 20 66 72 61 67 6e 75 6d 3d 34 20 20 66 72 61 67 73 69 7a 65 3d 31 32 38 20 62 79 | s.to..fragnum=4..fragsize=128.by |
0160 | 74 65 73 20 28 3d 33 32 73 61 6d 70 6c 65 73 29 20 69 66 0a 79 6f 75 20 75 73 65 20 73 74 65 72 | tes.(=32samples).if.you.use.ster |
0180 | 65 6f 20 6f 72 20 20 20 66 72 61 67 73 69 7a 65 3d 36 34 20 62 79 74 65 73 20 28 3d 33 32 20 73 | eo.or...fragsize=64.bytes.(=32.s |
01a0 | 61 6d 70 6c 65 73 29 20 69 66 20 79 6f 75 20 75 73 65 20 6d 6f 6e 6f 2e 0a 0a 28 64 6f 20 6e 6f | amples).if.you.use.mono...(do.no |
01c0 | 74 20 66 6f 72 67 65 74 20 74 6f 20 61 63 74 69 76 61 74 65 20 66 75 6c 6c 74 75 70 6c 65 78 20 | t.forget.to.activate.fulltuplex. |
01e0 | 77 69 74 68 20 75 73 69 6e 67 20 74 68 65 20 5f 54 52 49 47 47 45 52 5f 20 73 74 75 66 66 29 0a | with.using.the._TRIGGER_.stuff). |
0200 | 28 79 6f 75 20 6e 65 65 64 20 74 6f 20 66 72 69 73 74 20 64 65 61 63 74 69 76 61 74 65 20 61 75 | (you.need.to.frist.deactivate.au |
0220 | 64 69 6f 20 61 6e 64 20 74 68 65 6e 20 73 74 61 72 74 20 74 68 65 20 74 72 69 67 67 65 72 20 61 | dio.and.then.start.the.trigger.a |
0240 | 66 74 65 72 20 74 68 65 20 44 41 43 20 69 73 0a 70 72 65 66 69 6c 6c 65 64 20 28 73 65 65 20 62 | fter.the.DAC.is.prefilled.(see.b |
0260 | 65 6c 6f 77 29 29 0a 0a 54 68 69 73 20 77 69 6c 6c 20 67 69 76 65 20 79 6f 75 20 61 20 74 6f 74 | elow))..This.will.give.you.a.tot |
0280 | 61 6c 20 69 6e 70 75 74 20 74 6f 20 6f 75 74 70 75 74 20 6c 61 74 65 6e 63 79 20 6f 66 20 34 78 | al.input.to.output.latency.of.4x |
02a0 | 33 32 20 73 61 6d 70 6c 65 73 0a 3d 20 31 32 38 20 73 61 6d 70 6c 65 73 20 77 68 69 63 68 20 61 | 32.samples.=.128.samples.which.a |
02c0 | 74 20 34 34 2e 31 6b 48 7a 20 63 6f 72 72 65 73 70 6f 6e 64 20 74 6f 20 32 2e 39 6d 73 65 63 20 | t.44.1kHz.correspond.to.2.9msec. |
02e0 | 6c 61 74 65 6e 63 79 2e 0a 0a 6e 6f 77 20 73 65 74 20 79 6f 75 72 20 70 72 6f 63 65 73 73 20 74 | latency...now.set.your.process.t |
0300 | 6f 20 53 43 48 45 44 5f 46 49 46 4f 20 20 28 73 65 65 20 6d 61 6e 20 73 63 68 65 64 5f 73 65 74 | o.SCHED_FIFO..(see.man.sched_set |
0320 | 73 63 68 65 64 75 6c 65 72 29 0a 0a 61 66 74 65 72 20 74 68 65 20 69 6e 69 74 69 61 6c 69 7a 61 | scheduler)..after.the.initializa |
0340 | 74 69 6f 6e 20 79 6f 75 72 20 63 6f 64 65 20 73 68 6f 75 6c 64 20 64 6f 20 6d 6f 72 65 20 74 68 | tion.your.code.should.do.more.th |
0360 | 61 6e 20 6c 65 73 73 20 74 68 69 73 3a 0a 0a 2d 20 77 72 69 74 65 28 29 20 20 34 20 78 20 33 32 | an.less.this:..-.write()..4.x.32 |
0380 | 20 73 61 6d 70 6c 65 73 20 74 6f 20 74 68 65 20 61 75 64 69 6f 20 66 64 20 69 6e 20 6f 72 64 65 | .samples.to.the.audio.fd.in.orde |
03a0 | 72 20 74 6f 20 70 72 65 66 69 6c 6c 20 74 68 65 20 44 41 43 2e 0a 57 69 74 68 6f 75 74 20 74 68 | r.to.prefill.the.DAC..Without.th |
03c0 | 69 73 20 79 6f 75 20 77 69 6c 6c 20 67 65 74 20 64 72 6f 70 6f 75 74 73 2e 0a 0a 77 68 69 6c 65 | is.you.will.get.dropouts...while |
03e0 | 28 31 29 20 7b 0a 20 20 72 65 61 64 28 29 20 33 32 20 73 61 6d 70 6c 65 73 20 66 72 6f 6d 20 41 | (1).{...read().32.samples.from.A |
0400 | 44 43 0a 20 20 70 65 72 66 6f 72 6d 5f 64 73 70 5f 73 74 75 66 66 28 29 20 6f 6e 20 74 68 65 20 | DC...perform_dsp_stuff().on.the. |
0420 | 33 32 20 73 61 6d 70 6c 65 73 0a 20 20 77 72 69 74 65 28 29 20 33 32 20 73 61 6d 70 6c 65 73 20 | 32.samples...write().32.samples. |
0440 | 20 74 6f 20 44 41 43 0a 20 20 7d 0a 0a 49 66 20 79 6f 75 20 75 73 65 20 61 20 6c 6f 77 20 6c 61 | .to.DAC...}..If.you.use.a.low.la |
0460 | 74 65 6e 63 79 20 6b 65 72 6e 65 6c 20 61 6e 64 20 70 61 79 20 61 74 74 65 6e 74 69 6f 6e 20 74 | tency.kernel.and.pay.attention.t |
0480 | 6f 20 61 6c 6c 20 74 68 65 20 73 74 75 66 66 20 61 62 6f 76 65 2c 20 74 68 65 6e 0a 79 6f 75 20 | o.all.the.stuff.above,.then.you. |
04a0 | 77 69 6c 6c 20 67 65 74 20 72 6f 63 6b 20 73 6f 6c 69 64 20 33 6d 73 65 63 20 6c 61 74 65 6e 63 | will.get.rock.solid.3msec.latenc |
04c0 | 69 65 73 20 28 70 6c 75 73 20 65 76 65 6e 74 75 61 6c 20 63 6f 6e 76 65 72 74 65 72 20 6c 61 74 | ies.(plus.eventual.converter.lat |
04e0 | 65 6e 63 69 65 73 20 62 75 74 0a 74 68 65 73 65 20 61 72 65 20 69 6e 20 74 68 65 20 31 2d 32 6d | encies.but.these.are.in.the.1-2m |
0500 | 73 65 63 20 72 61 6e 67 65 20 41 46 41 49 4b 29 2e 0a 0a 55 73 69 6e 67 20 6d 75 6c 74 69 70 6c | sec.range.AFAIK)...Using.multipl |
0520 | 65 20 74 68 72 65 61 64 73 20 2c 20 70 69 70 65 73 20 65 74 63 2c 20 6f 6e 6c 79 20 63 6f 6d 70 | e.threads.,.pipes.etc,.only.comp |
0540 | 6c 69 63 61 74 65 73 20 79 6f 75 72 20 6c 69 66 65 20 61 6e 64 20 6f 66 74 65 6e 20 6d 61 6b 65 | licates.your.life.and.often.make |
0560 | 73 0a 69 74 20 69 6d 70 6f 73 73 69 62 6c 65 20 74 6f 20 61 63 68 69 65 76 65 20 74 68 65 73 65 | s.it.impossible.to.achieve.these |
0580 | 20 6c 6f 77 20 6c 61 74 65 6e 63 65 73 2e 0a 0a 52 65 61 6c 74 69 6d 65 2f 61 75 64 69 6f 20 70 | .low.latences...Realtime/audio.p |
05a0 | 72 6f 67 72 61 6d 6d 69 6e 67 20 69 73 20 6e 6f 74 20 61 6e 20 65 61 73 79 20 74 61 73 6b 20 2c | rogramming.is.not.an.easy.task., |
05c0 | 20 74 68 69 73 20 69 73 20 77 68 79 20 70 65 6f 70 6c 65 20 6f 66 74 65 6e 0a 66 61 69 6c 20 74 | .this.is.why.people.often.fail.t |
05e0 | 6f 20 67 65 74 20 74 68 65 20 64 65 73 69 72 65 64 20 72 65 73 75 6c 74 73 20 65 76 65 6e 20 69 | o.get.the.desired.results.even.i |
0600 | 66 20 74 68 65 69 72 20 68 61 72 64 77 61 72 65 20 69 73 20 6c 6f 77 2d 6c 61 74 65 6e 63 79 20 | f.their.hardware.is.low-latency. |
0620 | 63 61 70 61 62 6c 65 2e 0a 0a 54 68 65 20 70 72 6f 62 6c 65 6d 20 69 73 20 74 68 61 74 20 74 68 | capable...The.problem.is.that.th |
0640 | 65 20 66 69 6e 61 6c 20 6c 61 74 65 6e 63 79 20 64 65 70 65 6e 64 73 20 6f 6e 20 74 68 65 20 68 | e.final.latency.depends.on.the.h |
0660 | 61 72 64 77 61 72 65 20 79 6f 75 20 75 73 65 2c 0a 74 68 65 20 61 70 70 6c 69 63 61 74 69 6f 6e | ardware.you.use,.the.application |
0680 | 20 61 6e 64 20 74 68 65 20 6f 70 65 72 61 74 69 6e 67 20 73 79 73 74 65 6d 2e 0a 0a 63 68 65 65 | .and.the.operating.system...chee |
06a0 | 72 73 2c 0a 42 65 6e 6e 6f 2e 0a 0a 68 74 74 70 3a 2f 2f 77 77 77 2e 6c 69 6e 75 78 61 75 64 69 | rs,.Benno...http://www.linuxaudi |
06c0 | 6f 64 65 76 2e 6f 72 67 20 20 54 68 65 20 48 6f 6d 65 20 6f 66 20 4c 69 6e 75 78 20 41 75 64 69 | odev.org..The.Home.of.Linux.Audi |
06e0 | 6f 20 44 65 76 65 6c 6f 70 6d 65 6e 74 0a 0a 0a 0a 0a 0a 0a 4f 6e 20 53 61 74 2c 20 33 30 20 4a | o.Development.......On.Sat,.30.J |
0700 | 75 6e 20 32 30 30 31 2c 20 79 6f 75 20 77 72 6f 74 65 3a 0a 3e 20 4f 6e 20 32 30 30 31 2d 30 36 | un.2001,.you.wrote:.>.On.2001-06 |
0720 | 2d 32 39 20 32 31 3a 33 38 20 2b 30 32 30 30 2c 20 42 65 6e 6e 6f 20 53 65 6e 6f 6e 65 72 20 77 | -29.21:38.+0200,.Benno.Senoner.w |
0740 | 72 6f 74 65 3a 0a 3e 20 0a 3e 20 3e 20 4f 53 53 2f 46 72 65 65 20 72 65 66 75 73 65 73 20 74 6f | rote:.>..>.>.OSS/Free.refuses.to |
0760 | 20 75 73 65 20 61 20 6c 6f 77 20 23 20 6f 66 20 66 72 61 67 73 20 3f 0a 3e 20 3e 20 0a 3e 20 3e | .use.a.low.#.of.frags.?.>.>..>.> |
0780 | 20 54 68 61 74 27 73 20 61 20 6d 79 74 68 2e 0a 3e 20 0a 3e 20 49 20 68 6f 70 65 20 69 74 20 69 | .That's.a.myth..>..>.I.hope.it.i |
07a0 | 73 2e 20 3a 2d 29 0a 3e 20 0a 3e 20 54 68 65 20 66 61 63 74 20 69 73 20 74 68 61 74 20 69 6f 63 | s..:-).>..>.The.fact.is.that.ioc |
07c0 | 74 6c 28 53 4e 44 43 54 4c 5f 44 53 50 5f 53 45 54 46 52 41 47 4d 45 4e 54 29 20 73 75 63 63 65 | tl(SNDCTL_DSP_SETFRAGMENT).succe |
07e0 | 65 64 73 20 77 69 74 68 0a 3e 20 76 61 6c 75 65 73 20 61 73 20 6c 6f 77 20 61 20 30 78 31 30 30 | eds.with.>.values.as.low.a.0x100 |
0800 | 30 37 20 28 6f 6e 65 20 31 32 38 2d 42 20 66 72 61 67 6d 65 6e 74 29 20 62 75 74 20 74 68 65 20 | 07.(one.128-B.fragment).but.the. |
0820 | 6c 61 74 65 6e 63 79 20 69 73 0a 3e 20 73 74 69 6c 6c 20 68 69 67 68 20 65 6e 6f 75 67 68 20 74 | latency.is.>.still.high.enough.t |
0840 | 6f 20 62 65 20 63 6c 65 61 72 6c 79 20 6e 6f 74 69 63 65 61 62 6c 65 2c 20 77 68 69 63 68 20 73 | o.be.clearly.noticeable,.which.s |
0860 | 75 67 67 65 73 74 73 20 74 68 61 74 0a 3e 20 69 74 27 73 20 2a 77 61 79 2a 20 61 62 6f 76 65 20 | uggests.that.>.it's.*way*.above. |
0880 | 32 2f 33 20 6d 73 2e 20 20 54 68 69 73 20 69 73 20 6f 6e 20 61 6e 20 6f 74 68 65 72 77 69 73 65 | 2/3.ms...This.is.on.an.otherwise |
08a0 | 20 69 64 6c 65 20 6d 61 63 68 69 6e 65 0a 3e 20 65 71 75 69 70 70 65 64 20 77 69 74 68 20 61 20 | .idle.machine.>.equipped.with.a. |
08c0 | 53 42 20 50 43 49 20 31 32 38 2e 0a 3e 20 0a 3e 20 42 75 74 20 6d 61 79 62 65 20 69 74 27 73 20 | SB.PCI.128..>..>.But.maybe.it's. |
08e0 | 6d 65 20 77 68 6f 27 73 20 64 6f 69 6e 67 20 73 6f 6d 65 74 68 69 6e 67 20 77 72 6f 6e 67 2e 20 | me.who's.doing.something.wrong.. |
0900 | 49 27 76 65 20 62 65 65 6e 20 63 61 72 65 66 75 6c 0a 3e 20 74 6f 20 66 6c 75 73 68 20 73 74 64 | I've.been.careful.>.to.flush.std |
0920 | 69 6f 20 62 75 66 66 65 72 73 20 6f 72 20 75 73 65 20 75 6e 62 75 66 66 65 72 65 64 20 49 2f 4f | io.buffers.or.use.unbuffered.I/O |
0940 | 20 28 77 72 69 74 65 28 32 29 29 20 62 75 74 20 49 0a 3e 20 6d 61 79 20 68 61 76 65 20 6c 65 74 | .(write(2)).but.I.>.may.have.let |
0960 | 20 73 6f 6d 65 74 68 69 6e 67 20 65 6c 73 65 20 74 68 72 6f 75 67 68 2e 0a 3e 20 0a 3e 20 46 6f | .something.else.through..>..>.Fo |
0980 | 72 20 65 78 61 6d 70 6c 65 2c 20 73 69 6e 63 65 20 74 68 65 20 73 69 67 6e 61 6c 20 70 72 6f 63 | r.example,.since.the.signal.proc |
09a0 | 65 73 73 69 6e 67 20 61 6e 64 20 74 68 65 20 49 2f 4f 20 61 72 65 20 64 6f 6e 65 20 62 79 0a 3e | essing.and.the.I/O.are.done.by.> |
09c0 | 20 74 77 6f 20 64 69 66 66 65 72 65 6e 74 20 76 61 6e 69 6c 6c 61 20 70 72 6f 63 65 73 73 65 73 | .two.different.vanilla.processes |
09e0 | 20 63 6f 6d 6d 75 6e 69 63 61 74 69 6e 67 20 76 69 61 20 70 69 70 65 73 2c 20 69 74 20 6d 61 79 | .communicating.via.pipes,.it.may |
0a00 | 0a 3e 20 62 65 20 61 20 73 63 68 65 64 75 6c 69 6e 67 20 67 72 61 6e 75 6c 61 72 69 74 79 20 70 | .>.be.a.scheduling.granularity.p |
0a20 | 72 6f 62 6c 65 6d 20 28 45 2e 47 2e 20 74 68 65 20 6b 65 72 6e 65 6c 20 67 69 76 69 6e 67 20 74 | roblem.(E.G..the.kernel.giving.t |
0a40 | 68 65 0a 3e 20 49 2f 4f 20 70 72 6f 63 65 73 73 20 61 20 74 69 6d 65 20 73 6c 69 63 65 20 65 76 | he.>.I/O.process.a.time.slice.ev |
0a60 | 65 72 79 20 32 30 20 6d 73 29 2e 0a 3e 20 0a 3e 20 2d 2d 20 0a 3e 20 41 6e 64 72 e9 20 4d 61 6a | ery.20.ms)..>..>.--..>.Andr..Maj |
0a80 | 6f 72 65 6c 20 3c 61 6d 61 6a 6f 72 65 6c 40 74 65 61 73 65 72 2e 66 72 3e 0a 3e 20 68 74 74 70 | orel.<amajorel@teaser.fr>.>.http |
0aa0 | 3a 2f 2f 77 77 77 2e 74 65 61 73 65 72 2e 66 72 2f 7e 61 6d 61 6a 6f 72 65 6c 2f 0a 3e 20 0a 3e | ://www.teaser.fr/~amajorel/.>..> |
0ac0 | 20 64 75 70 73 77 61 70 64 72 6f 70 20 2d 2d 20 74 68 65 20 6d 75 73 69 63 2d 64 73 70 20 6d 61 | .dupswapdrop.--.the.music-dsp.ma |
0ae0 | 69 6c 69 6e 67 20 6c 69 73 74 20 61 6e 64 20 77 65 62 73 69 74 65 3a 20 73 75 62 73 63 72 69 70 | iling.list.and.website:.subscrip |
0b00 | 74 69 6f 6e 20 69 6e 66 6f 2c 0a 3e 20 46 41 51 2c 20 73 6f 75 72 63 65 20 63 6f 64 65 20 61 72 | tion.info,.>.FAQ,.source.code.ar |
0b20 | 63 68 69 76 65 2c 20 6c 69 73 74 20 61 72 63 68 69 76 65 2c 20 62 6f 6f 6b 20 72 65 76 69 65 77 | chive,.list.archive,.book.review |
0b40 | 73 2c 20 64 73 70 20 6c 69 6e 6b 73 0a 3e 20 68 74 74 70 3a 2f 2f 73 68 6f 6b 6f 2e 63 61 6c 61 | s,.dsp.links.>.http://shoko.cala |
0b60 | 72 74 73 2e 65 64 75 2f 6d 75 73 69 63 64 73 70 2f 0a 2d 2d 20 0a 0a 0a 64 75 70 73 77 61 70 64 | rts.edu/musicdsp/.--....dupswapd |
0b80 | 72 6f 70 20 2d 2d 20 74 68 65 20 6d 75 73 69 63 2d 64 73 70 20 6d 61 69 6c 69 6e 67 20 6c 69 73 | rop.--.the.music-dsp.mailing.lis |
0ba0 | 74 20 61 6e 64 20 77 65 62 73 69 74 65 3a 20 73 75 62 73 63 72 69 70 74 69 6f 6e 20 69 6e 66 6f | t.and.website:.subscription.info |
0bc0 | 2c 0a 46 41 51 2c 20 73 6f 75 72 63 65 20 63 6f 64 65 20 61 72 63 68 69 76 65 2c 20 6c 69 73 74 | ,.FAQ,.source.code.archive,.list |
0be0 | 20 61 72 63 68 69 76 65 2c 20 62 6f 6f 6b 20 72 65 76 69 65 77 73 2c 20 64 73 70 20 6c 69 6e 6b | .archive,.book.reviews,.dsp.link |
0c00 | 73 0a 68 74 74 70 3a 2f 2f 73 68 6f 6b 6f 2e 63 61 6c 61 72 74 73 2e 65 64 75 2f 6d 75 73 69 63 | s.http://shoko.calarts.edu/music |
0c20 | 64 73 70 2f 0a 0a 00 | dsp/... |