See also https://github.com/JuliaLang/julia/issues/17451, 
-Wl,--export-dynamic might help (thanks to Yichao Yu for that one).


On Sunday, July 10, 2016 at 11:38:11 PM UTC-7, Sourabh Chadha wrote:
>
> Thanks for the reply. After changing the compiler flags etc. the symbols 
> now seem to be exported but i get the same error. Here is the nm output
>
> nm ../usr/bin/embedding | grep my
> 0000000000601da0 t __frame_dummy_init_array_entry
> 0000000000400f10 t frame_dummy
> 0000000000400f40 T my_c_sqrt
>
>
> On Saturday, 9 July 2016 17:38:23 UTC+5:30, Isaiah wrote:
>>
>> The symbol exists but is not exported (t vs T). Try adding DLLEXPORT in 
>> front of the function declaration. On 0.4 it appears to have had a 
>> Windows-only export declaration.
>>
>> On Saturday, July 9, 2016, Sourabh Chadha <sourabh...@gmail.com> wrote:
>>
>>> I am new to Julia and have been trying to use ccall to call C functions 
>>> in embedded mode but i am unable to even successfully run the example 
>>> embedding.c that is in package. The example file define a 
>>> function my_c_sqrt and then tries to call it using jl_eval_string("println( 
>>> ccall( :my_c_sqrt, Float64, (Float64,), 2.0 ) )");. This doesnt work and if 
>>> i trace the issue by printing errors i get ErrorException("ccall: could not 
>>> find function my_c_sqrt").
>>>
>>> I have tried checking eveything. nm on the executble gives this.
>>> nm ../usr/bin/embedding | grep my
>>> 0000000000601d80 t __frame_dummy_init_array_entry
>>> 0000000000400f60 t frame_dummy
>>> 0000000000400f90 t my_c_sqrt
>>>
>>> so the symbol is available.
>>>
>>> I am running Red Hat Enterprise Linux Workstation release 7.0 (Maipo) nd 
>>> hve compiled julia Version 0.4.6 from scratch.
>>>
>>> any help would be really appreciated
>>>
>>>

Reply via email to