[sr-dev] git:5.1:8cb302f3: app_perl: first destroy old interpreter before creating the new one

Daniel-Constantin Mierla miconda at gmail.com
Wed Oct 9 08:57:21 CEST 2019


Module: kamailio
Branch: 5.1
Commit: 8cb302f39941b121875dd402ead726de6ec5a624
URL: https://github.com/kamailio/kamailio/commit/8cb302f39941b121875dd402ead726de6ec5a624

Author: Daniel-Constantin Mierla <miconda at gmail.com>
Committer: Daniel-Constantin Mierla <miconda at gmail.com>
Date: 2019-10-09T08:55:28+02:00

app_perl: first destroy old interpreter before creating the new one

- on interpreter reset, the new one may inherit globals from the old
one, if that is not yet destroyed

(cherry picked from commit 58047ba61d0cbceebc8c85590970a573fc396aa5)
(cherry picked from commit 8c70c16d10ed46f4ba8cf002a5b1599a02b5cb93)

---

Modified: src/modules/app_perl/app_perl_mod.c

---

Diff:  https://github.com/kamailio/kamailio/commit/8cb302f39941b121875dd402ead726de6ec5a624.diff
Patch: https://github.com/kamailio/kamailio/commit/8cb302f39941b121875dd402ead726de6ec5a624.patch

---

diff --git a/src/modules/app_perl/app_perl_mod.c b/src/modules/app_perl/app_perl_mod.c
index 74f08acff2..7a10a506c8 100644
--- a/src/modules/app_perl/app_perl_mod.c
+++ b/src/modules/app_perl/app_perl_mod.c
@@ -264,6 +264,8 @@ PerlInterpreter *parser_init(void) {
  *
  */
 int unload_perl(PerlInterpreter *p) {
+	/* clean and reset everything */
+	PL_perl_destruct_level = 1;
 	perl_destruct(p);
 	perl_free(p);
 
@@ -278,26 +280,26 @@ int unload_perl(PerlInterpreter *p) {
  */
 int perl_reload(void)
 {
-
-	PerlInterpreter *new_perl;
-
-	new_perl = parser_init();
-
-	if (new_perl) {
+	if(my_perl) {
 		unload_perl(my_perl);
-		my_perl = new_perl;
+	}
+	my_perl = parser_init();
+
 #ifdef PERL_EXIT_DESTRUCT_END
-		PL_exit_flags |= PERL_EXIT_DESTRUCT_END;
+	PL_exit_flags |= PERL_EXIT_DESTRUCT_END;
 #else
 #warning Perl 5.8.x should be used. Please upgrade.
 #warning This binary will be unsupported.
-		PL_exit_flags |= PERL_EXIT_EXPECTED;
+	PL_exit_flags |= PERL_EXIT_EXPECTED;
 #endif
+
+	if(my_perl) {
+		LM_DBG("new perl interpreter initialized\n");
 		return 0;
 	} else {
-		return -1;
+		LM_CRIT("failed to initialize a new perl interpreter - exiting\n");
+		exit(-1);
 	}
-
 }
 
 




More information about the sr-dev mailing list