First install MacPorts (and if you are on 10.6 or older, the Java Developer Package) and then run:
sudo port install libusb-devel git-core
sudo pkg_add -r git pkgconf
sudo apt-get build-dep dfu-util sudo apt-get install libusb-1.0-0-dev
The first time you will have to clone the git repository:
git clone git://git.code.sf.net/p/dfu-util/dfu-util cd dfu-util
If you later want to update to latest git version, just run this:
make maintainer-clean git pull
To build the source:
./autogen.sh ./configure # on most systems make
If you are building on Mac OS X, replace the ./configure command with:
./configure --libdir=/opt/local/lib --includedir=/opt/local/include # on MacOSX only
Your dfu-util binary will be inside the src folder. Use it from there, or install it to /usr/local/bin by running "sudo make install".
Windows binaries can be built in a MinGW environment, on a Windows computer or cross-hosted in another OS. To build it on a Debian or Ubuntu host, first install build dependencies:
sudo apt-get build-dep libusb-1.0-0 dfu-util sudo apt-get install mingw32
The below example builds dfu-util 0.8 and libusb 1.0.20 from unpacked release tarballs. If you instead build from git, you will have to run "./autogen.sh" before running the "./configure" steps.
mkdir -p build cd libusb-1.0.20 PKG_CONFIG_PATH=$PWD/../build/lib/pkgconfig ./configure \ --host=i586-mingw32msvc --prefix=$PWD/../build make make install cd .. cd dfu-util-0.8 PKG_CONFIG_PATH=$PWD/../build/lib/pkgconfig ./configure \ --host=i586-mingw32msvc --prefix=$PWD/../build make make install cd ..The build files will now be in build/bin.
cd libusb-1.0.20 ./configure --prefix=$HOME # MKDIR_P setting should not really be needed... make MKDIR_P="mkdir -p" make install cd .. cd dfu-util-0.8 ./configure USB_CFLAGS="-I$HOME/include/libusb-1.0" \ USB_LIBS="-L $HOME/lib -lusb-1.0" PKG_CONFIG=true make make install cd ..To link libusb statically into dfu-util.exe use instead of only "make":
make LDFLAGS=-staticThe built executables (and DLL) will now be under /usr/local/bin.