[kaffe] CVS kaffe (guilhem): A few fixes for the semaphore replacement.
Michael Franz
mvfranz at gmail.com
Tue Jan 11 19:47:15 PST 2005
Guilhem,
This is a little late, but this broke the darwin JIT3 build. It is
missing some symbols during linking:
_repsem_destroy
_repsem_init
_repsem_post
_repsem_wait
Your later patch (11/28/04) does not fix it the problem. Well, at
least darwin's JIT3 still does not compile.
Is there any help/insight you can give to me to try to resolve this?
Thanks
Michael
On Mon, 22 Nov 2004 10:19:17 -0800, Kaffe CVS <cvs-commits at kaffe.org> wrote:
> PatchSet 5469
> Date: 2004/11/22 18:15:11
> Author: guilhem
> Branch: HEAD
> Tag: (none)
> Log:
> A few fixes for the semaphore replacement.
>
> * kaffe/kaffevm/systems/unix-pthreads/thread-internal.h:
> Replaced sem_t by repsem_t where needed.
>
> * replace/semaphores.c: Use repsem_t instead of sem_t and
> define REPSEM_VALUE_MAX.
>
> Members:
> ChangeLog:1.3015->1.3016
> kaffe/kaffevm/systems/unix-pthreads/thread-internal.h:1.24->1.25
> replace/semaphores.c:1.1->1.2
>
> Index: kaffe/ChangeLog
> diff -u kaffe/ChangeLog:1.3015 kaffe/ChangeLog:1.3016
> --- kaffe/ChangeLog:1.3015 Mon Nov 22 17:23:26 2004
> +++ kaffe/ChangeLog Mon Nov 22 18:15:11 2004
> @@ -1,5 +1,13 @@
> 2004-11-22 Guilhem Lavaux <guilhem at kaffe.org>
>
> + * kaffe/kaffevm/systems/unix-pthreads/thread-internal.h:
> + Replaced sem_t by repsem_t where needed.
> +
> + * replace/semaphores.c: Use repsem_t instead of sem_t and
> + define REPSEM_VALUE_MAX.
> +
> +2004-11-22 Guilhem Lavaux <guilhem at kaffe.org>
> +
> * configure.ac:
> Call KAFFE_CHECK_SEMAPHORES.
>
> Index: kaffe/kaffe/kaffevm/systems/unix-pthreads/thread-internal.h
> diff -u kaffe/kaffe/kaffevm/systems/unix-pthreads/thread-internal.h:1.24 kaffe/kaffe/kaffevm/systems/unix-pthreads/thread-internal.h:1.25
> --- kaffe/kaffe/kaffevm/systems/unix-pthreads/thread-internal.h:1.24 Mon Nov 22 17:23:49 2004
> +++ kaffe/kaffe/kaffevm/systems/unix-pthreads/thread-internal.h Mon Nov 22 18:15:15 2004
> @@ -68,7 +68,7 @@
> int interrupting;
>
> /* convars and mutexes aren't useful in signal handlers, semaphores are */
> - sem_t sem;
> + repsem_t sem;
>
> /* the following fields hold our extensions */
> int active; /* are we in our user thread function 'func'? */
> Index: kaffe/replace/semaphores.c
> diff -u kaffe/replace/semaphores.c:1.1 kaffe/replace/semaphores.c:1.2
> --- kaffe/replace/semaphores.c:1.1 Mon Nov 22 17:24:15 2004
> +++ kaffe/replace/semaphores.c Mon Nov 22 18:15:15 2004
> @@ -39,11 +39,13 @@
>
> #include "repsemaphore.h"
>
> -int repsem_init(sem_t *sem, int pshared, int value)
> +#define REPSEM_VALUE_MAX 32767
> +
> +int repsem_init(repsem_t *sem, int pshared, int value)
> {
> int ret;
>
> - if (value > SEM_VALUE_MAX)
> + if (value > REPSEM_VALUE_MAX)
> {
> errno = EINVAL;
> return -1;
> @@ -68,12 +70,12 @@
> return 0;
> }
>
> -int repsem_post(sem_t *sem)
> +int repsem_post(repsem_t *sem)
> {
> if (pthread_mutex_lock(&sem->mutex) < 0)
> return -1;
>
> - if (sem->value == SEM_VALUE_MAX)
> + if (sem->value == REPSEM_VALUE_MAX)
> {
> errno = ERANGE;
> return -1;
> @@ -92,7 +94,7 @@
> return 0;
> }
>
> -int repsem_wait(sem_t *sem)
> +int repsem_wait(repsem_t *sem)
> {
> if (pthread_mutex_lock(&sem->mutex) < 0)
> return -1;
> @@ -109,7 +111,7 @@
> return 0;
> }
>
> -int repsem_trywait(sem_t *sem)
> +int repsem_trywait(repsem_t *sem)
> {
> if (pthread_mutex_lock(&sem->mutex) < 0)
> return -1;
> @@ -130,13 +132,13 @@
> return 0;
> }
>
> -int repsem_getvalue(sem_t *sem, int *sval)
> +int repsem_getvalue(repsem_t *sem, int *sval)
> {
> *sval = sem->value;
> return 0;
> }
>
> -int repsem_destroy(sem_t *sem)
> +int repsem_destroy(repsem_t *sem)
> {
> int ret;
>
> _______________________________________________
> kaffe mailing list
> kaffe at kaffe.org
> http://kaffe.org/cgi-bin/mailman/listinfo/kaffe
>
More information about the kaffe
mailing list