diff --git a/libs/ardour/ltc_slave.cc b/libs/ardour/ltc_slave.cc
index 6f3f464419..2117020e92 100644
--- a/libs/ardour/ltc_slave.cc
+++ b/libs/ardour/ltc_slave.cc
@@ -657,16 +657,22 @@ LTC_TransportMaster::position_string() const
std::string
LTC_TransportMaster::delta_string() const
{
- char delta[80];
+ char delta[128];
if (!_collect || current.timestamp == 0) {
snprintf (delta, sizeof(delta), "\u2012\u2012\u2012\u2012");
} else if ((monotonic_cnt - current.timestamp) > 2 * samples_per_ltc_frame) {
snprintf (delta, sizeof(delta), "%s", _("flywheel"));
} else {
- snprintf (delta, sizeof(delta), "%s%s%lldsm",
- sync_lock_broken ? "red" : "white",
- LEADINGZERO(::llabs(_current_delta)), PLUSMINUS(-_current_delta), ::llabs(_current_delta));
+ if (abs (_current_delta) > _session->sample_rate()) {
+ int secs = rint ((double) _current_delta / _session->sample_rate());
+ snprintf(delta, sizeof(delta), "\u0394%s%s%d s",
+ LEADINGZERO(abs(secs)), PLUSMINUS(-secs), abs(secs));
+ } else {
+ snprintf (delta, sizeof(delta), "%s%s%lldsm",
+ sync_lock_broken ? "red" : "white",
+ LEADINGZERO(::llabs(_current_delta)), PLUSMINUS(-_current_delta), ::llabs(_current_delta));
+ }
}
return delta;