This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Address of an element of a struct

I have this code:

typedef struct _DLL_struct
   {
   unsigned char DLL_type;
   unsigned char DLL_lenght;
   unsigned char DLL_data_begin;
   } DLL_struct;

unsigned char xdata FskRxBuf[MAX_SIZE_BUFFER];


void main(void)
   {
   DLL_struct *DLL_ptr;   // pointer to cast on the buffer
   unsigned char xdata chacksum_rx;

   DLL_ptr = (DLL_struct *)FskRxBuf;   // cast the struct to the buffer

   checksum_rx = *(&DLL_ptr->DLL_data_begin + DLL_ptr->DLL_lenght);  // read the received checksum
   }

I tried to define a struct pointer and cast it on a plain char buffer to obtain access to the buffer using the fields of the structure.
I run the code on a debugger and get a problem with the address of the structure fields.
Say that FskRxBuf begins at 0x0292, the debugger tells me that the expression &DLL_ptr->DLL_data_begin is 0x92 and not 0x0292 like I thought.
Where is my mistake?

Parents
  • I forgot a smiley in my previous statement.
    That said, I don't think that something has to be difficult to be good.
    The 8051 memory management isn't the smartest way I can imagine to handle memory.
    But I have to admit I'm not so into this micro to understand what could be the idea behind that.
    Just don't hate me for that, please.

Reply
  • I forgot a smiley in my previous statement.
    That said, I don't think that something has to be difficult to be good.
    The 8051 memory management isn't the smartest way I can imagine to handle memory.
    But I have to admit I'm not so into this micro to understand what could be the idea behind that.
    Just don't hate me for that, please.

Children
  • Two reasons for the memory layout:
    - Minimal transistor count.
    - Small instructions.

    For an 8-bit processor without real 16-bit registers, a full 16-bit address is no fun at all. Intel wanted as large part of the application as possible to use 8-bit addresses. Remember that the original C51 did not have any processor cache to handle the extra ticks required to access one or more extra bytes of instruction data from a very, very slow memory.

  • The 8051 memory management isn't the smartest way I can imagine to handle memory.

    Back in the time when the architecture was invented, the memory architecture was pretty smart for the intended purposes and the expected price range of the chip.

    Today, when throwing lots of transistors at a problem is cheap and acceptable, there are more convenient ways to deal with memory. Back then, that wasn't the case.

  • That said, I don't think that something has to be difficult to be good.
    Agreed, KISS is the best way. However, how much do you learn from something easy?
    The 8051 memory management isn't the smartest way I can imagine to handle memory.
    Smart?, maybe not, but darn efficient when the '51 is used for the applications it is intendede for

    Erik