From b9ff49548301d6c62476684462ae15a616d82415 Mon Sep 17 00:00:00 2001 From: Nick Craig-Wood Date: Sat, 20 Jun 2020 12:25:33 +0100 Subject: [PATCH] vfs: writeback - stop the timer explicitly on transfers exceeded --- vfs/vfscache/writeback.go | 25 ++++++++++++++++--------- 1 file changed, 16 insertions(+), 9 deletions(-) diff --git a/vfs/vfscache/writeback.go b/vfs/vfscache/writeback.go index 84b4efece..c0cf2ce3b 100644 --- a/vfs/vfscache/writeback.go +++ b/vfs/vfscache/writeback.go @@ -187,19 +187,24 @@ func (wb *writeBack) _peekItem() (wbItem *writeBackItem) { return wb.items[0] } +// stop the timer which runs the expiries +func (wb *writeBack) _stopTimer() { + if wb.expiry.IsZero() { + return + } + wb.expiry = time.Time{} + fs.Debugf(nil, "resetTimer STOP") + if wb.timer != nil { + wb.timer.Stop() + wb.timer = nil + } +} + // reset the timer which runs the expiries func (wb *writeBack) _resetTimer() { wbItem := wb._peekItem() if wbItem == nil { - if wb.expiry.IsZero() { - return - } - wb.expiry = time.Time{} - fs.Debugf(nil, "resetTimer STOP") - if wb.timer != nil { - wb.timer.Stop() - wb.timer = nil - } + wb._stopTimer() } else { if wb.expiry.Equal(wbItem.expiry) { return @@ -377,6 +382,8 @@ func (wb *writeBack) processItems(ctx context.Context) { if resetTimer { wb._resetTimer() + } else { + wb._stopTimer() } }