Page 1 of 1

Size of address given with ORG in 16 bit mode

Posted: Tue Mar 18, 2014 11:40 am
by shahsunny712
I have been trying to figure out what is the size of the address that can be given with the ORG directive in 8086 (or real mode), since it is a 16-bit environment but 8086 can address 20-bit memory.

Is the address given with ORG supposed to be within the current segment ? NASM's documentation doesn't mention it. What will happen if I do give a 20 bit address ? (I tried this, but there were no assembler errors/warnings. Didn't try to run that though). Will the start/end nibble be truncated or will it be undefined behaviour ?

Re: Size of address given with ORG in 16 bit mode

Posted: Tue Mar 18, 2014 11:56 am
by iansjack
Why didn't you try to run the program?

Re: Size of address given with ORG in 16 bit mode

Posted: Tue Mar 18, 2014 3:50 pm
by madanra
You could try disassembling it with ndisasm to see what was actually produced. Running it is the most effective way of finding out what it does though :)

Re: Size of address given with ORG in 16 bit mode

Posted: Tue Mar 18, 2014 8:00 pm
by Bender
Is the address given with ORG supposed to be within the current segment ? NASM's documentation doesn't mention it.
The NASM Manual (Chapter 7) gives you this info.
7.1.1 ORG: Binary File Program Origin

The bin format provides an additional directive to the list given in chapter 6: ORG. The function of the ORG directive is to specify the origin address which NASM will assume the program begins at when it is loaded into memory.

For example, the following code will generate the longword 0x00000104:

org 0x100
dd label
label:
Unlike the ORG directive provided by MASM-compatible assemblers, which allows you to jump around in the object file and overwrite code you have already generated, NASM's ORG does exactly what the directive says: origin. Its sole function is to specify one offset which is added to all internal address references within the section; it does not permit any of the trickery that MASM's version does. See section 12.1.3 for further comments.
The ORG directive simply adds the number specified to all label references. And yes ORG specifies the offset within a segment.
I think the sane limit of ORG under 16-bit mode should be 64KB (0xFFFF).
BTW Run the program and see what happens, it's always good to run and see the result in front of your eyes. :)

Re: Size of address given with ORG in 16 bit mode

Posted: Tue Mar 18, 2014 8:55 pm
by linguofreak
shahsunny712 wrote:I have been trying to figure out what is the size of the address that can be given with the ORG directive in 8086 (or real mode), since it is a 16-bit environment but 8086 can address 20-bit memory.

Is the address given with ORG supposed to be within the current segment ? NASM's documentation doesn't mention it. What will happen if I do give a 20 bit address ? (I tried this, but there were no assembler errors/warnings. Didn't try to run that though). Will the start/end nibble be truncated or will it be undefined behaviour ?
In real mode you will never have a 20 bit address*. You will either have a straight 16 bit offset into an implied segment, or a segment:offset pair (32 bits total, 16 bits each for the segment and offset).

As others have mentioned, the NASM ORG directive is a 16-bit offset.

*Unless your program calculates that address itself from a segment:offset pair, and then converts it back to a segment:offset pair before using it.

Re: Size of address given with ORG in 16 bit mode

Posted: Wed Mar 19, 2014 1:56 am
by Antti
This problem is exactly something that should be solved before running the program. Are you all sure that running the program reliably shows the problem? Or could that be that it accidentally happens to work? Normal code does not rely on the ORG directive as much as one may think.

Analysing the assembler output is a better option unless the behavior can be verified by looking at the documentation.