联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Java编程Java编程

日期:2020-01-13 09:17

Hmk5: Running target code

Macau University of Science and Technology

2019 FAll

Purpose

We will write a program that works as a virtual machine that can process a sequence of instructions

of P-code. Instructions of P-code have been introduced in class, which are based on a stack. The

above picture is found from the internet,

Preparation

The file p-code.pdf lists the instructions of P-code.

The P-code Machine

The runtime environment of a P-code virtual machine (PVM) has 5 parts.

Code area: It is an array of P--code instructions.

PC: A special place in memory, which records the address of the next instruction to be executed.

By default, PC = PC + 1, after the current instruction is executed. A special case is a jumping

instruction: when the current is a jump instruction to some label, and the corresponding labeled

instruction is at address j, then PC will be changed to j.

Data area: It is an array. Each slot in the array is dedicated to a name (variable or label), in the

slot is the value of the name. For a variable, its value is an integer (assume ). For a label, its value

is an address (index in the code area).

Symbol table: It is a data structure that supports the following operations:

lookup(x) : Given a name (a string) return its address in the data area. If x does not exists,

some special signal is returned. The names include variable names and label names.

insert(x) : Allocate a new slot in the data area for the value of the name x (x is not

initialized at the moment). A simple way is that the address of the next available slot of the

data area is reserved for x, and the address of x should be registered in the symbol table so

that x can be looked up later.

When should insert(x) be called?

When a name x is used by an instruction (lod or lda), if x is new (lookup(x) cannot find it), x is

inserted into the symbol table. When a label instruction is executed, the label should be

inserted into the data area, and its address should be registered in the symbol table.

stack: A stack is needed by the P-code instructions. It is an array of integer.

A stack remembers:

the stack top, which is an index in the array, it is the address where the latest data item is

saved. Data are added or removed from the stack at the top. Initially, when the stack is

empty, the top could be a special value like -1.

The stack supports 2 operations:

pop() : When the stack is not empty, return the data (integer) at the top, and top = top 1.

When the stack is empty, nothing is popped, and some error message is printed out.

push(c) : When the stack is not full, top = top + 1, and c is saved at the top in the data

area. When the stack is already full, nothing is pushed, and some error message is printed.

Behavior of the PVM.

Given a P-code program. The PVM executable file should open the program and executes the

instructions one by one. The output of of the wri instruction should be be printed on the screen. A

P--code program will stop when there is no more instruction to run, or the halting instruction ( stp ) is

executed.

How to submit

Submit before Monday, January 6, 2020.

Attach all of your source code file. If you created some P-code files ( .p files) for testing, also

attached them. Please use a file readme.txt to describe your work, like the achievements and

problems of your work, and how to compile and run your code

At most three students can form a group to do the homework together and submit the homework

together with an email. If you can do the homework by yourself (a one-person group), it surely

will be fine.

Submit the homework by sending an email (to must_learn_c@126.com ) with attached program

files (together with the file of the grammar rules). The details of how to submit your homework is

in the file how_to_submit_homeworks.pdf .

References

1. Kenneth C. Louden. Compiler Construction Principles and Practice. PWS Publishing Company,

1997. ISBN 0-534-93972-4 http://www.cs.sjsu.edu/~louden/cmptext/.

2. Andrew W. Appel. Modern Compiler Implementation in C: Basic Techniques. Cambridge

University Press, New York, NY, USA, 1997.


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp