mirror of
https://github.com/rofl0r/proxychains-ng
synced 2025-01-22 08:32:59 +08:00
25afe98b20
this is in order to get irssi, which forks for DNS lookups, and similar programs, to work as intended. in a previous attempt i learned that shared memory created in a child process is not visible to the parent; in this attempt i spin off a thread from the parent which listens on a pipe and manages the shared memory allocation from the parent address-space. however this doesnt work as expected: memory allocated in the parent after the child forked is not visi- ble to the child as well. so what happens is: irssi starts a child process, the thread allocs memory and hands it to the child, the child attempts to write and segfaults. however irssi doesnt crash. since now the memory is already allocated, doing the dns lookup again will succeed. i.e. the dns lookup works now in irssi by luck. all but the first dns lookups will suceed. however this is not good enough for me to be satisfied, i commit this only for documentation purposes.
39 lines
732 B
C
39 lines
732 B
C
#include "../src/shm.h"
|
|
#include <assert.h>
|
|
|
|
#define s(A) (sizeof(A) - 1)
|
|
#define ss(A) (A), s(A)
|
|
|
|
int main() {
|
|
char buf4096[4096];
|
|
struct stringpool sp;
|
|
stringpool_init(&sp);
|
|
char *r;
|
|
size_t pos = 0;
|
|
r = stringpool_add(&sp, ss("AAAAA"));
|
|
assert(r == sp.start);
|
|
|
|
pos += s("AAAAA");
|
|
assert(sp.alloced == 4096);
|
|
assert(sp.used == pos);
|
|
|
|
r = stringpool_add(&sp, buf4096, sizeof(buf4096));
|
|
assert(r == sp.start + pos);
|
|
|
|
pos += sizeof(buf4096);
|
|
assert(sp.alloced == 4096 * 2);
|
|
assert(sp.used == pos);
|
|
|
|
r = stringpool_add(&sp, buf4096, 4096 - s("AAAAA"));
|
|
assert(r == sp.start + pos);
|
|
pos += 4096 - s("AAAAA");
|
|
assert(pos == 4096 * 2);
|
|
|
|
assert(sp.alloced == 4096 * 2);
|
|
assert(sp.used == pos);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
} |