On Tue, Aug 17, 2010 at 5:13 PM, David Marlin <[email protected]> wrote:
>
> Mike Frysinger wrote:
>> On Tue, Aug 17, 2010 at 5:42 PM, David Marlin wrote:
>>> Mike Frysinger wrote:
>>>> On Tue, Aug 17, 2010 at 2:34 PM, David Marlin wrote:
>>>>> 'lchown02.c' does not build properly due to calls to mmap and
>>>>> get_high_address (which references sbrk) when UCLINUX=1 is defined.
>>>> you'll need to clarify. it builds fine for me, it just may not run
>>>> correctly due to the assumptions of memory placement.
>>> Thank you for the feedback. I'm new to uClinux, so I'm only going on what
>>> I've read, but my understanding is that 'sbrk' is not supported in uClinux.
>>
>> it depends on how you use it. sbrk(0) should always work since you're
>> only querying the current size. sbrk(1+) might work depending on the
>> current memory layout, but it isnt reliable, so it's recommended
>> people dont use it when possible on nommu. technically speaking, it
>> can even fail under mmu systems, it's just highly unlikely with newly
>> started processes.
>>
>> the lib/get_high_address.c usage is valid since it does sbrk(0), but
>> overall the function is useless since it is assuming that a few pages
>> after the end of the sbrk() region is unallocated memory. on nommu
>> systems, it could easily be valid (either the same process or a
>> different one or the kernel).
>>
>> so on nommu/linux, this function should be avoided due to its design
>> flaws, not because any of the unctions it calls do not work.
>
> Thank you for the excellent explanation.
>
> :
>
>>> Most of the testcases skip the call to get_high_address when UCLINUX=1, so I
>>> was just following their example.
>>
>> i like to look forward and start down a better path rather than
>> continue to hedge overgrown crap ;)
>
> Understood.
>
> When creating patches I typically look to the existing sources for
> examples. This is because I assume that 1) the current code has already
> been reviewed and accepted, 2) the people who wrote it know more about
> what they were trying to accomplish and how they wanted it to work than
> I do, and 3) consistency in the code and coding style tend to make
> maintenance easier.
>
> I understand that over time code may become a bit dated and require some
> redesign/updates, but being new to these bits of code I defer to the
> experts for that.
>
> There appear to be three primary ways tests are being handled in LTP for
> uClinux now:
> 1) "filter" the test directory (FILTER_OUT_DIRS in the Makefile)
> e.g., testcases/kernel/syscalls/Makefile
> 2) skip the entire 'main' test, and display "not available in uCLinux"
> e.g., testcases/kernel/syscalls/mremap/mremap03.c
> 3) skip only parts of the test
> e.g., testcases/kernel/syscalls/stat/stat06.c
>
> There may be other ways that I have not noticed (yet).
>
> I think the question is, do we want to continue using these approaches,
> or try to standardize on one or two (possibly new) approaches, with some
> guidelines on when to use each?
>
> I am willing to help with any modifications, but I don't have enough
> experience with uClinux (or LTP development) to determine the best
> approach(es) or rules for use. Once guidelines are established I can
> help update the code (submit patches). As a 'user' of LTP, my goal is
> just to be able to set UCLINUX=1, build, install, and run the tests on a
> system running uClinux. :-)
FILTER_OUT_DIRS is the most recent addition that I made, but the
only caveat is that the runltp scripts are dumb and can't distinguish
between "not built" and "failed" easily (you have to manually go in
and inspect the results, which is annoying), so this can add a lot of
noise to the output in a test run, depending on what you run. I was
going to fix this, but then I switched over to more FreeBSD work than
Linux work, and it kind of got shelved. If it's worth picking up and
completing, I'll do it, but I need to finish off writing a few more
conformance tests and fix a set of build-related items with
open_posix_testsuite before I pick that up.
Thanks,
-Garrett
------------------------------------------------------------------------------
This SF.net email is sponsored by
Make an app they can't live without
Enter the BlackBerry Developer Challenge
http://p.sf.net/sfu/RIM-dev2dev
_______________________________________________
Ltp-list mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/ltp-list