summaryrefslogtreecommitdiff
path: root/3rdparty/portaudio/src/hostapi/oss/low_latency_tip.txt
blob: 2d982b79baa6d943c1fae0c7122d190ebf46c6f4 (plain)
ofshex dumpascii
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/...