qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [RFC PATCH] vl.c: add -semihosting-config "arg" sub-arg


From: Leon Alrae
Subject: Re: [Qemu-devel] [RFC PATCH] vl.c: add -semihosting-config "arg" sub-argument
Date: Thu, 2 Apr 2015 08:56:19 +0100
User-agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:24.0) Gecko/20100101 Thunderbird/24.5.0

On 01/04/2015 16:21, Liviu Ionescu wrote:
> 
>> On 01 Apr 2015, at 16:18, Leon Alrae <address@hidden> wrote:
>>
>> ... This simple patch adds "arg" sub-argument which in my opinion is flexible
>> enough to satisfy semi-hosting interfaces which allocate buffers at runtime
>> (so it is possible to pass any number of strings of any length) as well as 
>> the
>> ones which have limited buffer for a single input string.
> 
> I'm not sure I understand this.
> 
> the ARM semihosting interface (see below for the specs) uses a single buffer, 
> usually of 80 bytes for embedded applications, that must be entirely 
> allocated before the call, and in this buffer a single null terminated string 
> is returned, assuming the buffer is large enough, otherwise -1 is returned.
> 
> what the semihosting debugger (qemu in our case) must do, is to get this 
> string from somewhere, preferably from the command line, and pass it to the 
> debugged application.
> 
> 
> to me, the natural implementation is to use a single string.
> 
> can you explain what are the advantages of handling multiple strings that 
> must be later concatenated with spaces separators, to compose the full 
> command line?
> 
> in other words, why is it better to define something like 
> 
>   "gcm --gtest_output=xml:gcm.xml --gtest_filter=FooTest.* --gtest_repeat=10" 
> 
> as 
> 
>   -semihosting-config 
> target=native,arg="gcm",arg="--gtest_output=xml:gcm.xml",arg="--gtest_filter=FooTest.*",arg="--gtest_repeat=10"
> 
> instead of
> 
>   -semihosting-config target=native,cmdline="gcm --gtest_output=xml:gcm.xml 
> --gtest_filter=FooTest.* --gtest_repeat=10"

The ARM semihosting supports SYS_GET_CMDLINE syscall which returns a
single string containing all arguments (whitespace separated I presume).
The UHI semihosting supports Argn syscall which returns single argument,
and Argn is called multiple times to build argv (each argument can
contain whitespaces).

I believe having just one flexible command line option in QEMU
satisfying these two cases would be ideal. But if arg doesn't suit your
needs then as Matthew already mentioned we probably should go for having
cmdline and arg mutually exclusive.

Leon




reply via email to

[Prev in Thread] Current Thread [Next in Thread]