Randy Dunlap | b67ad18 | 2008-11-12 13:26:55 -0800 | [diff] [blame] | 1 | If variable is of Type, use printk format specifier: |
| 2 | --------------------------------------------------------- |
| 3 | int %d or %x |
| 4 | unsigned int %u or %x |
| 5 | long %ld or %lx |
| 6 | unsigned long %lu or %lx |
| 7 | long long %lld or %llx |
| 8 | unsigned long long %llu or %llx |
| 9 | size_t %zu or %zx |
| 10 | ssize_t %zd or %zx |
| 11 | |
| 12 | Raw pointer value SHOULD be printed with %p. |
| 13 | |
| 14 | u64 SHOULD be printed with %llu/%llx, (unsigned long long): |
| 15 | |
| 16 | printk("%llu", (unsigned long long)u64_var); |
| 17 | |
| 18 | s64 SHOULD be printed with %lld/%llx, (long long): |
| 19 | |
| 20 | printk("%lld", (long long)s64_var); |
| 21 | |
| 22 | If <type> is dependent on a config option for its size (e.g., sector_t, |
| 23 | blkcnt_t, phys_addr_t, resource_size_t) or is architecture-dependent |
| 24 | for its size (e.g., tcflag_t), use a format specifier of its largest |
| 25 | possible type and explicitly cast to it. Example: |
| 26 | |
| 27 | printk("test: sector number/total blocks: %llu/%llu\n", |
| 28 | (unsigned long long)sector, (unsigned long long)blockcount); |
| 29 | |
| 30 | Reminder: sizeof() result is of type size_t. |
| 31 | |
| 32 | Thank you for your cooperation and attention. |
| 33 | |
| 34 | |
| 35 | By Randy Dunlap <rdunlap@xenotime.net> |