|
|
1.1 ! root 1: /* ! 2: * This header file describes the structures of the file format for "fat" ! 3: * architecture specific file (wrapper design). At the begining of the file ! 4: * there is one fat_header structure followed by a number of fat_arch ! 5: * structures. For each architecture in the file, specified by a pair of ! 6: * cputype and cpusubtype, the fat_header describes the file offset, file ! 7: * size and alignment in the file of the architecture specific member. ! 8: * The padded bytes in the file to place each member on it's specific alignment ! 9: * are defined to be read as zeros and can be left as "holes" if the file system ! 10: * can support them as long as they read as zeros. ! 11: * ! 12: * All structures defined here are always written and read to/from disk ! 13: * in big-endian order. ! 14: */ ! 15: ! 16: /* ! 17: * <mach/machine.h> is needed here for the cpu_type_t and cpu_subtype_t types ! 18: * and contains the constants for the possible values of these types. ! 19: */ ! 20: #import <mach/machine.h> ! 21: #import <architecture/byte_order.h> ! 22: ! 23: #define FAT_MAGIC 0xcafebabe ! 24: #define FAT_CIGAM NXSwapLong(FAT_MAGIC) ! 25: ! 26: struct fat_header { ! 27: unsigned long magic; /* FAT_MAGIC */ ! 28: unsigned long nfat_arch; /* number of structs that follow */ ! 29: }; ! 30: ! 31: struct fat_arch { ! 32: cpu_type_t cputype; /* cpu specifier (int) */ ! 33: cpu_subtype_t cpusubtype; /* machine specifier (int) */ ! 34: unsigned long offset; /* file offset to this object file */ ! 35: unsigned long size; /* size of this object file */ ! 36: unsigned long align; /* alignment as a power of 2 */ ! 37: }; ! 38:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.