From: Jan Kiszka <jan.kiszka@domain.hid>
To: xenomai-core <xenomai@xenomai.org>
Subject: [Xenomai-core] [PATCH] speed up building of posix apps
Date: Fri, 18 Aug 2006 14:05:14 +0200 [thread overview]
Message-ID: <44E5ACFA.50905@domain.hid> (raw)
[-- Attachment #1.1: Type: text/plain, Size: 593 bytes --]
Hi,
with the growing number of wrapped posix applications also their fairly
slow build process became visible. It somehow scaled badly.
I had the idea to pass all wrapping commands to the linker via a file
for quite some time. Now I tried it and it gives a nice speedup of
roughly 400% for me when building typical single-file apps (mileage may
vary, I'm building on vmware box...). Moreover, it beautifies the
compiler output.
Tested on various setups, no regressions known so far.
Jan
PS: What about the silence-libtool patch? I've heard neither ack nor
nack so far.
[-- Attachment #1.2: wrapping-speedup.patch --]
[-- Type: text/plain, Size: 6412 bytes --]
Index: configure.in
===================================================================
--- configure.in (revision 1453)
+++ configure.in (working copy)
@@ -525,8 +525,7 @@ XENO_USER_APP_CFLAGS=$XENO_USER_CFLAGS
XENO_USER_CFLAGS="$XENO_USER_CFLAGS -D__IN_XENO__ -Wstrict-prototypes"
XENO_USER_APP_LDFLAGS=$XENO_USER_LDFLAGS
-XENO_POSIX_WRAPPERS=`while read symbol; do echo -n "-Wl,--wrap,$symbol "; done \
- < $srcdir/src/skins/posix/posix.wrappers`
+XENO_POSIX_WRAPPERS="-Wl,@`cd $srcdir && pwd`/src/skins/posix/posix.wrappers"
AC_MSG_CHECKING(whether POSIX skin library automatically calls mlockall)
AC_ARG_ENABLE(posix-auto-mlockall,
Index: src/skins/posix/posix.wrappers
===================================================================
--- src/skins/posix/posix.wrappers (revision 1453)
+++ src/skins/posix/posix.wrappers (working copy)
@@ -1,89 +1,89 @@
-pthread_create
-pthread_detach
-pthread_setschedparam
-pthread_getschedparam
-pthread_yield
-sched_yield
-sem_init
-sem_destroy
-sem_post
-sem_timedwait
-sem_wait
-sem_trywait
-sem_getvalue
-sem_open
-sem_close
-sem_unlink
-clock_getres
-clock_gettime
-clock_settime
-clock_nanosleep
-nanosleep
-pthread_mutexattr_init
-pthread_mutexattr_destroy
-pthread_mutexattr_gettype
-pthread_mutexattr_settype
-pthread_mutexattr_getprotocol
-pthread_mutexattr_setprotocol
-pthread_mutexattr_getpshared
-pthread_mutexattr_setpshared
-pthread_mutex_init
-pthread_mutex_destroy
-pthread_mutex_lock
-pthread_mutex_trylock
-pthread_mutex_timedlock
-pthread_mutex_unlock
-pthread_condattr_init
-pthread_condattr_destroy
-pthread_condattr_getclock
-pthread_condattr_setclock
-pthread_condattr_getpshared
-pthread_condattr_setpshared
-pthread_cond_init
-pthread_cond_destroy
-pthread_cond_wait
-pthread_cond_timedwait
-pthread_cond_signal
-pthread_cond_broadcast
-mq_open
-mq_close
-mq_unlink
-mq_getattr
-mq_setattr
-mq_send
-mq_timedsend
-mq_receive
-mq_timedreceive
-mq_notify
-open
-socket
-close
-ioctl
-read
-write
-recvmsg
-sendmsg
-recvfrom
-sendto
-recv
-send
-getsockopt
-setsockopt
-bind
-connect
-listen
-accept
-getsockname
-getpeername
-shutdown
-timer_create
-timer_delete
-timer_settime
-timer_getoverrun
-timer_gettime
-ftruncate
-close
-shm_open
-shm_unlink
-mmap
-munmap
+--wrap pthread_create
+--wrap pthread_detach
+--wrap pthread_setschedparam
+--wrap pthread_getschedparam
+--wrap pthread_yield
+--wrap sched_yield
+--wrap sem_init
+--wrap sem_destroy
+--wrap sem_post
+--wrap sem_timedwait
+--wrap sem_wait
+--wrap sem_trywait
+--wrap sem_getvalue
+--wrap sem_open
+--wrap sem_close
+--wrap sem_unlink
+--wrap clock_getres
+--wrap clock_gettime
+--wrap clock_settime
+--wrap clock_nanosleep
+--wrap nanosleep
+--wrap pthread_mutexattr_init
+--wrap pthread_mutexattr_destroy
+--wrap pthread_mutexattr_gettype
+--wrap pthread_mutexattr_settype
+--wrap pthread_mutexattr_getprotocol
+--wrap pthread_mutexattr_setprotocol
+--wrap pthread_mutexattr_getpshared
+--wrap pthread_mutexattr_setpshared
+--wrap pthread_mutex_init
+--wrap pthread_mutex_destroy
+--wrap pthread_mutex_lock
+--wrap pthread_mutex_trylock
+--wrap pthread_mutex_timedlock
+--wrap pthread_mutex_unlock
+--wrap pthread_condattr_init
+--wrap pthread_condattr_destroy
+--wrap pthread_condattr_getclock
+--wrap pthread_condattr_setclock
+--wrap pthread_condattr_getpshared
+--wrap pthread_condattr_setpshared
+--wrap pthread_cond_init
+--wrap pthread_cond_destroy
+--wrap pthread_cond_wait
+--wrap pthread_cond_timedwait
+--wrap pthread_cond_signal
+--wrap pthread_cond_broadcast
+--wrap mq_open
+--wrap mq_close
+--wrap mq_unlink
+--wrap mq_getattr
+--wrap mq_setattr
+--wrap mq_send
+--wrap mq_timedsend
+--wrap mq_receive
+--wrap mq_timedreceive
+--wrap mq_notify
+--wrap open
+--wrap socket
+--wrap close
+--wrap ioctl
+--wrap read
+--wrap write
+--wrap recvmsg
+--wrap sendmsg
+--wrap recvfrom
+--wrap sendto
+--wrap recv
+--wrap send
+--wrap getsockopt
+--wrap setsockopt
+--wrap bind
+--wrap connect
+--wrap listen
+--wrap accept
+--wrap getsockname
+--wrap getpeername
+--wrap shutdown
+--wrap timer_create
+--wrap timer_delete
+--wrap timer_settime
+--wrap timer_getoverrun
+--wrap timer_gettime
+--wrap ftruncate
+--wrap close
+--wrap shm_open
+--wrap shm_unlink
+--wrap mmap
+--wrap munmap
Index: scripts/xeno-config.in
===================================================================
--- scripts/xeno-config.in (revision 1453)
+++ scripts/xeno-config.in (working copy)
@@ -89,14 +89,10 @@ while test $# -gt 0; do
;;
--posix-ldflags)
if test \! -r $XENO_POSIX_WRAPPERS; then
- echo "POSIX support is not available" >&2
- exit 1
- fi
- wrappers=`cat $XENO_POSIX_WRAPPERS | \
- while read symbol; do \
- echo -n "-Wl,--wrap,$symbol " ; \
- done`
- echo "$wrappers $XENO_POSIX_LDFLAGS"
+ echo "POSIX support is not available" >&2
+ exit 1
+ fi
+ echo "-Wl,@$XENO_POSIX_WRAPPERS $XENO_POSIX_LDFLAGS"
;;
--lib*-dir|--libdir|--user-libdir)
echo $XENO_LIBRARY_DIR
Index: ChangeLog
===================================================================
--- ChangeLog (revision 1453)
+++ ChangeLog (working copy)
@@ -1,7 +1,14 @@
+2006-08-18 Jan Kiszka <jan.kiszka@domain.hid>
+
+ * src/skins/posix/posix.wrappers, configure.in,
+ scripts/xeno-config.in: Read wrapping options from file instead of
+ passing them via command line.
+
2006-08-16 Sebastian Smolorz <Sebastian.Smolorz@domain.hid>
* include/rtdm/rtcan.h, ksrc/drivers/can/rtcan_{module,socket,raw}.c:
- Get rid of RTCAN_TIMEOUT_* defines and replace them with RTDM_TIMEOUT_*
+ Get rid of RTCAN_TIMEOUT_* defines and replace them with
+ RTDM_TIMEOUT_*.
2006-08-16 Jan Kiszka <jan.kiszka@domain.hid>
@@ -36,8 +43,8 @@
2006-08-12 Ulrich Schwab <schwab@domain.hid>
- * ksrc/arch/i386/smi.c added id of Intel ICH7 to list of SMI chipsets
-
+ * ksrc/arch/i386/smi.c added id of Intel ICH7 to list of SMI chipsets
+
2006-08-12 Gilles Chanteperdrix <gilles.chanteperdrix@xenomai.org>
* ksrc/skins/posix/thread.c (thread_destroy): Do not assume that
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 250 bytes --]
next reply other threads:[~2006-08-18 12:05 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-08-18 12:05 Jan Kiszka [this message]
2006-08-18 12:38 ` [Xenomai-core] [PATCH] speed up building of posix apps Philippe Gerum
2006-08-18 12:57 ` Jan Kiszka
2006-08-18 13:48 ` Gilles Chanteperdrix
2006-08-18 13:58 ` Jan Kiszka
2006-08-18 16:40 ` Jan Kiszka
2006-08-18 17:28 ` Gilles Chanteperdrix
2006-08-18 17:39 ` Jan Kiszka
2006-08-18 21:11 ` Gilles Chanteperdrix
2006-08-19 10:24 ` Jan Kiszka
2006-08-19 11:09 ` Gilles Chanteperdrix
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=44E5ACFA.50905@domain.hid \
--to=jan.kiszka@domain.hid \
--cc=xenomai@xenomai.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.