From: Stephen Satchell <list@fluent2.pyramid.net>
To: Nate <nate@uniwest.com>, linux-gcc@vger.kernel.org
Subject: Re: C Language Reference for @ and :
Date: Wed, 28 Aug 2002 15:16:40 -0700 [thread overview]
Message-ID: <5.1.0.14.0.20020828145900.01d25780@fluent2.pyramid.net> (raw)
In-Reply-To: <000301c24ed4$8a6fa100$5001a8c0@uniwest.com>
At 01:50 PM 8/28/02 -0700, Nate wrote:
>I am looking at some C code and I cannot find any language reference as to
>what the '@' symbol or token means...
>
>For, example, from the header file I am trying to interpret....
>
>/////////////////////////////////////////////////////////////////
>static unsigned char P1 @ 0x90;
>static unsigned char P2 @ 0xA0;
>static unsigned char P3 @ 0xB0;
>/////////////////////////////////////////////////////////////////
The compiler implements an extension that indicates that the unsigned char
P1 is at the absolute address 0x00000090, and when the compiler generates
an access it should use this absolute address. The equivalent ANSI C code
using pointer variables might be:
static unsigned char * const P1 = (unsigned char *) 0x90;
static unsigned char * const P2 = (unsigned char *) 0xA0;
static unsigned char * const P3 = (unsigned char *) 0xB0;
Or the other way to do this is to use the preprocessor:
#define P1 ((unsigned char *)(0x90));
#define P2 ((unsigned char *)(0xA0));
#define P3 ((unsigned char *)(0xB0));
I used to see this with some compilers for machines that had memory-mapped
I/O in which the registers were at hardware-fixed locations. This is
actually bad form, particularly when a driver can be used with multiple
devices and there was no way to "map in" the particular device interface.
This is an oldie, and VERY machine-dependent.
>Also what does these colons mean... ( I understand this is creating a new
>type and it is a "public by default" class for a bit watching type.) But
>what does the colon do? Initialize defualts?
>
>/////////////////////////////////////////////////////////////////
>typedef struct
>{
> unsigned B0:1;
> unsigned B1:1;
> unsigned B2:1;
> unsigned B3:1;
> unsigned B4:1;
> unsigned B5:1;
> unsigned B6:1;
> unsigned B7:1;
>} SFR;
>/////////////////////////////////////////////////////////////////
Bitfield definition. Page 136-138 in the first edition of K&R _The C
Programming Language_, 149-150 in the second edition. This is part of ANSI
C, but the implementation definition makes it a non-portable
construct. Some people like to try to use bitfields in networking, with
disastrous results as you change compilers or even versions of the same
compiler.
The colon introduces a bit-width. In your definition, you are defining
seven bits in the variable SFR to be one-bit values that can be set or
reset using a simple assignment statement:
SFR.B0 = 1; /* Set a single bit */
SFR.B4 = 0; /* Reset a single bit */
The problem is that which structure variables get assigned to which bits is
not specified in the standard, but is labelled "implementation
defined." From the definition you show, I suspect that the compiler
originally used to compile the code assigned bit fields from the low-order
bits to the high-order bits of a regular integer. Other compilers may
start from the most significant bit and work down, which is why this
construct is highly non-portable if you store or read the variable to/from
storage or a network.
Satch
next prev parent reply other threads:[~2002-08-28 22:16 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2002-08-01 7:56 stat() problems Stefanos Koutsoutos
2002-08-01 11:48 ` Alexandre P. Nunes
2002-08-01 12:05 ` Stefanos Koutsoutos
2002-08-28 20:50 ` C Language Reference for @ and : Nate
2002-08-28 22:16 ` Stephen Satchell [this message]
2003-01-15 20:00 ` Stack and Heap Nate
[not found] <Pine.GSO.4.21.0208281355510.20978-100000@general3.asu.edu>
2002-08-28 21:09 ` C Language Reference for @ and : Nate
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=5.1.0.14.0.20020828145900.01d25780@fluent2.pyramid.net \
--to=list@fluent2.pyramid.net \
--cc=linux-gcc@vger.kernel.org \
--cc=nate@uniwest.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).