我正在尝试将新功能“pa_context_set_sink_input_paused”添加到c文件中。这个c文件是pulseaudio的一部分。我能够成功编译pulseaudio。
我添加到c文件的代码(其中定义了许多其他函数,并且这些函数被声明为全局)。
pa_operation* pa_context_set_sink_input_paused(pa_context *c, uint32_t idx, int pause, pa_context_success_cb_t cb, void *userdata)
{
pa_operation *o;
pa_tagstruct *t;
uint32_t tag;
pa_assert(c);
pa_assert(PA_REFCNT_VALUE(c) >= 1);
PA_CHECK_VALIDITY_RETURN_NULL(c, !pa_detect_fork(), PA_ERR_FORKED);
PA_CHECK_VALIDITY_RETURN_NULL(c, c->state == PA_CONTEXT_READY, PA_ERR_BADSTATE);
PA_CHECK_VALIDITY_RETURN_NULL(c, idx != PA_INVALID_INDEX, PA_ERR_INVALID);
//PA_CHECK_VALIDITY_RETURN_NULL(c, pa_cvolume_valid(volume), PA_ERR_INVALID);
PA_CHECK_VALIDITY_RETURN_NULL(c, c->version >= 11, PA_ERR_NOTSUPPORTED);
o = pa_operation_new(c, NULL, (pa_operation_cb_t) cb, userdata);
t = pa_tagstruct_command(c, PA_COMMAND_SET_SINK_INPUT_PAUSE, &tag); // ADD A NEW COMMAND
pa_tagstruct_putu32(t, idx);
pa_tagstruct_puts(t, NULL);
pa_tagstruct_put_boolean(t, pause);
pa_pstream_send_tagstruct(c->pstream, t);
pa_pdispatch_register_reply(c->pdispatch, tag, DEFAULT_TIMEOUT, pa_context_simple_ack_callback, pa_operation_ref(o), (pa_free_cb_t) pa_operation_unref);
return o;
}
在头文件中,该函数声明为
/** Set the pause of a sink input stream specified by its index */
pa_operation* pa_context_set_sink_input_paused(pa_context *c, uint32_t idx, int pause, pa_context_success_cb_t cb, void *userdata); //ADDED BY SATHISH
编译如下:
$ gcc pa_listclients_pause.c -o pa_listclients_pause -L /home/sathish/Desktop/pulseaudio-4.0/build/src/.libs/ -lpulse
/tmp/ccueP47b.o: In function `pa_get_devicelist':
pa_listclients_pause.c.text+0x6cb): undefined reference to `pa_context_set_sink_input_paused'
collect2: error: ld returned 1 exit status
但是当我尝试使用这个新函数运行程序时,它会返回“未定义的引用”。
我尝试运行nm命令并检查libpulse.so中是否存在新功能
该函数返回我它找到了它..
$ nm -A *.so | grep "pa_context_set_sink_input_paused"
libpulse.so:0001d4a0 **t** pa_context_set_sink_input_paused
它被标识为带有字母“t”的本地符号。
我无法理解发生了什么。你能帮我解决这个问题吗?
谢谢, Sathish所在
更新: -
谢谢大家,
Your pointers helped me to narrow down close to a solution.. I edited my Makefile process to expose my new function as a "GLOBAL SYMBOL".
In explanation, there was a file named "map-file" which holding which functions become as global and local. I added my function into the global part of the file.. These seems to have temporarily solved the issue..
I have added the new error I am facing as a seperate question.
http://stackoverflow.com/questions/20702888/relocation-error-while-running-binary
Any pointers on the new issue ??
谢谢, Sathish所在
答案 0 :(得分:1)
这是演示类似问题的示例:
在我的共享库中:
static void test_func_1()
{
}
void test_func_2()
{
}
nm显示:
>nm -C ./libmylib.so | grep test
000000000000062a T test_func_2()
0000000000000624 t test_func_1()
何时将主程序与此库链接:
int main()
{
test_func_1();
test_func_2();
return 0;
}
>g++ -g -m64 main.cpp -o main -L. -lmylib
/tmp/cciphwuO.o: In function `main':
/main.cpp:32: undefined reference to `test_func_1()'
collect2: ld returned 1 exit status
或者:
void test_func_1()
{
}
void __attribute__ ((visibility ("default"))) test_func_2()
{
}
并使用-fvisibility构建:
g++ -fvisibility=hidden -m64 -shared -g -fpic mylib.cpp -o libmylib.so
给出同样的问题:
>nm -C ./libmylib.so | grep test
00000000000005c4 t test_func_1()
00000000000005ca T test_func_2()