KnowledgeBase Archive

An Archive of Early Microsoft KnowledgeBase Articles

View on GitHub

Q80119: FIX: ALIGN Immediately After INCLUDE Generates L1101

Article: Q80119
Product(s): Microsoft Macro Assembler
Version(s): 6.0
Operating System(s): 
Keyword(s): 
Last Modified: 04-MAY-2001

-------------------------------------------------------------------------------
The information in this article applies to:

- Microsoft Macro Assembler (MASM), version 6.0 
-------------------------------------------------------------------------------

SYMPTOMS
========

The Microsoft Macro Assembler (MASM) version 6.0 generates an invalid object
module when given code that contains an INCLUDE directive followed immediately
by an ALIGN directive. The contents of the included file are not important; it
can even be an empty file. The linker may not issue a warning. If the linker
does detect the error, it generates the following:

  error L1101: invalid object module

RESOLUTION
==========

To work around this problem, place the INCLUDE directive at the beginning of the
file so that the ALIGN directive does not immediately follow the INCLUDE
directive.

STATUS
======

Microsoft has confirmed this to be a problem in MASM version 6.0. This problem
was corrected in MASM version 6.0a.

MORE INFORMATION
================

If you assemble the following sample code with /Zi, the linker will detect the
invalid object module and issue the error message. Without /Zi, no warning is
given and the program terminates normally, but the object module is still
invalid.

Sample Code
-----------

  ; Assemble options needed: none
  ; The file FILE.INC needs to be created, but may be left empty.

  _text   SEGMENT para public 'code'
          ASSUME  CS:_text

  start:  mov cx, 0100h
  INCLUDE FILE.INC
          ALIGN 4
  loopx:  mov ax, 4C00h
          int 21h

  _text   ENDS

  END     start

Additional query words: 6.00 buglist6.00 fixlist6.00a

======================================================================
Keywords          :  
Technology        : kbMASMsearch kbAudDeveloper kbMASM600
Version           : :6.0
Solution Type     : kbfix

=============================================================================

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.