You might have noticed by now that some of external CODE memory locations that MCS BASIC-52 calls and uses are located around 2000H and some of the locations are located around 4000H. Specifically, they are as follows:
LOCATION FUNCTION
2001 H ON RESET, MCS BASIC-52 LOOKS FOR A 0AAH IN THIS LOCATION, IF
PRESENT, CALLS LOCATION 2090H
2002H MCS BASIC-52 EXAMINES THIS LOCATION TO SEE IF THE USER
WANTS TO IMPLEMENT THE COMMAND/STATEMENT EXTENSION OP-
TION, A 05AH IS TO BE PLACED IN THIS LOCATION TO EVOKE THE
COMMAND/EXTENSION OPTION
2048H MCS BASIC-52 CALLS THE LOCATION IF THE USER WANTS TO IMPLE-
MENT THE COMMAND/STATEMENT EXTENSION OPTION. THE USER
WILL USUALLY SET BIT 45 THEN RETURN.
2070H MCS BASIC-52 CALLS THIS LOCATION TO GET THE USER VECTOR TA-
BLE ADDRESS WHEN THE COMMAND/STATEMENT EXTENSION OP-
TION IS EVOKED. THE ADDRESS OF THE VECTOR TABLE IS PUT IN
THE DPTR BY THE USER.
2078H MCS BASIC-52 CALLS THIS LOCATION TO GET THE USER LOOKUP TA-
BLE ADDRESS WHEN THE COMMAND/STATEMENT EXTENSION OP-
TION IS EVOKED. THE ADDRESS OF THE LOOKUP TABLE IS PUT IN
THE DPTR BY THE USER.
2090H MCS BASIC-52 CALLS THIS LOCATION WHEN THE USER EVOKES THE
ASSEMBLY LANGUAGE RESET OPTION
4003H EXTERNAL INTERRUPT 0
400BH TIMER0 INTERRUPT
4013H EXTERNAL INTERRUPT 1
401BH TIMER1 INTERRUPT
4023H SERIAL PORT INTERRUPT
402BH TIMER 2 INTERRUPT
4030H USER CONSOLE OUTPUT
4033H USER CONSOLE INPUT
4036H USER CONSOLE STATUS
403CH USER PRINT@ OR LIST@ VECTOR
4100H-41FFH USER CALLS FROM 0 TO 7FH
Other vectors between 2040H and 2090H also exist, but they are mainly for testing purposes, but for your information they are:
LOCATION FUNCTION
2040H TRAP LOCATION FOR EXTERNAL INTERRUPT 0 IF BIT 26H OF INTER-
NAL RAM IS SET AND THE DMA OPTION IS EVOKED. PSW IS NOT
PUSHED ONTO STACK. INTERRUPTS OF COURSE, MUST BE ENA-
BLED. ALSO, THIS LOCATION WILL BE CALLED FOR CONSOLE OUT-
PUT IF BIT 2CH OF INTERNAL RAM IS SET.
2050H TRAP LOCATION FOR SERIAL PORT INTERRUPT IF BIT 1FH OF INTER-
NAL RAM IS SET. PSW IS PUSHED ONTO THE STACK.
2060H CALLED FOR CONSOLE INPUT IF BIT 32H OF INTERNAL RAM IS SET.
2068H CALLED FOR CONSOLE STATUS CHECK IF BIT 32H OF INTERNAL RAM
IS SET.
2088H TIMER1 INTERRUPT TRAP IF BIT 1AH OF INTERNAL RAM IS SET. PSW
IS PUSHED ONTO THE STACK.
Contrary to popular belief, these vectors were not chosen to force the user to buy bigger EPROMS. They are chosen so that addresses 2000H and 4000H can be overlayed and create no conflicts. The Overlayed addresses would appear as 2001H, 2002H, 4003H, 400BH, 4013H, 401BH, 4023H, 402BH, 4030H, 4033H, 4036H, 4039H, 2040H, 2048H, 2050H, 2060H, 2068H, 2070H, 2078H, 2088H, 2090H, and 4100H thru 41FFH. The diagram on the next page illustrates how to implement overlapping addresses for 2000H and 4000H. By using overlapping addresses, the user can implement all MCS BASIC-52 user expansion options with only a few hundred bytes of EPROM.
The reason this type of addressing scheme was chosen is that it permits the designer to offer custom versions of MCS BASIC-52, by using the vector locations in the 2000H region. And give the designers OEM the ability to take advantage of the I/O vectors located in the 4000H region.
As an added note, the MCS-51 instruction set is object relocatable on 2K boundaries if no LCALL or LJMP instructions are used. This means that it is possible for the designer to ORG a program for 2000H and actually execute the program at 2800H, 3000H, 3800H, etc. If the user does not use the LCALL or LJMP instructions.