1
Fork 0
mirror of https://github.com/jech/galene.git synced 2024-11-22 08:35:57 +01:00

Move monotonic time to separate package, use microseconds.

This commit is contained in:
Juliusz Chroboczek 2020-05-02 15:27:47 +02:00
parent 1f50b42ee0
commit 7961d7279b
4 changed files with 70 additions and 22 deletions

View file

@ -18,6 +18,7 @@ import (
"time"
"sfu/estimator"
"sfu/mono"
"sfu/packetcache"
"github.com/gorilla/websocket"
@ -319,10 +320,10 @@ func upLoop(conn *upConnection, track *upTrack) {
buf := make([]byte, packetcache.BufSize)
var packet rtp.Packet
var local []*downTrack
var localTime time.Time
var localTime uint64
for {
now := time.Now()
if now.Sub(localTime) > time.Second/2 {
now := mono.Microseconds()
if now < localTime || now > localTime + 500000 {
local = track.getLocal()
localTime = now
}
@ -598,7 +599,9 @@ func rtcpDownListener(g *group, conn *downConnection, track *downTrack, s *webrt
log.Printf("sendPLI: %v", err)
}
case *rtcp.ReceiverEstimatedMaximumBitrate:
track.maxBitrate.Set(p.Bitrate, msSinceEpoch())
track.maxBitrate.Set(p.Bitrate,
mono.Microseconds(),
)
case *rtcp.ReceiverReport:
for _, r := range p.Reports {
if r.SSRC == track.track.SSRC() {
@ -609,7 +612,9 @@ func rtcpDownListener(g *group, conn *downConnection, track *downTrack, s *webrt
}
}
case *rtcp.TransportLayerNack:
maxBitrate := track.maxBitrate.Get(msSinceEpoch())
maxBitrate := track.maxBitrate.Get(
mono.Microseconds(),
)
bitrate := track.rate.Estimate()
if uint64(bitrate) < maxBitrate {
sendRecovery(p, track)
@ -640,7 +645,7 @@ func trackKinds(down *downConnection) (audio bool, video bool) {
}
func updateUpBitrate(up *upConnection) {
now := msSinceEpoch()
now := mono.Microseconds()
for _, track := range up.tracks {
track.maxBitrate = ^uint64(0)
@ -678,8 +683,8 @@ func updateUpBitrate(up *upConnection) {
func (up *upConnection) sendPLI(track *upTrack) error {
last := atomic.LoadUint64(&track.lastPLI)
now := msSinceEpoch()
if now >= last && now-last < 200 {
now := mono.Microseconds()
if now >= last && now-last < 200000 {
return nil
}
atomic.StoreUint64(&track.lastPLI, now)

View file

@ -17,6 +17,7 @@ import (
"time"
"sfu/estimator"
"sfu/mono"
"sfu/packetcache"
"github.com/pion/webrtc/v2"
@ -68,28 +69,22 @@ type upConnection struct {
tracks []*upTrack
}
func msSinceEpoch() uint64 {
return uint64(time.Since(epoch) / time.Millisecond)
}
var epoch = time.Now()
type timeStampedBitrate struct {
bitrate uint64
timestamp uint64
bitrate uint64
microseconds uint64
}
func (tb *timeStampedBitrate) Set(bitrate, timestamp uint64) {
func (tb *timeStampedBitrate) Set(bitrate, us uint64) {
// this is racy -- a reader might read the
// data between the two writes. This shouldn't
// matter, we'll recover at the next sample.
atomic.StoreUint64(&tb.bitrate, bitrate)
atomic.StoreUint64(&tb.timestamp, timestamp)
atomic.StoreUint64(&tb.bitrate, bitrate)
atomic.StoreUint64(&tb.microseconds, us)
}
func (tb *timeStampedBitrate) Get(now uint64) uint64 {
ts := atomic.LoadUint64(&tb.timestamp)
if now < ts || now > ts + 1000 {
ts := atomic.LoadUint64(&tb.microseconds)
if now < ts || now > ts+4000000 {
return ^uint64(0)
}
return atomic.LoadUint64(&tb.bitrate)
@ -720,7 +715,7 @@ func getClientStats(c *client) clientStats {
loss := atomic.LoadUint32(&t.loss)
conns.tracks = append(conns.tracks, trackStats{
bitrate: uint64(t.rate.Estimate()) * 8,
maxBitrate: t.maxBitrate.Get(msSinceEpoch()),
maxBitrate: t.maxBitrate.Get(mono.Microseconds()),
loss: uint8((loss * 100) / 256),
})
}

19
mono/mono.go Normal file
View file

@ -0,0 +1,19 @@
package mono
import (
"time"
)
var epoch = time.Now()
func fromDuration(d time.Duration, hz uint32) uint64 {
return uint64(d) * uint64(hz) / uint64(time.Second)
}
func Now(hz uint32) uint64 {
return fromDuration(time.Since(epoch), hz)
}
func Microseconds() uint64 {
return Now(1000000)
}

29
mono/mono_test.go Normal file
View file

@ -0,0 +1,29 @@
package mono
import (
"testing"
"time"
)
func differs(a, b, delta uint64) bool {
if a < b {
a, b = b, a
}
return a - b >= delta
}
func TestMono(t *testing.T) {
a := Now(48000)
time.Sleep(4 * time.Millisecond)
b := Now(48000) - a
if differs(b, 4 * 48, 16) {
t.Errorf("Expected %v, got %v", 4 * 48, b)
}
c := Microseconds()
time.Sleep(4 * time.Millisecond)
d := Microseconds() - c
if differs(d, 4000, 1000) {
t.Errorf("Expected %v, got %v", 4000, d)
}
}