[PATCH 2/3] Use latest <sys/time.h> from FreeBSD for RTEMS

Sebastian Huber sebastian.huber@embedded-brains.de
Wed Mar 11 12:53:00 GMT 2015



----- Ursprüngliche Mail -----
> Von: "Corinna Vinschen" <vinschen@redhat.com>
> An: newlib@sourceware.org
> Gesendet: Mittwoch, 11. März 2015 13:31:57
> Betreff: Re: [PATCH 2/3] Use latest <sys/time.h> from FreeBSD for RTEMS

> On Mar 11 13:11, Sebastian Huber wrote:
>> ----- Ursprüngliche Mail -----
>> > Von: "Corinna Vinschen" <vinschen@redhat.com>
>> > An: newlib@sourceware.org
>> > Gesendet: Mittwoch, 11. März 2015 11:42:06
>> > Betreff: Re: [PATCH 2/3] Use latest <sys/time.h> from FreeBSD for RTEMS
>> 
>> > On Mar  9 14:03, Sebastian Huber wrote:
>> >> Import the latest <sys/time.h> from FreeBSD for RTEMS.  This has two
>> >> reasons.
>> >> 
>> >> 1. We want to use the FreeBSD timecounters for timekeeping in RTEMS.
>> >> See also https://devel.rtems.org/ticket/2271.
>> >> 
>> >> 2. This makes the port of the network stack from FreeBSD easier.
>> >> 
>> >> newlib/ChangeLog
>> >> 2015-03-09  Sebastian Huber  <sebastian.huber@embedded-brains.de>
>> >> 
>> >>         * libc/sys/rtems/include/sys/_timeval.h: Import from FreeBSD.
>> >>         * libc/sys/rtems/include/sys/time.h: Likewise.
>> >>         * libc/include/sys/time.h: Delete RTEMS specifics.
>> >>         * libc/include/sys/types.h (sbintime_t): Define for RTEMS.
>> >>         (suseconds_t): Likewise.
>> >>         * libc/sys/rtems/include/machine/_types.h (__suseconds_t):
>> >>         Define.
>> >> ---
>> >>  newlib/libc/include/sys/time.h               |   6 +-
>> >>  newlib/libc/include/sys/types.h              |  12 +
>> >>  newlib/libc/sys/rtems/include/sys/_timeval.h |  52 +++
>> >>  newlib/libc/sys/rtems/include/sys/time.h     | 496 +++++++++++++++++++++++++++
>> >>  newlib/libc/sys/rtems/machine/_types.h       |   2 +
>> >>  5 files changed, 565 insertions(+), 3 deletions(-)
>> >>  create mode 100644 newlib/libc/sys/rtems/include/sys/_timeval.h
>> >>  create mode 100644 newlib/libc/sys/rtems/include/sys/time.h
>> >> 
>> >> diff --git a/newlib/libc/include/sys/time.h b/newlib/libc/include/sys/time.h
>> >> index 470a1a6..fc42c6c 100644
>> >> --- a/newlib/libc/include/sys/time.h
>> >> +++ b/newlib/libc/include/sys/time.h
>> >> @@ -20,8 +20,8 @@ struct timeval {
>> >>    suseconds_t tv_usec;
>> >>  };
>> >>  
>> >> -/* BSD time macros used by RTEMS code */
>> >> -#if defined (__rtems__) || defined (__CYGWIN__)
>> >> +/* BSD time macros */
>> >> +#if defined (__CYGWIN__)
>> > 
>> > I don't quite grok this.  You're disabling the BSD timeval macros for
>> > rtems here, just to re-introduce them verbatim in
>> > libc/sys/rtems/include/sys/time.h.  What's the idea to split them off?
>> > That's not overly clean, unless their definition is different, which
>> > it isn't.  Care to explain?
>> 
>> In case I understand the build system correctly, then header files in
>> the libc/sys/rtems/include directory are RTEMS specific and replace
>> the ones in libc/include. My aim is to use a purely RTEMS specific
>> <sys/time.h> which is derived from the latest FreeBSD version.
> 
> Is the FreeBSD version unsuitable for other targets?  What would be
> the problem to replace the public sys/time.h with that FreeBSD version
> instead?

The FreeBSD version contains also some _KERNEL parts.  I need this for RTEMS since I want to use the FreeBSD timecounters for RTEMS internally.  In case they don't hurt, then I can try to merge the Newlib <sys/time.h> and the FreeBSD <sys/time.h> somehow and avoid a RTEMS specific version.



More information about the Newlib mailing list