From mboxrd@z Thu Jan 1 00:00:00 1970 From: Bernhard Bitsch To: development@lists.ipfire.org Subject: Aw: [PATCH 1/5] location-functions.pl: Use a single script-wide db_handle. Date: Sun, 08 Nov 2020 20:36:40 +0100 Message-ID: In-Reply-To: <20201107184724.3590-1-stefan.schantl@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============5338953722055425822==" List-Id: --===============5338953722055425822== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable This means, we stay with the unbalanced memory allocation in (Perl) libloc. W= hich leaves a memory leak. > Gesendet: Samstag, 07. November 2020 um 19:47 Uhr > Von: "Stefan Schantl" > An: development(a)lists.ipfire.org > Betreff: [PATCH 1/5] location-functions.pl: Use a single script-wide db_han= dle. > > Create and use a single script-wide database handle for libloc to > prevent from creating multiple ones. > > This helps saving memory, especially on small systems. > > Reference #12515. > The error can be produced easily with small memory, but it is present in all = systems. Therefore I've posted this solution as work-around only! - Bernhard > Signed-off-by: Stefan Schantl > --- > config/cfgroot/location-functions.pl | 11 ++++------- > 1 file changed, 4 insertions(+), 7 deletions(-) > > diff --git a/config/cfgroot/location-functions.pl b/config/cfgroot/location= -functions.pl > index 2cfe7f908..9b1d0bfb5 100644 > --- a/config/cfgroot/location-functions.pl > +++ b/config/cfgroot/location-functions.pl > @@ -55,6 +55,9 @@ our $keyfile =3D "$location_dir/signing-key.pem"; > # Directory which contains the exported databases. > our $xt_geoip_db_directory =3D "/usr/share/xt_geoip/"; > > +# Create libloc database handle. > +my $db_handle =3D &init(); > + > # > ## Tiny function to init the location database. > # > @@ -86,7 +89,7 @@ sub verify ($) { > ## Function to the the country code of a given address. > # > sub lookup_country_code($$) { > - my ($db_handle, $address) =3D @_; > + my ($address) =3D @_; > > # Lookup the given address. > my $country_code =3D &Location::lookup_country_code($db_handle, $address); > @@ -174,9 +177,6 @@ sub get_full_country_name($) { > > # Function to get all available locations. > sub get_locations() { > - # Create libloc database handle. > - my $db_handle =3D &init(); > - > # Get locations which are stored in the location database. > my @database_locations =3D &Location::database_countries($db_handle); > > @@ -197,9 +197,6 @@ sub address_has_flags($) { > # Array to store the flags of the address. > my @flags; > > - # Init libloc database handle. > - my $db_handle =3D &init(); > - > # Loop through the hash of possible network flags. > foreach my $flag (keys(%network_flags)) { > # Check if the address has the current flag. > -- > 2.20.1 > > --===============5338953722055425822==--