From 61d1a86ec3fbff20742146005f67b4764541067d Mon Sep 17 00:00:00 2001 From: Jean-Michel Lacroix Date: Tue, 25 Oct 2022 15:23:09 -0400 Subject: [PATCH] bandwidthd: fix time_t problem Fixes issu #19510 with the change in time_t with musl 1.2 Signed-off-by: Jean-Michel Lacroix --- utils/bandwidthd/Makefile | 4 +- .../bandwidthd/patches/040-64bit-time-t.patch | 76 +++++++++++++++++++ 2 files changed, 78 insertions(+), 2 deletions(-) diff --git a/utils/bandwidthd/Makefile b/utils/bandwidthd/Makefile index 89af8e85b7f7c..d0bb1300079f1 100644 --- a/utils/bandwidthd/Makefile +++ b/utils/bandwidthd/Makefile @@ -1,5 +1,5 @@ # -# Copyright (C) 2006-2017 OpenWrt.org +# Copyright (C) 2006-2020 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. @@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk PKG_NAME:=bandwidthd PKG_VERSION:=2.0.1-35 -PKG_RELEASE:=6 +PKG_RELEASE:=7 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz PKG_SOURCE_URL:=https://codeload.github.com/NethServer/bandwidthd/tar.gz/$(PKG_VERSION)? diff --git a/utils/bandwidthd/patches/040-64bit-time-t.patch b/utils/bandwidthd/patches/040-64bit-time-t.patch index d07506b511c3d..f0ddd586e45d0 100644 --- a/utils/bandwidthd/patches/040-64bit-time-t.patch +++ b/utils/bandwidthd/patches/040-64bit-time-t.patch @@ -1,5 +1,14 @@ --- a/bandwidthd.c +++ b/bandwidthd.c +@@ -103,7 +103,7 @@ void bd_CollectingData(char *filename) + } + } + +-int WriteOutWebpages(long int timestamp) ++int WriteOutWebpages(time_t timestamp) + { + struct IPDataStore *DataStore = IPDataStore; + struct SummaryData **SummaryData; @@ -893,7 +893,7 @@ void StoreIPDataInCDF(struct IPData IncD { IPData = &IncData[counter]; @@ -36,3 +45,70 @@ goto End_RecoverDataFromCdf; if (!timestamp) // First run through loop +--- a/graph.c ++++ b/graph.c +@@ -767,8 +767,8 @@ void PrepareXAxis(gdImagePtr im, time_t + int black, red; + time_t sample_begin, sample_end; + struct tm *timestruct; +- long int MarkTime; +- long int MarkTimeStep; ++ time_t MarkTime; ++ time_t MarkTimeStep; + double x; + + sample_begin=timestamp-config.range; +@@ -786,7 +786,7 @@ void PrepareXAxis(gdImagePtr im, time_t + if ((24*60*60*(XWIDTH-XOFFSET))/config.range > (XWIDTH-XOFFSET)/10) + { + // Day bars +- timestruct = localtime((time_t *)&sample_begin); ++ timestruct = localtime(&sample_begin); + timestruct->tm_sec = 0; + timestruct->tm_min = 0; + timestruct->tm_hour = 0; +@@ -805,7 +805,7 @@ void PrepareXAxis(gdImagePtr im, time_t + gdImageLine(im, x, 0, x, YHEIGHT-YOFFSET, red); + gdImageLine(im, x+1, 0, x+1, YHEIGHT-YOFFSET, red); + +- timestruct = localtime((time_t *)&MarkTime); ++ timestruct = localtime(&MarkTime); + strftime(buffer, 100, "%a, %b %d", timestruct); + gdImageString(im, gdFontSmall, x-30, YHEIGHT-YOFFSET+10, buffer, black); + +@@ -817,7 +817,7 @@ void PrepareXAxis(gdImagePtr im, time_t + else + { + // Month Bars +- timestruct = localtime((time_t *)&sample_begin); ++ timestruct = localtime(&sample_begin); + timestruct->tm_sec = 0; + timestruct->tm_min = 0; + timestruct->tm_hour = 0; +@@ -839,7 +839,7 @@ void PrepareXAxis(gdImagePtr im, time_t + gdImageLine(im, x, 0, x, YHEIGHT-YOFFSET, red); + gdImageLine(im, x+1, 0, x+1, YHEIGHT-YOFFSET, red); + +- timestruct = localtime((time_t *)&MarkTime); ++ timestruct = localtime(&MarkTime); + strftime(buffer, 100, "%b", timestruct); + gdImageString(im, gdFontSmall, x-6, YHEIGHT-YOFFSET+10, buffer, black); + +@@ -854,7 +854,7 @@ void PrepareXAxis(gdImagePtr im, time_t + // **** Write the tic marks + // ******************************************************************** + +- timestruct = localtime((time_t *)&sample_begin); ++ timestruct = localtime(&sample_begin); + timestruct->tm_sec = 0; + timestruct->tm_min = 0; + timestruct->tm_hour = 0; +@@ -884,7 +884,7 @@ void PrepareXAxis(gdImagePtr im, time_t + x = (MarkTime-sample_begin)*((XWIDTH-XOFFSET)/config.range) + XOFFSET; + } + +- timestruct = localtime((time_t *)&sample_begin); ++ timestruct = localtime(&sample_begin); + timestruct->tm_sec = 0; + timestruct->tm_min = 0; + timestruct->tm_hour = 0;