[OE-core] [PATCH 1/1] runqemu: show bitbake errors to user
Scott Garman
scott.a.garman at intel.com
Wed Sep 19 05:35:04 UTC 2012
On 09/14/2012 04:20 PM, Mark Hatle wrote:
> On 9/14/12 6:15 PM, Scott Garman wrote:
>> In certain edge cases, bitbake may fail to run and cause setup_tmpdir()
>> within runqemu to fail, and not give the user a helpful error message.
>> Catch this case and show the user the output of bitbake -e.
>>
>> This fixes [YOCTO #3112]
>>
>> Signed-off-by: Scott Garman <scott.a.garman at intel.com>
>> ---
>> scripts/runqemu | 12 ++++++++++--
>> 1 file changed, 10 insertions(+), 2 deletions(-)
>>
>> diff --git a/scripts/runqemu b/scripts/runqemu
>> index e843946..8bb77ff 100755
>> --- a/scripts/runqemu
>> +++ b/scripts/runqemu
>> @@ -283,8 +283,16 @@ setup_tmpdir() {
>> # We have bitbake in PATH, get OE_TMPDIR from bitbake
>> OE_TMPDIR=`MACHINE=$MACHINE bitbake -e | grep ^TMPDIR=\" |
>> cut -d '=' -f2 | cut -d '"' -f2`
>> if [ -z "$OE_TMPDIR" ]; then
>> - echo "Error: this script needs to be run from your build
>> directory,"
>> - echo "or you need to explicitly set OE_TMPDIR in your
>> environment"
>> + # Check for errors from bitbake that the user needs to
>> know about
>> + BITBAKE_OUTPUT=`bitbake -e`
>
> I'm not sure that is a good idea. If there is a failure (anything on
> stderr) it will just be dumped to the screen...
I'm afraid this is not the case with the error case I was testing this
against. That case being when there is an LCONF_VERSION mismatch in
bblayers.conf. Those user instructions are written to STDOUT.
> If it does succeed, it could attempt to load that variable with many MB
> of data, which also likely isn't what is desired.
This is a valid point. I could change it to bitbake -e | wc -l, and
check the number of lines of output. I'm basically just checking to see
that this is greater than 0.
> It might be better to dump the items to a tmp file (securely created of
> course) ;) and then keep processing the same file for error messages,
> warnings, etc...
This code path should only be run on very unusual edge cases, so I'm not
inclined to add additional tmpfile handling complexity and have to deal
with cleaning up the files, etc.
I will re-spin this patch with the wc -l modification.
Scott
--
Scott Garman
Embedded Linux Engineer - Yocto Project
Intel Open Source Technology Center
More information about the Openembedded-core
mailing list