<?xml version='1.0' encoding='UTF-8'?>
<panic_category>
<category_name>KERN-EXEC</category_name>
<category_description> <p> These panics represent program errors which are detected by the Kernel Executive. Typically, they are caused by passing bad or contradictory parameters to functions. Threads which cause exceptions also raise a KERN-EXEC panic. </p> <p> The thread causing the panic is terminated. </p></category_description>
<panics>
<panic>
<panic_id>0</panic_id>
<panic_description><p> This panic is raised when the Kernel cannot find an object in the object index for the current process or current thread using the specified object index number (the raw handle number). </p> <p> The most common reason for this is trying to use a kernel-side resource without first having sucessfully created it or sucessfully opened it. Typically, such resources are created or opened through user side handles, which are instances of classes derived from <code class="ApiItem">RHandleBase</code>, for example, <code class="ApiItem">RLibrary</code>, <code class="ApiItem">RThread</code>, <code class="ApiItem">RProcess</code>, <code class="ApiItem">RSemaphore</code> etc. [Note that this list is not exhaustive]. </p> <p> For example, a call to <code class="ApiItem">RLibrary::Lookup()</code> panics with KERN-EXEC 0 if not preceded by a successful call to <code class="ApiItem">RLibrary::Load()</code>. </p></panic_description>
</panic>
<panic>
<panic_id>1</panic_id>
<panic_description><p> This is a general panic raised as a result of trying an unauthorised activity such as trying to suspend a thread, to set the priority of a thread or to set the priority of a process, when not authorised to do so. </p></panic_description>
</panic>
<panic>
<panic_id>2</panic_id>
<panic_description><p> This panic is raised by the kernel when opening a kernel side object, a <code class="ApiItem">DObject</code> type, and the fullname is invalid. </p> <p> The fullname is deemed to be invalid if it contains a character that is not one of the printable characters lying between 0x20 and 0x7e inclusive, or it contains an asterisk or a question mark. </p> <p> See also <code class="ApiItem">Kern::ValidateFullName()</code>. </p></panic_description>
</panic>
<panic>
<panic_id>3</panic_id>
<panic_description><p> This panic is raised when an unhandled exception occurs. Exceptions have many causes, but the most common are access violations caused, for example, by dereferencing NULL. Among other possible causes are: general protection faults, executing an invalid instruction, alignment checks, etc. </p></panic_description>
</panic>
<panic>
<panic_id>4</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>5</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>6</panic_id>
<panic_description><p> This panic is raised by the kernel when a handle to a code segment is invalid. </p></panic_description>
</panic>
<panic>
<panic_id>7</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>8</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>9</panic_id>
<panic_description><p> This is a general type of panic that is usually raised by a device driver when dealing with an asynchronous request, and it finds that an asynchronous request is already outstanding. For an example of the context in which this is raised, see <code class="filename">...\cedar\e32test\examples\driver1\driver1_ldd.cpp</code>. </p> <p> This panic is also raised when trying to subscribe to a property through a call to <code class="ApiItem">RProperty::Subscribe()</code> and there is already an outstanding subscription on this property handle. </p></panic_description>
</panic>
<panic>
<panic_id>10</panic_id>
<panic_description><p> This panic is raised by <code class="ApiItem">DLogicalChannel::Request()</code> when the request number passed to the function is smaller than the permitted minimum. </p> <p> See also <code class="ApiItem">DLogicalChannel::EMinRequestId</code>. </p></panic_description>
</panic>
<panic>
<panic_id>11</panic_id>
<panic_description><p> This panic is raised when creating a logical channel, and the unit number is outside the permitted range: </p> <p> If unit numbers are not permitted, the unit number value must be <code class="ApiItem">KNullUnit</code>. </p> <p> If unit numbers are permitted, the unit number value must be less than <code class="ApiItem">KMaxUnits</code>. </p> <p> A logical channel is created as a result of a call to <code class="ApiItem">RBusLogicalChannel::DoCreate()</code>. </p></panic_description>
</panic>
<panic>
<panic_id>12</panic_id>
<panic_description><p> This panic is raised by the kernel if an event capture hook has already been designated. </p></panic_description>
</panic>
<panic>
<panic_id>13</panic_id>
<panic_description><p> This panic is raised by the kernel if the current thread is not the designated event capture hook. </p></panic_description>
</panic>
<panic>
<panic_id>14</panic_id>
<panic_description><p> This panic is raised when an attempt is made to set the priority of a thread or process to an illegal value. </p> <p> The permitted priority values for a user process are a subset of the values defined by the <code class="ApiItem">TProcessPriority</code> enum. The permitted values are: </p> <code> EPriorityLow </code> <p> <code>EPriorityBackground </code> </p> <p> <code>EPriorityForeground </code> </p> <p> <code>EPriorityHigh </code> </p> <p> The permitted priority values for a user thread are a subset of the values defined by the <code class="ApiItem">TThreadPriority</code> enum. The permitted values are: </p> <p> <code> EPriorityMuchLess </code> </p> <p> <code> EPriorityLess </code> </p> <p> <code> EPriorityNormal </code> </p> <p> <code>EPriorityMore </code> </p> <p> <code> EPriorityMuchMore </code> </p> <code>EPriorityRealTime </code> </p> <p> <code>EPriorityAbsoluteVeryLow </code> </p> <p> <code> EPriorityAbsoluteLow </code> </p> <p> <code> EPriorityAbsoluteBackground </code> </p> <p> <code> EPriorityAbsoluteForeground </code> </p> <p> <code> EPriorityAbsoluteHigh </code> </p></panic_description>
</panic>
<panic>
<panic_id>15</panic_id>
<panic_description><p> This panic is raised when a timer event is requested from an asynchronous timer service, an <code class="ApiItem">RTimer</code>, and a timer event is already outstanding. It is caused by calling either the <code>At()</code>, <code>After()</code> or <code>Lock()</code> member functions after a previous call to any of these functions, but before the timer event requested by those functions has completed. </p></panic_description>
</panic>
<panic>
<panic_id>16</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>17</panic_id>
<panic_description><p> The panic is raised if kernel heap checking has failed. </p></panic_description>
</panic>
<panic>
<panic_id>18</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>19</panic_id>
<panic_description><p> This panic is raised by the Kernel when a server program makes a request to receive a message, i.e. when it calls the <code>Receive()</code> member function of <code>RServer2</code>, the handle to the Kernel side server object. The panic occurs when a receive message request has previously been made and is still outstanding. </p> <p> Note that <code>RServer2</code> is internal to Symbian </p></panic_description>
</panic>
<panic>
<panic_id>20</panic_id>
<panic_description><p> This panic is raised by the Kernel when a request for an event, as originated by a call to <code>UserSvr::RequestEvent()</code>, defined in <code class="filename">e32svr.h</code>, is made while a previously made request is still outstanding. </p></panic_description>
</panic>
<panic>
<panic_id>21</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>22</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>23</panic_id>
<panic_description><p> This panic is raised in a call to <code class="ApiItem">RSessionBase::ShareAuto()</code> or <code class="ApiItem">RSessionBase::ShareProtected()</code>, i.e. when attempting to create a session with a server that can be shared, and the server does not allow or support shared sessions. </p></panic_description>
</panic>
<panic>
<panic_id>24</panic_id>
<panic_description><p> This panic is raised when writing global DLL data, and the length of data to be written is greater than the space available. </p></panic_description>
</panic>
<panic>
<panic_id>25</panic_id>
<panic_description><p> This panic is raised when searching for objects, using the internal function <code>TFindHandleBase::NextObject()</code>, and an invalid type of object is specified; i.e. it is not a thread, process, chunk, mutex etc. etc. </p></panic_description>
</panic>
<panic>
<panic_id>26</panic_id>
<panic_description><p> This panic is raised by kernel side code that implements heap debugging behaviour, when a specific debug request is not recognised. </p></panic_description>
</panic>
<panic>
<panic_id>27</panic_id>
<panic_description><p> This panic is raised when an executive call is made with an invalid call number. </p></panic_description>
</panic>
<panic>
<panic_id>28</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>29</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>30</panic_id>
<panic_description><p> This panic is raised when an attempt is being made to send a synchronous message to a server more than once, using the current thread's dedicated synchronous message. </p></panic_description>
</panic>
<panic>
<panic_id>31</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>32</panic_id>
<panic_description><p> This panic is called by <code>DProcess::Resume()</code> when trying to resume a process that is still being loaded. </p></panic_description>
</panic>
<panic>
<panic_id>33</panic_id>
<panic_description><p> This panic is raised in a call to <code class="ApiItem">Kern::KUDesInfo()</code>, <code class="ApiItem">Kern::KUDesPut()</code> etc, when an invalid descriptor is passed. </p></panic_description>
</panic>
<panic>
<panic_id>34</panic_id>
<panic_description><p> This panic is raised in a call to <code class="ApiItem">Kern::KUDesSetLength()</code> &amp; <code class="ApiItem">Kern::KUDesPut()</code> when the descriptor passed to it is not a modifiable type; i.e. is derived from <code class="ApiItem">TDesC</code> but not derived from <code class="ApiItem">TDes</code>. </p></panic_description>
</panic>
<panic>
<panic_id>35</panic_id>
<panic_description><p> This panic is raised in a call to <code class="ApiItem">Kern::KUDesSetLength()</code> &amp; <code class="ApiItem">Kern::KUDesPut()</code> when the length of the source descriptor is longer than the maximum length of the target descriptor. </p></panic_description>
</panic>
<panic>
<panic_id>36</panic_id>
<panic_description><p> This panic is raised by the kernel side code that implements the setting of the currency symbol when the length of the currency symbol is greater than <code class="ApiItem">KMaxCurrencySymbol</code>. </p></panic_description>
</panic>
<panic>
<panic_id>37</panic_id>
<panic_description><p> This panic is raised by kernel code when it tries to acquire the process DLL lock just before a load, and the wait DLL lock is invalid. </p></panic_description>
</panic>
<panic>
<panic_id>38</panic_id>
<panic_description><p> This panic is raised by internal kernel code when an illegal attempt is made to attach to a library. </p></panic_description>
</panic>
<panic>
<panic_id>39</panic_id>
<panic_description><p> This panic is raised when extracting a list of DLL entry points, and the number exceeds the maximum permitted. </p></panic_description>
</panic>
<panic>
<panic_id>40</panic_id>
<panic_description><p> This panic is raised by internal kernel code when an illegal attempt is made to detach a library. </p></panic_description>
</panic>
<panic>
<panic_id>41</panic_id>
<panic_description><p> This panic is raised by internal kernel code when an illegal attempt is made to attach to a library. </p></panic_description>
</panic>
<panic>
<panic_id>42</panic_id>
<panic_description><p> This panic is raised by internal kernel code when an illegal attempt is made to detach a library. </p></panic_description>
</panic>
<panic>
<panic_id>43</panic_id>
<panic_description><p> This panic is raised by kernel code when it tries to release the process DLL lock when a load fails, and the release DLL lock is invalid. </p></panic_description>
</panic>
<panic>
<panic_id>44</panic_id>
<panic_description><p> This panic is raised when a bad message handle is passed to the kernel. This usually occurs when using functions called on the <code class="ApiItem">RMessagePtr2</code> or <code class="ApiItem">RMessage2</code> classes after the message has been completed; or when the <code>iHandle</code> data member of the base class <code class="ApiItem">RHandleBase</code> has become corrupt. </p></panic_description>
</panic>
<panic>
<panic_id>45</panic_id>
<panic_description><p> This panic is not used. </p></panic_description>
</panic>
<panic>
<panic_id>46</panic_id>
<panic_description><p> This panic can be raised as a result of a call to one of a large number of functions. In general, the panic indicates an attempt to perform an operation on a thread or process by code running in another process - violating the security principle of process isolation. </p> <p> There are exceptions to this general rule, for example, where the panic is raised because the calling process has insufficient capability. The precise reason is stated with the function(s). </p> <p> The panic is raised on a call to the following function if the process owning the thread performing the call is not the creator of the target process or, if a handle is specified, the handle is not local. </p> <p> <code class="ApiItem">RProcess::SetParameter()</code> </p> <p> The panic is raised on a call to the following functions if the process owning the thread performing the call is not the same as the target process. </p> <p> <code class="ApiItem">RProcess::Kill()</code> </p> <p> <code class="ApiItem">RProcess::Terminate()</code> </p> <p> <code class="ApiItem">RProcess::Panic()</code> </p> <p> <code class="ApiItem">RProcess::SetJustInTime()</code> </p> <p> <code class="ApiItem">RProcess::Resume()</code> </p> <p> <code class="ApiItem">RThread::Kill()</code> </p> <p> <code class="ApiItem">RThread::Terminate()</code> </p> <p> <code class="ApiItem">RThread::Panic()</code> </p> <p> <code class="ApiItem">RThread::Suspend()</code> </p> <p> <code class="ApiItem">RThread::Resume()</code> </p> <p> <code class="ApiItem">RThread::SetPriority()</code> </p> <p> <code class="ApiItem">RThread::RequestComplete()</code> </p> <p> <code class="ApiItem">RThread::RequestSignal()</code> </p> <p> NOTE: the creator of a new process can kill or panic the new process, change the new process priority and set the new process startup parameters until the process is resumed (which the creator can also do). After the new process has been resumed, then it becomes totally independent of its creator, and any attempt to panic it, kill it etc will raise the KERN-EXEC 46 panic. </p> <p> The panic is raised on call to the following (Symbian partner only) functions if the calling process does not have the <em>PowerMgmt</em> capability (<code class="ApiItem">TCapability::ECapabilityPowerMgmt</code>): </p> <p> <code class="ApiItem">Power::PowerDown()</code> </p> <p> <code class="ApiItem">Power::EnableWakeupEvents()</code> </p> <p> <code class="ApiItem">Power::DisableWakeupEvents()</code> </p> <p> <code class="ApiItem">Power::RequestWakeupEventNotification()</code> </p> <p> <code class="ApiItem">Power::CancelWakeupEventNotification()</code> </p> <p> The panic is raised on call to the following functions if the calling process does not have the <em>WriteDeviceData</em> capability (<code class="ApiItem">TCapability::ECapabilityWriteDeviceData</code>): </p> <p> <code class="ApiItem">User::SetMachineConfiguration()</code> </p> <p> <code class="ApiItem">User::SetHomeTime()</code> </p> <p> <code class="ApiItem">User::SetUTCTime()</code> </p> <p> <code class="ApiItem">User::SetUTCOffset()</code> </p> <p> <code class="ApiItem">User::SetUTCTimeAndOffset()</code> </p> <p> The panic is raised on call to the following function if the calling process does not have the <em>ReadDeviceData</em> capability (<code class="ApiItem">TCapability::ECapabilityReadDeviceData</code>): </p> <p> <code class="ApiItem">User::MachineConfiguration()</code> </p></panic_description>
</panic>
<panic>
<panic_id>47</panic_id>
<panic_description><p> This panic is raised when the user issues a request to be notified of messages or the availability of space, when a request has already been issued and is still outstanding. </p> <p> See <code class="ApiItem">RMsgQueue</code>, asynchronous message queues. </p></panic_description>
</panic>
<panic>
<panic_id>48</panic_id>
<panic_description><p> This panic is raised when creating a message queue, and the size of the template parameter is invalid. </p> <p> See <code class="ApiItem">RMsgQueue</code>, asynchronous message queues. </p></panic_description>
</panic>
<panic>
<panic_id>49</panic_id>
<panic_description><p> This panic is raised when creating a message queue, and the specified number of slots is not positive. </p> <p> See <code class="ApiItem">RMsgQueue</code>, asynchronous message queues. </p></panic_description>
</panic>
<panic>
<panic_id>50</panic_id>
<panic_description><p> This panic is raised if an attempt is made to cancel an outstanding request to be notified of messages or the availability of space, and the cancel is being made by a thread in a different process to the one from which the request was originally made. </p> <p> See <code class="ApiItem">RMsgQueue</code>, asynchronous message queues. </p></panic_description>
</panic>
<panic>
<panic_id>51</panic_id>
<panic_description><p> This panic is raised by <code>RProcess::Setparameter()</code> if a slot value is invalid. </p></panic_description>
</panic>
<panic>
<panic_id>52</panic_id>
<panic_description><p> This panic is raised by <code>RProcess::Setparameter()</code> if a slot is in use. </p></panic_description>
</panic>
<panic>
<panic_id>53</panic_id>
<panic_description><p> This panic is raised by <code>RProcess::Setparameter()</code> if the length of the data passed is negative. </p></panic_description>
</panic>
<panic>
<panic_id>54</panic_id>
<panic_description><p> This panic is raised by <code class="ApiItem">RCondVar::Wait()</code> when the current thread does not hold the specified mutex. </p></panic_description>
</panic>
<panic>
<panic_id>55</panic_id>
<panic_description><p> This panic is raised when a call is made to <code>RThread::GetDesMaxLength()</code>, which is now obsolete. </p></panic_description>
</panic>
<panic>
<panic_id>56</panic_id>
<panic_description><p> This panic is raised on a process which has not yet been resumed, and whose creator has died. </p></panic_description>
</panic>
<panic>
<panic_id>57</panic_id>
<panic_description><p> This panic is raised when a session receives a message to connect to a server when the session is already connected to that server. </p></panic_description>
</panic>
<panic>
<panic_id>58</panic_id>
<panic_description><p> This panic is raised during an attempt to connect to a server. As part of this process, a pointer to an instance of the <code class="ApiItem">CSession2</code> derived class is saved in the instance of the <code class="ApiItem">CServer2</code> derived class. </p> <p> The panic is caused when the pointer to the session object is NULL. </p></panic_description>
</panic>
<panic>
<panic_id>59</panic_id>
<panic_description><p> This panic is raised during an attempt to connect to a server. As part of this process, a pointer to an instance of the <code class="ApiItem">CSession2</code> derived class is saved in the instance of the <code class="ApiItem">CServer2</code> derived class. </p> <p> This panic is caused when a pointer to the session has previously been set. </p></panic_description>
</panic>
<panic>
<panic_id>60</panic_id>
<panic_description><p> This panic is raised during an attempt to connect to a server. As part of this process, a pointer to an instance of the <code class="ApiItem">CSession2</code> derived class is saved in the instance of the <code class="ApiItem">CServer2</code> derived class. </p> <p>This panic is caused when a pointer to a session is being set, and the message is not the connect message.</p></panic_description>
</panic>
</panics>
</panic_category>