KnowledgeBase Archive

An Archive of Early Microsoft KnowledgeBase Articles

View on GitHub

Q24270: Tracking Down a Null Pointer Assignment Error

Article: Q24270
Product(s): See article
Version(s): 1.00 1.10 2.00 2.10 2.20 2.30 | 2.20 2.30
Operating System(s): MS-DOS | OS/2
Keyword(s): ENDUSER | S_C | mspl13_basic
Last Modified: 21-AUG-1989

Question:

I consistently get the error number R6001 "null pointer assignment"
when I run my program. How can I use CodeView to determine the point
at which the null pointer assignment is occurring?

Response:

Use a tracepoint, which can be set to watch a range of memory up to
128 bytes. It will halt the execution of the program when any value in
this range is changed. If you set a tracepoint over the entire range
of the null segment, the program will halt immediately after the
instruction that wrote over the null segment.

The location of the null segment is available in the link maps of
Microsoft compilers. It starts at DS:0 and is 42H bytes long. The
Microsoft copyright notice is written there at program startup and
if this area is written to during the course of the program, the
error r6001 is generated. The most common cause of this error is
using a pointer that has not been initialized to point to a memory
area. Pointers that have not had space allocated for them (using
malloc for example) or that have not been assigned to a specific
data element (arrays or structures for example) are considered
uninitialized.

An example of using CodeView to determine where an unitialized pointer
is being used follows:

g main                  /* go to the beginning of main() */
n16                     /* switch to hexadecimal (base 16) */
tpb DS:0 DS:42          /* set a Trace Point of type Byte starting
                              at address DS:0 and extending to DS:42 */

When any value in the specified range changes, CodeView will stop the
execution of your program. The previously executed line was probably
the line that caused the R6001 error.

THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Copyright Microsoft Corporation 1986-2002.