Hacker News new | past | comments | ask | show | jobs | submit login

Good article.

I've done C on half of those platforms. 8051 is actually more complex than described. There are two different kinds of RAM with two different addressing modes. IIRC there are 128 bytes of "zero page" RAM and, depending on the specific variant, somewhere between 256 bytes and a few kilobytes of "normal" RAM. Both RAM types can be present, and the addresses can both be the same value, but point to different memory, so the context of the RAM type is critical. The variants usually have a lot more ROM than RAM so coding styles may need to be adjusted, such as using a lot of (ROM initialized data) constants instead of computing things at run time.

6502 has a similar "zero page" addressing mode to the 8051.

I never encountered any alignment exceptions on 68k (Aztec C). Either I was oblivious and lucky, or just naturally wrote good code.

I do remember something about PDP-11 where there was a maximum code segment size (32k words?).

C on the VAX (where I first learned it) was a superset of the (not yet) ANSI standard. I vaguely remember some cases where the compiler/environment would allow some lazy notation with regard to initialized data structures.

They left out some interesting platforms (such as 6809/OS9, TI MSP430 and PPC), which have their own quirks.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: