jmc@warwick.UUCP (02/11/87)
In porting UNIX V.3 onto a new chipset I discovered a curiosity in the 3b2 assembler/loader. .comm x,4 (instruction refering to x) has "4" in the displacement not 0 - the same as the "value" field, which distinguishes ".comm" from an undefined external. The loader subtracts the value field whatever it means from the relocated position. Everything ends up in the right place, unless you are naive enough (like me of course) to write your own assembler which puts "0" in the displacement. Then the undoctored loader ends up subtracting 4 from the address with unfortunate effects if you are trying to debug a sparkling new kernel! I cannot believe it is logically correct to treat the value field in this way although the two bug(?)s compensate. Note that an ordinary undefined goes in as 0. Any Comments? John Collins, Xi Software Ltd, ..... xisl!jmc