Update contrib.
1 // Copyright (c) 1994-2009 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of the License "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
14 // e32\include\e32kpan.h
15 // Kernel-generated panic codes
27 These panics represent program errors detected by the Kernel.
28 Typically, they are caused by passing bad or contradictory parameters
29 to functions. Threads that cause exceptions also raise a KERN-EXEC type panic.
35 This panic is raised when the Kernel cannot find an object in
36 the object index for the current process, or current thread, using
37 a specified object index number (the raw handle number).
42 This is a general panic raised as a result of attempting
43 some unauthorised activity such as trying to suspend a thread,
44 or trying to set the priority of a thread, when not authorised to do so.
49 This panic is raised by the kernel when opening a kernel side object,
50 a DObject type, and the fullname is invalid.
55 This panic is raised when an unhandled exception occurs.
56 Exceptions have many causes, but the most common are access violations
57 caused, for example, by dreferencing NULL.
59 Among other possible causes are:
60 general protection faults, executing an invalid instruction,
61 alignment checks, etc.
76 This panic is raised by the kernel when a handle to a code segment
84 ESegmentWriteOutOfRange=7,
92 This is a general panic raised by the kernel when an attempt
93 is made to issue a request when one is already outstanding, and only one
94 outstanding request is permitted at any one time.
96 ERequestAlreadyPending=9,
99 This panic is raised by the Request() member function of
100 the DLogicalChannel() kernel object when the request number passed
101 to the function is smaller than the permitted minimum.
103 @see DLogicalChannel::EMinRequestId
105 ERequestNoInvalid=10,
108 This panic is raised when creating a logical channel, and the unit number
109 is outside the permitted range.
111 If unit numbers are not permmitted, the unit number value
113 If unit numbers are permitted, the unit number value must
114 be less than KMaxUnits.
119 This panic is raised by the kernel if an event capture
120 hook has already been designated.
122 EEventAlreadyCaptured=12,
125 This panic is raised by the kernel if the current thread is not
126 the designated event capture hook.
128 EEventNotCaptured=13,
131 This panic is raised when an attempt is made to set the priority of
132 a thread or process to an illegal value.
137 This panic is raised when a timer event is requested from an asynchronous
138 timer service, an RTimer, and a timer event is already outstanding.
139 It is caused by calling either the At(), After() or Lock() member functions
140 after a previous call to any of these functions but before the timer event
141 requested by those functions has completed.
143 ETimerAlreadyPending=15,
151 The panic is raised if kernel heap checking has failed.
153 EFailedKernelHeapCheck=17,
158 ERequestFromWrongThread=18,
161 This panic is raised by the Kernel when a server program issues a request
162 to receive a message, i.e. when it calls the Receive() member function
163 of RServer, the handle to the Kernel side server object.
165 The panic occurs when a receive message request has previously been made
166 and is still outstanding.
168 EMesAlreadyPending=19,
171 This panic is raised by the Kernel when a request for an event
172 (as originated by a call to UserSvr::RequestEvent()) is made while
173 a previously made request is still outstanding.
175 EEventRequestPending=20,
180 EIllegalWsProcess=21,
185 EHardwareNotAvailable=22,
188 This panic is raised when attempting to create a session with a server,
189 and access is been denied.
191 EUnsharableSession=23,
194 This panic is raised when writing global DLL data, and the length of
195 data to be written is greater than the space available.
200 This panic is raised when searching for objects, using the internal
201 function TFindHandleBase::NextObject(), and an invalid object type
207 This panic is raised by kernel side code that implements heap debugging
208 behaviour, when a specific debug request is not recognised.
210 EBadKernelHeapDebugFunction=26,
213 This panic is raised when an executive call is made with an invalid call
216 EInvalidSystemCall=27,
221 ESetSessionPtrInvalidMessage=28,
226 ECompleteDisconnectInvalidMessage=29,
229 This panic is raised when an attempt is being made to send
230 a synchronous message to a server more than once, using
231 the current thread's dedicated synchronous message.
233 ESyncMsgSentTwice=30,
238 EAutoAttachFailed=31,
241 This panic is called by DProcess::Resume() when trying to resume
242 a process that is still being loaded.
244 EProcessNotLoaded=32,
247 This panic is raised in a call to Kern::KUDesInfo(), Kern::KUDesPut() etc
248 when an invalid descriptor is passed.
250 EKUDesInfoInvalidType=33,
253 This panic is raised in a call to Kern::KUDesSetLength() & Kern::KUDesPut()
254 when the descriptor passed to it is not a modifiable type.
256 EKUDesSetLengthInvalidType=34,
259 This panic is raised in a call to Kern::KUDesSetLength() & Kern::KUDesPut()
260 when the length of the source descriptor is longer than the length of
261 the target descriptor.
263 EKUDesSetLengthOverflow=35,
266 This panic is raised by the kernel side code that implements the setting
267 of the currency symbol when the length of the currency symbol is
268 greater than KMaxCurrencySymbol.
273 This panic is raised by kernel code when it tries to acquire the process
274 DLL lock just before a load, and the wait DLL lock is invalid.
276 EWaitDllLockInvalid=37,
279 This panic is raised by internal kernel code when an illegal attempt
280 is made to attatch to a library.
282 ELibraryAttachInvalid=38,
285 This panic is raised when extracting a list of DLL entry points
286 and the number exceeds the maximum permitted.
288 ETooManyEntryPoints=39,
291 This panic is raised by internal kernel code when an illegal attempt
292 is made to detach a library.
294 ELibraryDetachInvalid=40,
297 This panic is raised by internal kernel code when an illegal attempt
298 is made to attach to a library.
300 ELibraryAttachedInvalid=41,
303 This panic is raised by internal kernel code when an illegal attempt
304 is made to detach a library.
306 ELibraryDetachedInvalid=42,
309 This panic is raised by kernel code when it tries to release the process DLL lock
310 when a load fails, and the release DLL lock is invalid.
312 EReleaseDllLockInvalid=43,
315 This panic is raised when a bad message handle is passed to the kernel.
316 This usually occurs when using methods on the RMessagePtr2 or RMessage2 classes
317 after the message has been completed; or when the iHandle data member has become
320 EBadMessageHandle=44,
325 EInvalidMessageParameter=45,
328 This panic can be raised as a result of a call to one of a large
329 number of functions. In general, the panic indicates an attempt to perform an
330 operation on a thread or process by code running in another process - violating
331 the security principle of process isolation.
333 There are exceptions to this general rule, for example, where the
334 panic is raised because the calling process has insufficient capability. The
335 precise reason is stated with the function(s).
337 -# The panic is raised on a call to the following function if the
338 process owning the thread performing the call is not the creator of the target
339 process or, if a handle is specified, the handle is not local.
340 - RProcess::SetParameter()
342 -# The panic is raised on a call to the following functions if the
343 process owning the thread performing the call is not the same as the target
346 - RProcess::Terminate()
348 - RProcess::SetJustInTime()
351 - RThread::Terminate()
355 - RThread::SetPriority()
356 - RThread::RequestComplete()
357 - RThread::RequestSignal()
359 NOTE: the creator of a new process can kill or panic the new
360 process, change the new process priority and set the new process startup
361 parameters until the process is resumed (which the creator can also do). After
362 the new process has been resumed, then it becomes totally independent of its
363 creator, and any attempt to panic it, kill it etc will raise the KERN-EXEC 46
365 -# The panic is raised on call to the following (Symbian partner
366 only) functions if the calling process does not have the PowerMgmt
367 capability (TCapability::ECapabilityPowerMgmt):
369 - Power::EnableWakeupEvents()
370 - Power::DisableWakeupEvents()
371 - Power::RequestWakeupEventNotification()
372 - Power::CancelWakeupEventNotification()
374 -# The panic is raised on call to the following functions if the
375 calling process does not have the WriteDeviceData capability
376 (TCapability::ECapabilityWriteDeviceData):
377 - User::SetMachineConfiguration()
378 - User::SetHomeTime()
380 - User::SetUTCOffset()
381 - User::SetUTCTimeAndOffset()
383 -# The panic is raised on call to the following function if the
384 calling process does not have the ReadDeviceData capability
385 (TCapability::ECapabilityReadDeviceData):
386 - User::MachineConfiguration()
389 EPlatformSecurityTrap=46,
392 This panic is raised when the user issues a request to be notified of
393 messages or the availability of space, when a request has already been
394 issued and is still outstanding.
398 EMsgQueueRequestPending=47,
401 This panic is raised when creating a message queue and the size of
402 the template parameter is invalid.
406 EMsgQueueInvalidLength=48,
409 This panic is raised when creating a message queue and the specified number
410 of slots is not positive.
414 EMsgQueueInvalidSlots=49,
417 This panic is raised if an attempt is made to cancel an outstanding request
418 to be notified of messages or the availability of space, and the cancel is
419 being made by a thread in a different process.
421 EMsgQueueIllegalCancel=50,
424 This panic is raised by RProcess::Setparameter()
425 if a slot value is invalid.
427 EParameterSlotRange=51,
430 This panic is raised by RProcess::Setparameter()
433 EParameterSlotInUse=52,
436 This panic is raised by RProcess::Setparameter()
437 if the length of the data passed is negative.
439 EParameterSlotDataLength=53,
442 This panic is raised by RCondVar::Wait() when the current thread does
443 not hold the specified mutex.
445 ECondVarWaitMutexNotLocked=54,
448 This panic is raised when a call is made to RThread::GetDesMaxLength(),
451 EObsoleteFunctionality=55,
454 This panic is raised on a process which has not yet been resumed and whoes
457 EZombieProcessKilled=56,
460 A connect message was sent to a session that has already been successfully
461 connected to the server (cookie is non-NULL).
463 ESessionAlreadyConnected=57,
466 A session tried to set the kernel session cookie to a null value
468 ESessionNullCookie=58,
471 A session tried to set the kernel session cookie twice
473 ESessionCookieAlreadySet=59,
476 A session tried to set the kernel session cookie with a message
477 that wasn't the connect message
479 ESessionInvalidCookieMsg=60,
482 A realtime thread executed a non-realtime function.
484 EIllegalFunctionForRealtimeThread=61,
487 This panic is raised by Kern::SetThreadRealtimeState when the state argument is invalid.
489 EInvalidRealtimeState=62,
492 A bad descriptor was passed to a server over IPC, causing an exception when the kernel tried to
493 update its length field.
495 EBadIpcDescriptor=63,
498 An invalid notification type was passed to a shared buffers exec call handler.
500 EShBufExecBadNotification=64,
503 An invalid parameter was passed to a shared buffers exec call handler.
505 EShBufExecBadParameter=65,