Intel's standard library headers are disgusting and are committing the cardinal sin of defining macros which may interfere with user code (which in this case they have).
The problem is simple to repro:
#include <atomic>
#include <boost/shared_ptr.hpp>
int main() { }
Or:
#include <atomic>
#include <boost/thread.hpp>
int main() { }
This issue has been reported previously to Intel, but remains even in the latest version of the compiler (created and released well after the bug report):
I am using two patches locally, one for Boost.SmartPtr, and one for Boost.Thread.
The patches have been sent to the Boost developer mailing list, but I have not yet received a response. They are also on the Boost bug tracker as #6842 and #6843. They're pretty disgusting themselves, but at least compiling code using Boost on Intel C++ works now. At the very least they probably require a bit of extra wrapping to detect affected versions and configurations (e.g. v12 with C++0x mode).
I still get the feeling though that there is a better workaround, so if anyone has any ideas I'd love to hear them.