Debugging Makefiles


Jump to: navigation, search

Here is some information on debugging Makefiles:



showing symbol values, and showing file dependencies

There’s a good Dr. Dobbs article on this topic, by John Graham-Cumming, at:

or printable, all-in-one page, at

This article describes some macros you can put in your Makefiles to showyou the values of symbols, and to show the dependencies that led to a particulartarget being built. This is handy if you have a complex Makefile that youare trying to debug.

Makefile Debugger

John has also written a Makefile Debugger.

The following articles describe the debugger and how to use it:

The following resources are needed to use the debugger:

Expand the tarballs from these, and place __gmsl, gmsl and gmd in thedirectory with the Makefile you wish to debug.

Add the following lines to your Makefile:

include gmd


all:        $(__BREAKPOINT)


remake is a patched GNU make with a debugger,better tracing and error reporting. The latest version is based on GNU make version 3.82 released sources.


Use the option –debugger (short form is -X) in your make invocation. For example:

$ remake --debugger

But much of the time you may be able to get by using just the better tracing that is given.For that use option –trace (short form is -x). For example:

$ remake -x

Debugging a kernel build

Verbose options

There are several Kernel makefile tricks which are helpful for debugging a kernel build.

Try “make V=1 [<rest of make args…>]” to see all the full-length commands used to build the kernel.

Sometimes, if a particular step is breaking and you don’t understand why, you can copy-and-paste fromthis verbose command output (to the shell command line). To do this you need to make sure you are inthe correct source directory, and that all required files are present.

To see why a particular target is being build, use “make V=2”.This is quite useful when a small change results in much more being build than you expected.

Building in a separate directory

Use the variable KBUILD_OUTPUT either as an environment variable or on the make command line, if you wishto put the build output into a separate directory from the source. This can be useful for several reasons, including when you want to build for multiple architectures from the same source, or when you wish to avoid cluttering upthe source tree with object files, libraries and other generated files (to make diffs easier).

This entry was posted in Uncategorized. Bookmark the permalink.

Leave a Reply

Fill in your details below or click an icon to log in: Logo

You are commenting using your account. Log Out / Change )

Twitter picture

You are commenting using your Twitter account. Log Out / Change )

Facebook photo

You are commenting using your Facebook account. Log Out / Change )

Google+ photo

You are commenting using your Google+ account. Log Out / Change )

Connecting to %s