• Pros and Cons of fixed width types from C99's stdint.h
  • Fixed width types for platform code and binary codecs
  • Motivation for standard types for independent code
  • Use of semantic typedefs
  • Discriminating uintptr_t vs intptr_t vs void* vs size_t

General Portability

  • If you choose fixed width types then there is less chance of code breaking when moved onto a different platform
    • I think that's a fallacy.
    • Where we're needlessly using [INT16][1][?][1] or [UINT16][2][?][2], we're actually trying to guarantee that int hold a 16-bit value. That's already guaranteed by the C standard anyway.
    • Similarly with [INT32][3][?][3] or [UINT32][4][?][4], where the C standard guarantees a long will hold the necessary values.
    • Consider also the [CHAR8][5][?][5], [UINT8][6][?][6], string.h mess we've got. It really would be simpler to use plain char for strings.

Overflow

  • Using standard types int and char is only ok if you are absolutely sure that they are never going to overflow under any circumstances / platforms / compilers.
    • Overflow applies just as much to fixed-width types - if we're going to do any arithmetic on a fixed-width type, we still have to bounds check it.

Linking to standard libraries

  • There's a huge advantage to standard types in being able to link against different standard libraries without vigorous sprinklings of bug-hiding casts.
  • Systems programmers have gone to the effort of abstracting the underlying platform in implementing a standard library - it seems wasteful to ignore that.

Guarantee of existance

  • [u]int[8|16|32]_t are not guaranteed to exist - a library for an 8-bit micro *could* define only int8_t and uint8_t.
  • All compliant libraries are required to define [u]int_least[8|16|32]_t however, so maybe we ought to use those... :)

Static type checking

  • it gives Lint a greater chance of picking up errors.
    • Nope, lint already knows about the width of the platform's standard types.
    • If we want better checking we should use purely-semantic typedefs (e.g. typedef [UINT16][2][?][2] [CRC16][7][?][7]_T) more and turn on lint's strong type checks.

Performance

  • As for the performance hit, we are talking about code that has to run efficiently on a 16-bit embedded micro, if that code is then ported to a PC platform then speed of execution is hardly going to be an issue.
    • Agree. The performance advantage is negligeable.
    • But why prevent the compiler from doing its job?