This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

Build Error with arago linux-davinci.git build

I'm trying to get an environment setup to clone and build all the most important git trees.  One of them (at least I think!) is the linux-davinci.git tree hosted on the arago site.  I built the kernel using CodeSourcery arm-2010q1 compiler and the davinci_all_defconfig.  Is that the one you guys normally test with?

I get the following build error(s):

  LD      .tmp_vmlinux1
drivers/built-in.o: In function `davincifb_release_window':
led-triggers.c:(.text+0xe704): undefined reference to `davinci_disp_release_layer'
drivers/built-in.o: In function `davincifb_remove':
led-triggers.c:(.text+0xe770): undefined reference to `davinci_disp_unregister_callback'
drivers/built-in.o: In function `get_video_mode':
led-triggers.c:(.text+0xe7ec): undefined reference to `davinci_enc_get_mode'
drivers/built-in.o: In function `davincifb_blank':
led-triggers.c:(.text+0xe9b8): undefined reference to `davinci_disp_disable_layer'
drivers/built-in.o: In function `davincifb_ioctl':
led-triggers.c:(.text+0xed54): undefined reference to `davinci_disp_set_zoom'
led-triggers.c:(.text+0xedb0): undefined reference to `davinci_disp_disable_layer'
led-triggers.c:(.text+0xee20): undefined reference to `davinci_disp_set_blending_factor'
led-triggers.c:(.text+0xee38): undefined reference to `davinci_disp_enable_color_key'
led-triggers.c:(.text+0xee40): undefined reference to `davinci_disp_disable_color_key'
led-triggers.c:(.text+0xeebc): undefined reference to `davinci_disp_set_clut_ycbcr'
led-triggers.c:(.text+0xeef0): undefined reference to `davinci_disp_get_blink_attribute'
led-triggers.c:(.text+0xef94): undefined reference to `davinci_disp_set_blink_attribute'
led-triggers.c:(.text+0xefbc): undefined reference to `davinci_disp_get_vid_expansion'
led-triggers.c:(.text+0xefc4): undefined reference to `davinci_disp_get_osd_expansion'
led-triggers.c:(.text+0xf0d0): undefined reference to `davinci_disp_set_vid_expansion'
led-triggers.c:(.text+0xf0d8): undefined reference to `davinci_disp_set_osd_expansion'
led-triggers.c:(.text+0xf0fc): undefined reference to `davinci_disp_get_osd_clut'
led-triggers.c:(.text+0xf110): undefined reference to `davinci_disp_get_rom_clut'
led-triggers.c:(.text+0xf11c): undefined reference to `davinci_disp_get_rec601_attenuation'
led-triggers.c:(.text+0xf154): undefined reference to `davinci_disp_get_palette_map'
led-triggers.c:(.text+0xf170): undefined reference to `davinci_disp_get_palette_map'
led-triggers.c:(.text+0xf180): undefined reference to `davinci_disp_get_palette_map'
led-triggers.c:(.text+0xf190): undefined reference to `davinci_disp_get_palette_map'
led-triggers.c:(.text+0xf1ac): undefined reference to `davinci_disp_get_palette_map'
drivers/built-in.o:led-triggers.c:(.text+0xf1bc): more undefined references to `davinci_disp_get_palette_map' follow
drivers/built-in.o: In function `davincifb_ioctl':
led-triggers.c:(.text+0xf330): undefined reference to `davinci_disp_set_rom_clut'
led-triggers.c:(.text+0xf348): undefined reference to `davinci_disp_set_rom_clut'
led-triggers.c:(.text+0xf364): undefined reference to `davinci_disp_set_osd_clut'
led-triggers.c:(.text+0xf370): undefined reference to `davinci_disp_set_rec601_attenuation'
led-triggers.c:(.text+0xf39c): undefined reference to `davinci_disp_set_palette_map'
led-triggers.c:(.text+0xf3b8): undefined reference to `davinci_disp_set_palette_map'
led-triggers.c:(.text+0xf3c8): undefined reference to `davinci_disp_set_palette_map'
led-triggers.c:(.text+0xf3d8): undefined reference to `davinci_disp_set_palette_map'
led-triggers.c:(.text+0xf3f4): undefined reference to `davinci_disp_set_palette_map'
drivers/built-in.o:led-triggers.c:(.text+0xf404): more undefined references to `davinci_disp_set_palette_map' follow
drivers/built-in.o: In function `davincifb_ioctl':
led-triggers.c:(.text+0xf538): undefined reference to `davinci_disp_set_rom_clut'
led-triggers.c:(.text+0xf550): undefined reference to `davinci_disp_set_rom_clut'
led-triggers.c:(.text+0xf56c): undefined reference to `davinci_disp_set_background'
led-triggers.c:(.text+0xf620): undefined reference to `davinci_disp_cursor_disable'
led-triggers.c:(.text+0xf67c): undefined reference to `davinci_disp_set_cursor_config'
led-triggers.c:(.text+0xf680): undefined reference to `davinci_disp_cursor_enable'
drivers/built-in.o: In function `davincifb_pan_display':
led-triggers.c:(.text+0xf7e8): undefined reference to `davinci_disp_is_second_field'
led-triggers.c:(.text+0xf804): undefined reference to `davinci_disp_start_layer'
drivers/built-in.o: In function `davincifb_setcolreg':
led-triggers.c:(.text+0xf978): undefined reference to `davinci_disp_set_clut_rgb'
drivers/built-in.o: In function `set_video_mode':
led-triggers.c:(.text+0xf9a8): undefined reference to `davinci_enc_get_mode'
led-triggers.c:(.text+0xfb64): undefined reference to `davinci_enc_set_mode'
drivers/built-in.o: In function `davincifb_check_var':
led-triggers.c:(.text+0xfd38): undefined reference to `davinci_disp_try_layer_config'
drivers/built-in.o: In function `davincifb_init_window':
led-triggers.c:(.text+0xffc8): undefined reference to `davinci_disp_request_layer'
led-triggers.c:(.text+0x10104): undefined reference to `davinci_disp_release_layer'
drivers/built-in.o: In function `davincifb_set_par':
led-triggers.c:(.text+0x102a0): undefined reference to `davinci_disp_set_field_inversion'
led-triggers.c:(.text+0x102f4): undefined reference to `davinci_disp_disable_layer'
led-triggers.c:(.text+0x10310): undefined reference to `davinci_disp_release_layer'
led-triggers.c:(.text+0x1032c): undefined reference to `davinci_disp_request_layer'
led-triggers.c:(.text+0x103cc): undefined reference to `davinci_disp_set_layer_config'
led-triggers.c:(.text+0x103dc): undefined reference to `davinci_disp_start_layer'
led-triggers.c:(.text+0x103f4): undefined reference to `davinci_disp_enable_layer'
drivers/built-in.o: In function `davincifb_vsync_callback':
led-triggers.c:(.text+0x10468): undefined reference to `davinci_disp_start_layer'
led-triggers.c:(.text+0x1049c): undefined reference to `davinci_disp_start_layer'
led-triggers.c:(.text+0x104d0): undefined reference to `davinci_disp_start_layer'
led-triggers.c:(.text+0x10504): undefined reference to `davinci_disp_start_layer'
led-triggers.c:(.text+0x10558): undefined reference to `davinci_disp_start_layer'
drivers/built-in.o:led-triggers.c:(.text+0x1058c): more undefined references to `davinci_disp_start_layer' follow
drivers/built-in.o: In function `davincifb_probe':
led-triggers.c:(.text+0x10e08): undefined reference to `davinci_disp_register_callback'

FYI, the arago hosted linux-omap tree built ok.  I've also been able to successfully build the community versions of these same trees.  So I'm not sure if you guys broke something or if I'm using the wrong configuration or if I shouldn't even be looking at this tree!

On a related note I'm trying to create a wiki page to help people with some of these "getting started" issues (which trees to look at, which configs to use, etc.).

http://processors.wiki.ti.com/index.php/Summary_of_Important_Git_Trees

Thanks for any help.

Brad

  • Brad,

     

    No, that is not the correct toolchain, as noted here:

    http://arago-project.org/wiki/index.php/Getting_CodeSourcery_Toolchain

     

     

  • Thanks for pointing that out, Jeff.  I did a distclean and rebuilt with arm-2009q1 but get the exact same error.  I imagine the info I'm looking for (i.e. which configuration to use) is contained in the bitbake scripts.  I'm trying to take things one step at a time so I thought it would be best to try and get comfortable with git before jumping to bitbake.  What do you guys think?  Will I be less trouble if I switch to the full bitbake build for arago?

  • Brad,

    The PSP recipes in Arago use their own copy of the default configuration file.  These are usually copies of the config file from the kernel tree.  There is a defconfig per device and they are different.  Comparing them with the defconfigs in the kernel tree it looks like using the davinci_all_defconfig is not the correct one.  I would imagine you should be using the individual machine defconfigs like davinci_dm644x_defconfig.  Can you try that configuration file and see if that works for you?

  • That's it.  Thanks, Chase!

    I added this info to Summary of Important Git Trees.

  • One other side note... I'm now trying to run the whole enchilada, i.e. the "real" arago.  I started following the directions here, and was prompted to install a whole bunch of packages when I tried running this step:

     MACHINE=omap3evm bitbake arago-console-image

    The only one that was problematic was makeinfo.  When I searched for makeinfo in Ubuntu 10.04 it came up with texi2html which was another one of the required packages.  But installing texi2html did not solve the issue.  After much googling I determined that texinfo is the name of the package that contains makeinfo.  I'm not sure if that issue is specific to Ubuntu 10.04 or not.

    Mainly I wanted this on the web in case other people have this issue.  Hopefully google will help them find it!

  • Brad,

     

    For Arago related support, I'd suggest you use the mailing list dedicated to it:

    http://arago-project.org/wiki/index.php/FAQ#Q:_Is_there_a_mailing_list_or_IRC_channel.3F

  • That's a great suggestion except the email bounced!

  • Brad,

     

    Which email bounced?  Did you subscribe to the list as it instructs and that subscription bounced or did you just try to send something to the list before joining or what?  If you give me some more info, I can try to ping the right people to figure out what is going on.  Thanks.

  • JH said:

    For Arago related support, I'd suggest you use the mailing list dedicated to it:

    http://arago-project.org/wiki/index.php/FAQ#Q:_Is_there_a_mailing_list_or_IRC_channel.3F

    This sounded to me like there was an email support list.  I went to the page you mentioned and saw the following:

    "Alternatively, you can send an email to the arago-devel-request@gforge.ti.com "

    It seemed like exactly the thing!  Now upon much closer reading it seems that is just the email address to subscribe to the mailing list!!!  However, upon closer reading yet it seems that list would not be an appropriate place to email technical questions.  Here's another quote:

    "Please feel free to subscribe to the arago-devel mailing list for all the development, usage, announcements and while the volume is low, any other general discussions"

    So how do I get Arago support?  I've got another question and I'm about ready to post on the forum!

  • Brad,

    As Jeff correctly pointed out, arago-devel@gforge.ti.com is the mailing list for any development and support questions. Like any other mailing list, before sending and receiving emails on the list, you need to subsribe first.

    As the FAQ entry says, you can either go to https://gforge.ti.com/mailman/listinfo/arago-devel and subscribe from the web page, _or_ you can send an email to a _robot_ at arago-devel-request@gforge.ti.com address, which will respond with the instructions on how to subscribe to the list over the email. If it's too complicated for you, please use the web link instead.

    The main address to send your questions to the list is still arago-devel@gforge.ti.com, but if you are not subscribed yet, it will be held for moderation and I would have to approve or reject it first, before it can be sent.

    You can check the list archives at one of the following locations:
    https://gforge.ti.com/gf/project/arago/mailman/?action=ListThreads&mailman_id=39
    https://gforge.ti.com/pipermail/arago-devel/

    For near real-time questions and support, you can try #arago IRC channel on freenode network. You can theoretically post your questions here as well, but I usually don't have bandwidth to monitor yet another forum...

    Denys

  • ]

    Chase Maupin said:

    Brad,

    The PSP recipes in Arago use their own copy of the default configuration file.  These are usually copies of the config file from the kernel tree.  There is a defconfig per device and they are different.  Comparing them with the defconfigs in the kernel tree it looks like using the davinci_all_defconfig is not the correct one.  I would imagine you should be using the individual machine defconfigs like davinci_dm644x_defconfig.  Can you try that configuration file and see if that works for you?

    FYI, look in git's arch/arm/configs subfolder to find the right one.   For the DM6467T EVM I'm betting it's "davinci_dm646x_1ghz_defconfig".  There's also a "davinci_dm646x_defconfig", but it's probably for the DM6467, which differs from the DM6467T.