mirror of
https://github.com/cookiengineer/audacity
synced 2025-12-02 14:50:17 +01:00
Reapply 5955dbc752
Author: Leland Lucius <github@homerow.net> Date: Wed Oct 2 10:17:00 2019 -0500 Possible fix for bug #590 This change reduces the risk of LADSPA plugins referencing Audacity symbols by using the RTLD_DEEPBIND flag when loading the plugins. It also addresses an issue specific to the "blop" plugins where they load their own libraries (without RTLD_DEEPBIND). A much better solution would be to change Audacity's default symbol visibility to "hidden" which would expose ONLY symbols specificially marked as visible.
This commit is contained in:
@@ -18,7 +18,7 @@
|
|||||||
#define HASHELEM(p) ((p).symbol_name)
|
#define HASHELEM(p) ((p).symbol_name)
|
||||||
#define HASHVAL 50
|
#define HASHVAL 50
|
||||||
#define HASHENTRIES 50
|
#define HASHENTRIES 50
|
||||||
#define HASHENTER lookup
|
#define HASHENTER hash_lookup
|
||||||
#define HASHNOCOPY
|
#define HASHNOCOPY
|
||||||
|
|
||||||
#include "hashrout.h"
|
#include "hashrout.h"
|
||||||
@@ -26,7 +26,7 @@
|
|||||||
void defvar(char *name, int *addr)
|
void defvar(char *name, int *addr)
|
||||||
|
|
||||||
{
|
{
|
||||||
intptr_t i = lookup(name);
|
intptr_t i = hash_lookup(name);
|
||||||
HASHENTRY(i).symb_type = var_symb_type;
|
HASHENTRY(i).symb_type = var_symb_type;
|
||||||
HASHENTRY(i).ptr.intptr = addr;
|
HASHENTRY(i).ptr.intptr = addr;
|
||||||
}
|
}
|
||||||
@@ -34,7 +34,7 @@ void defvar(char *name, int *addr)
|
|||||||
|
|
||||||
void defun(char *name, seq_cmd_fn addr)
|
void defun(char *name, seq_cmd_fn addr)
|
||||||
{
|
{
|
||||||
intptr_t i = lookup(name);
|
intptr_t i = hash_lookup(name);
|
||||||
HASHENTRY(i).symb_type = fn_symb_type;
|
HASHENTRY(i).symb_type = fn_symb_type;
|
||||||
HASHENTRY(i).ptr.routine = addr;
|
HASHENTRY(i).ptr.routine = addr;
|
||||||
}
|
}
|
||||||
@@ -42,7 +42,7 @@ void defun(char *name, seq_cmd_fn addr)
|
|||||||
|
|
||||||
void defvec(char *name, int *addr, int size)
|
void defvec(char *name, int *addr, int size)
|
||||||
{
|
{
|
||||||
intptr_t i = lookup(name);
|
intptr_t i = hash_lookup(name);
|
||||||
HASHENTRY(i).symb_type = vec_symb_type;
|
HASHENTRY(i).symb_type = vec_symb_type;
|
||||||
HASHENTRY(i).size = size;
|
HASHENTRY(i).size = size;
|
||||||
HASHENTRY(i).ptr.intptr = addr;
|
HASHENTRY(i).ptr.intptr = addr;
|
||||||
|
|||||||
@@ -25,7 +25,7 @@ typedef struct symb_descr {
|
|||||||
} ptr;
|
} ptr;
|
||||||
} symb_descr_node;
|
} symb_descr_node;
|
||||||
|
|
||||||
intptr_t lookup(char *s);
|
intptr_t hash_lookup(char *s);
|
||||||
void defvar(char *name, int *addr);
|
void defvar(char *name, int *addr);
|
||||||
void defvec(char *name, int *addr, int size);
|
void defvec(char *name, int *addr, int size);
|
||||||
/* former defun_type replaced by seq_cmd_fn */
|
/* former defun_type replaced by seq_cmd_fn */
|
||||||
|
|||||||
@@ -464,7 +464,7 @@ private void docall(void)
|
|||||||
if (fieldx == 1) fferror("Routine name expected");
|
if (fieldx == 1) fferror("Routine name expected");
|
||||||
else if (token[fieldx] != '(') fferror("Open paren expected");
|
else if (token[fieldx] != '(') fferror("Open paren expected");
|
||||||
else {
|
else {
|
||||||
desc = &HASHENTRY(lookup(symbol));
|
desc = &HASHENTRY(hash_lookup(symbol));
|
||||||
if (!desc->symb_type) {
|
if (!desc->symb_type) {
|
||||||
fieldx = 0;
|
fieldx = 0;
|
||||||
fferror("Function not defined");
|
fferror("Function not defined");
|
||||||
@@ -1030,7 +1030,7 @@ private void doset(boolean vec_flag)
|
|||||||
linex += scan();
|
linex += scan();
|
||||||
if (!token[0]) fferror("Variable name expected");
|
if (!token[0]) fferror("Variable name expected");
|
||||||
else {
|
else {
|
||||||
struct symb_descr *desc = &HASHENTRY(lookup(token));
|
struct symb_descr *desc = &HASHENTRY(hash_lookup(token));
|
||||||
if (!desc->symb_type) fferror("Called function not defined");
|
if (!desc->symb_type) fferror("Called function not defined");
|
||||||
else if (vec_flag && (desc->symb_type != vec_symb_type)) {
|
else if (vec_flag && (desc->symb_type != vec_symb_type)) {
|
||||||
fferror("This is not an array");
|
fferror("This is not an array");
|
||||||
|
|||||||
Reference in New Issue
Block a user