Microsoft KB Archive/98314

= PRB: #pragma pack Can Generate Compiler Warnings =

Article ID: 98314

Article Last Modified on 7/5/2005

-

APPLIES TO


 * Microsoft Visual C++ 1.0 Professional Edition
 * Microsoft Visual C++ 1.5 Professional Edition
 * Microsoft Visual C++ 1.51
 * Microsoft Visual C++ 1.0 Professional Edition
 * Microsoft Visual C++ 2.0 Professional Edition
 * Microsoft Visual C++ 2.1
 * Microsoft Visual C++ 4.0 Standard Edition
 * Microsoft Visual C++ 4.1 Subscription
 * Microsoft Visual C++ 4.2 Professional Edition
 * Microsoft Visual C++ 5.0 Standard Edition
 * Microsoft Visual C++ 6.0 Service Pack 5

-



This article was previously published under Q98314





SYMPTOMS
When an application uses the pack pragma, C/C++ the compiler generates the following message:

warning C4103 used #pragma pack to change alignment

Microsoft Visual C++ 5.0 generates a different warning:

warning C4653: compiler option 'structure packing (/Zp)' inconsistent with precompiled header; current command-line option ignored



CAUSE
The pragma pack argument differs from the structure packing option specified on the compiler command line. This warning was added to the compiler because third-party tools can change the performance of user code by including a pragma pack message in library include files. The warning message is designed to indicate potential bugs in code under development.



RESOLUTION
If the code restores the pack argument to the structure packing option specified on the compiler command line, the warning does not occur. The sample code below demonstrates restoring the compiler default.



MORE INFORMATION
The pack pragma and the /Zp compiler option each pack data structures to a specified byte boundary. For example, if a structure requires 9 bytes of storage and the compiler command line includes the /Zp1 option or the code includes the #pragma pack(1) statement, the compiler reads and writes 9 bytes of information when it accesses the structure. If the compiler command line includes the /Zp2 option or the code includes the #pragma pack(2) statement, the compiler reads and writes 10 bytes when it accesses the structure.

Adding the /Zp option to the command line may generate a different warning if the PCH file is not updated after the change:

warning C4653: compiler option 'structure packing (/Zp)' inconsistent with precompiled header; current command-line option ignored

If the code includes the pack pragma, the compiler determines whether the /Zp option is specified, where  is 1 (the default when no number is specified), 2, 4, 8, or 16. If the compiler command line does not specify the /Zp option, the compiler packs structures on 2-, 4-, or 8-byte boundaries depending on the compiler version.

The compiler generates a warning if a header file changes the structure packing boundary and does not restore it to the value it before the end of the file.

Sample Code
/*
 * Compile options needed: /Zp2 or /Zp4

FILE.H --


 * 1) pragma pack(1)

// Remove the comment from the following line to eliminate this // warning: // #pragma pack

FILE.C --


 * 1) include &quot;file.h&quot;

void main(void) {}

Additional query words: 8.00 8.00c 9.00 9.10

Keywords: kbprb kbcompiler KB98314

-

[mailto:TECHNET@MICROSOFT.COM Send feedback to Microsoft]

© Microsoft Corporation. All rights reserved.