未定义的引用 - 本地符号

时间:2013-12-20 04:10:57

标签: c linux gcc pulseaudio

我正在尝试将新功能“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所在

1 个答案:

答案 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()