List Info

Thread: pointer indirection on the LHS of an assignment




pointer indirection on the LHS of an assignment
user name
2006-10-07 13:12:07
  sort of a combination of a C and gcc question but what's
the rules
these days on the following (ripped from the linux kernel
source, from
asm/semaphore.h)?

===
static inline void sema_init (struct semaphore *sem, int
val)
{
/*
 *      *sem = (struct
semaphore)__SEMAPHORE_INITIALIZER((*sem),val);
 *
 * i'd rather use the more flexible initialization above,
but sadly
 * GCC 2.7.2.3 emits a bogus warning. EGCS doesn't. Oh well.
 */
        atomic_set(&sem->count, val);
        sem->sleepers = 0;
        init_waitqueue_head(&sem->wait);
}
===

  i recall that earlier compilers complained about that
first example
of pointer indirection as the target of an assignment.  is
that legal
these days?

rday
-
To unsubscribe from this list: send the line
"unsubscribe linux-c-programming" in
the body of a message to majordomovger.kernel.org
More majordomo info at  http://vge
r.kernel.org/majordomo-info.html
pointer indirection on the LHS of an assignment
user name
2006-10-07 22:53:14
Robert P. J. Day wrote:

>   sort of a combination of a C and gcc question but
what's the rules
> these days on the following (ripped from the linux
kernel source, from
> asm/semaphore.h)?
> 
> ===
> static inline void sema_init (struct semaphore *sem,
int val)
> {
> /*
>  *      *sem = (struct
semaphore)__SEMAPHORE_INITIALIZER((*sem),val);
>  *
>  * i'd rather use the more flexible initialization
above, but sadly
>  * GCC 2.7.2.3 emits a bogus warning. EGCS doesn't. Oh
well.
>  */
>         atomic_set(&sem->count, val);
>         sem->sleepers = 0;
>         init_waitqueue_head(&sem->wait);
> }
> ===
> 
>   i recall that earlier compilers complained about that
first example
> of pointer indirection as the target of an assignment. 
is that legal
> these days?

The problem with the first example is that the
__SEMAPHORE_INITIALIZER
macro uses C99 features, which probably aren't supported in
gcc 2.7.x.

The LHS has nothing to do with it.

-- 
Glynn Clements <glynngclements.plus.com>
-
To unsubscribe from this list: send the line
"unsubscribe linux-c-programming" in
the body of a message to majordomovger.kernel.org
More majordomo info at  http://vge
r.kernel.org/majordomo-info.html
pointer indirection on the LHS of an assignment
user name
2006-10-08 06:53:46
On Sat, 7 Oct 2006, Glynn Clements wrote:

>
> Robert P. J. Day wrote:
>
> >   sort of a combination of a C and gcc question
but what's the rules
> > these days on the following (ripped from the linux
kernel source, from
> > asm/semaphore.h)?
> >
> > ===
> > static inline void sema_init (struct semaphore
*sem, int val)
> > {
> > /*
> >  *      *sem = (struct
semaphore)__SEMAPHORE_INITIALIZER((*sem),val);
> >  *
> >  * i'd rather use the more flexible initialization
above, but sadly
> >  * GCC 2.7.2.3 emits a bogus warning. EGCS
doesn't. Oh well.
> >  */
> >         atomic_set(&sem->count, val);
> >         sem->sleepers = 0;
> >         init_waitqueue_head(&sem->wait);
> > }
> > ===
> >
> >   i recall that earlier compilers complained about
that first example
> > of pointer indirection as the target of an
assignment.  is that legal
> > these days?
>
> The problem with the first example is that the
> __SEMAPHORE_INITIALIZER macro uses C99 features, which
probably
> aren't supported in gcc 2.7.x.
>
> The LHS has nothing to do with it.

ah, sorry, i didn't look closely enough.  so if one could
count on a
C99-compilant compiler being available, then the first form
would be
perfectly acceptable?  thanks.

rday
-
To unsubscribe from this list: send the line
"unsubscribe linux-c-programming" in
the body of a message to majordomovger.kernel.org
More majordomo info at  http://vge
r.kernel.org/majordomo-info.html
pointer indirection on the LHS of an assignment
user name
2006-10-08 12:17:39
Robert P. J. Day wrote:

> > The problem with the first example is that the
> > __SEMAPHORE_INITIALIZER macro uses C99 features,
which probably
> > aren't supported in gcc 2.7.x.
> >
> > The LHS has nothing to do with it.
> 
> ah, sorry, i didn't look closely enough.  so if one
could count on a
> C99-compilant compiler being available, then the first
form would be
> perfectly acceptable?  thanks.

Yes.

-- 
Glynn Clements <glynngclements.plus.com>
-
To unsubscribe from this list: send the line
"unsubscribe linux-c-programming" in
the body of a message to majordomovger.kernel.org
More majordomo info at  http://vge
r.kernel.org/majordomo-info.html
[1-4]

about | contact  Other archives ( Real Estate discussion Medical topics )