aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/acpi/fan.c
diff options
context:
space:
mode:
authorMichael Ellerman <michael@ellerman.id.au>2008-03-12 03:03:24 -0400
committerPaul Mackerras <paulus@samba.org>2008-03-12 19:10:26 -0400
commit31bf111944e31b64a7b692f9d660f71c5ff3d419 (patch)
treed35dd19288e3bc3529c1ccb00aacc74690f97776 /drivers/acpi/fan.c
parent07dc42f632e335a03c0e780805dc9dc141f83e63 (diff)
[POWERPC] Fix large hash table allocation on Cell blades
My recent hack to allocate the hash table under 1GB on cell was poorly tested, *cough*. It turns out on blades with large amounts of memory we fail to allocate the hash table at all. This is because RTAS has been instantiated just below 768MB, and 0-x MB are used by the kernel, leaving no areas that are both large enough and also naturally-aligned. For the cell IOMMU hack the page tables must be under 2GB, so use that as the limit instead. This has been tested on real hardware and boots happily. Signed-off-by: Michael Ellerman <michael@ellerman.id.au> Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'drivers/acpi/fan.c')
0 files changed, 0 insertions, 0 deletions
wb">unsigned long nsentctlpkt; unsigned long nsentdatapkt; struct mutex recv_mtx; struct sk_buff_head recv_queue; struct work_struct recv_work; int release_in_progress; /* ugly hack to allow for notification of added/removed * controllers. The Right Way (tm) is known. XXX */ void (*callback) (unsigned int cmd, __u32 contr, void *data); }; u16 capi20_isinstalled(void); u16 capi20_register(struct capi20_appl *ap); u16 capi20_release(struct capi20_appl *ap); u16 capi20_put_message(struct capi20_appl *ap, struct sk_buff *skb); u16 capi20_get_manufacturer(u32 contr, u8 buf[CAPI_MANUFACTURER_LEN]); u16 capi20_get_version(u32 contr, struct capi_version *verp); u16 capi20_get_serial(u32 contr, u8 serial[CAPI_SERIAL_LEN]); u16 capi20_get_profile(u32 contr, struct capi_profile *profp); int capi20_manufacturer(unsigned int cmd, void __user *data); /* temporary hack XXX */ void capi20_set_callback(struct capi20_appl *ap, void (*callback) (unsigned int cmd, __u32 contr, void *data)); #define CAPI_NOERROR 0x0000 #define CAPI_TOOMANYAPPLS 0x1001 #define CAPI_LOGBLKSIZETOSMALL 0x1002 #define CAPI_BUFFEXECEEDS64K 0x1003 #define CAPI_MSGBUFSIZETOOSMALL 0x1004 #define CAPI_ANZLOGCONNNOTSUPPORTED 0x1005 #define CAPI_REGRESERVED 0x1006 #define CAPI_REGBUSY 0x1007 #define CAPI_REGOSRESOURCEERR 0x1008 #define CAPI_REGNOTINSTALLED 0x1009 #define CAPI_REGCTRLERNOTSUPPORTEXTEQUIP 0x100a #define CAPI_REGCTRLERONLYSUPPORTEXTEQUIP 0x100b #define CAPI_ILLAPPNR 0x1101 #define CAPI_ILLCMDORSUBCMDORMSGTOSMALL 0x1102 #define CAPI_SENDQUEUEFULL 0x1103 #define CAPI_RECEIVEQUEUEEMPTY 0x1104 #define CAPI_RECEIVEOVERFLOW 0x1105 #define CAPI_UNKNOWNNOTPAR 0x1106 #define CAPI_MSGBUSY 0x1107 #define CAPI_MSGOSRESOURCEERR 0x1108 #define CAPI_MSGNOTINSTALLED 0x1109 #define CAPI_MSGCTRLERNOTSUPPORTEXTEQUIP 0x110a #define CAPI_MSGCTRLERONLYSUPPORTEXTEQUIP 0x110b typedef enum { CapiMessageNotSupportedInCurrentState = 0x2001, CapiIllContrPlciNcci = 0x2002, CapiNoPlciAvailable = 0x2003, CapiNoNcciAvailable = 0x2004, CapiNoListenResourcesAvailable = 0x2005, CapiNoFaxResourcesAvailable = 0x2006, CapiIllMessageParmCoding = 0x2007, } RESOURCE_CODING_PROBLEM; typedef enum { CapiB1ProtocolNotSupported = 0x3001, CapiB2ProtocolNotSupported = 0x3002, CapiB3ProtocolNotSupported = 0x3003, CapiB1ProtocolParameterNotSupported = 0x3004, CapiB2ProtocolParameterNotSupported = 0x3005, CapiB3ProtocolParameterNotSupported = 0x3006, CapiBProtocolCombinationNotSupported = 0x3007, CapiNcpiNotSupported = 0x3008, CapiCipValueUnknown = 0x3009, CapiFlagsNotSupported = 0x300a, CapiFacilityNotSupported = 0x300b, CapiDataLengthNotSupportedByCurrentProtocol = 0x300c, CapiResetProcedureNotSupportedByCurrentProtocol = 0x300d, CapiTeiAssignmentFailed = 0x300e, } REQUESTED_SERVICES_PROBLEM; typedef enum { CapiSuccess = 0x0000, CapiSupplementaryServiceNotSupported = 0x300e, CapiRequestNotAllowedInThisState = 0x3010, } SUPPLEMENTARY_SERVICE_INFO; typedef enum { CapiProtocolErrorLayer1 = 0x3301, CapiProtocolErrorLayer2 = 0x3302, CapiProtocolErrorLayer3 = 0x3303, CapiTimeOut = 0x3303, // SuppServiceReason CapiCallGivenToOtherApplication = 0x3304, } CAPI_REASON; #endif /* __KERNEL__ */ #endif /* __KERNELCAPI_H__ */