/* * Copyright (c) 1999 Apple Computer, Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * * This file contains Original Code and/or Modifications of Original Code * as defined in and that are subject to the Apple Public Source License * Version 2.0 (the 'License'). You may not use this file except in * compliance with the License. Please obtain a copy of the License at * http://www.opensource.apple.com/apsl/ and read it before using this * file. * * The Original Code and all software distributed under the License are * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. * Please see the License for the specific language governing rights and * limitations under the License. * * @APPLE_LICENSE_HEADER_END@ */ #ifndef _MACH_O_ARCH_H_ #define _MACH_O_ARCH_H_ /* * Copyright (c) 1997 Apple Computer, Inc. * * Functions that deal with information about architectures. * */ #include #include #include /* The NXArchInfo structs contain the architectures symbolic name * (such as "ppc"), its CPU type and CPU subtype as defined in * mach/machine.h, the byte order for the architecture, and a * describing string (such as "PowerPC"). * There will both be entries for specific CPUs (such as ppc604e) as * well as generic "family" entries (such as ppc). */ typedef struct { const char *name; cpu_type_t cputype; cpu_subtype_t cpusubtype; enum NXByteOrder byteorder; const char *description; } NXArchInfo; #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /* NXGetAllArchInfos() returns a pointer to an array of all known * NXArchInfo structures. The last NXArchInfo is marked by a NULL name. */ extern const NXArchInfo *NXGetAllArchInfos(void); /* NXGetLocalArchInfo() returns the NXArchInfo for the local host, or NULL * if none is known. */ extern const NXArchInfo *NXGetLocalArchInfo(void); /* NXGetArchInfoFromName() and NXGetArchInfoFromCpuType() return the * NXArchInfo from the architecture's name or cputype/cpusubtype * combination. A cpusubtype of CPU_SUBTYPE_MULTIPLE can be used * to request the most general NXArchInfo known for the given cputype. * NULL is returned if no matching NXArchInfo can be found. */ extern const NXArchInfo *NXGetArchInfoFromName(const char *name); extern const NXArchInfo *NXGetArchInfoFromCpuType(cpu_type_t cputype, cpu_subtype_t cpusubtype); /* The above interfaces that return pointers to NXArchInfo structs in normal * cases returns a pointer from the array returned in NXGetAllArchInfos(). * In some cases when the cputype is CPU_TYPE_I386 or CPU_TYPE_POWERPC it will * retun malloc(3)'ed NXArchInfo struct which contains a string in the * description field also a malloc(3)'ed pointer. To allow programs not to * leak memory they can call NXFreeArchInfo() on pointers returned from the * above interfaces. Since this is a new API on older systems can use the * code below. Going forward the above interfaces will only return pointers * from the array returned in NXGetAllArchInfos(). */ extern void NXFreeArchInfo(const NXArchInfo *x); /* The code that can be used for NXFreeArchInfo() when it is not available is: * * static void NXFreeArchInfo( * const NXArchInfo *x) * { * const NXArchInfo *p; * * p = NXGetAllArchInfos(); * while(p->name != NULL){ * if(x == p) * return; * p++; * } * free((char *)x->description); * free((NXArchInfo *)x); * } */ /* NXFindBestFatArch() is passed a cputype and cpusubtype and a set of * fat_arch structs and selects the best one that matches (if any) and returns * a pointer to that fat_arch struct (or NULL). The fat_arch structs must be * in the host byte order and correct such that the fat_archs really points to * enough memory for nfat_arch structs. It is possible that this routine could * fail if new cputypes or cpusubtypes are added and an old version of this * routine is used. But if there is an exact match between the cputype and * cpusubtype and one of the fat_arch structs this routine will always succeed. */ extern struct fat_arch *NXFindBestFatArch(cpu_type_t cputype, cpu_subtype_t cpusubtype, struct fat_arch *fat_archs, uint32_t nfat_archs); /* NXFindBestFatArch_64() is passed a cputype and cpusubtype and a set of * fat_arch_64 structs and selects the best one that matches (if any) and * returns a pointer to that fat_arch_64 struct (or NULL). The fat_arch_64 * structs must be in the host byte order and correct such that the fat_archs64 * really points to enough memory for nfat_arch structs. It is possible that * this routine could fail if new cputypes or cpusubtypes are added and an old * version of this routine is used. But if there is an exact match between the * cputype and cpusubtype and one of the fat_arch_64 structs this routine will * always succeed. */ extern struct fat_arch_64 *NXFindBestFatArch_64(cpu_type_t cputype, cpu_subtype_t cpusubtype, struct fat_arch_64 *fat_archs64, uint32_t nfat_archs); /* NXCombineCpuSubtypes() returns the resulting cpusubtype when combining two * different cpusubtypes for the specified cputype. If the two cpusubtypes * can't be combined (the specific subtypes are mutually exclusive) -1 is * returned indicating it is an error to combine them. This can also fail and * return -1 if new cputypes or cpusubtypes are added and an old version of * this routine is used. But if the cpusubtypes are the same they can always * be combined and this routine will return the cpusubtype pass in. */ extern cpu_subtype_t NXCombineCpuSubtypes(cpu_type_t cputype, cpu_subtype_t cpusubtype1, cpu_subtype_t cpusubtype2); #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* _MACH_O_ARCH_H_ */