首页
网站开发
桌面应用
管理软件
微信开发
App开发
嵌入式软件
工具软件
数据采集与分析
其他
首页
>
> 详细
c/c++编程设计讲解、辅导data编程、辅导c++程序 辅导Python编程|辅导R语言程序
项目预算:
开发周期:
发布时间:
要求地区:
Week 22/24 Assessed Coursework
C/DEBUGGING
Deadline Friday Week 24 (14/5/21, 16:00)
In week 20, you worked on the task of implementing a C function which translates MIPS assembly
code into bytecode. You task for the SCC.150 week 24 coursework is to extend the code and
implement an exec_bytecode function, to complete your MIPS CPU emulator. The function should
read the bytecode generated by the make_bytecode function and stored in the integer array
text. Your program should unmarshal 32-bit instructions and modify appropriately the state of
the registers contained in the registers integer array and the pc global variable. Your
implementation should support the following instructions:
NOP - no operation, ADD - addition, ADDI – addition immediate ,
ANDI - bitwise immediate and, SRL - shift right logical, SLL - shift left logical,
BEQ - branch on equal, BNE - branch on not equal
Your implementation should manipulate the pc register value and emulate addresses in the text
memory area (0x00400000 – 0x1001000, start from address 0x00400000) and should provide a way
to terminate the execution of a program (e.g. nop instruction).
Important notes:
• Marks will be awarded only for the exec_bytecode function implementation and any new
functions that you will define/implement to improve code readability.
• You should use the update template, which can be found at
https://modules.lancaster.ac.uk/draftfile.php/465779/user/draft/55386476/emulator_w24.
zip to implement your solution, which contains a correct implementation of the
make_bytecode code.
Figure 1 Output of the MIPS emulator when running the Ethiopean multiplication algorithm with input the number 5 and 5.
Marking Scheme
Aspect Weighting
Functionality 60%
Code elegance, clarity, organization 30%
Self-marking 10%
Functionality
A+ Registers are handled correctly in all cases, there is a method to terminate the
program, the emulator executes correctly complex MIPS programs.
A The program can parse and execute branch instructions.
B I-type instructions are correctly parse and executed (addi, andi).
C R-type instructions are correctly parsed and executed (add, srl, sll).
D Program is read from the int array, a loop is implemented to execute the program
(program counter is used), code is executed based on instruction opcode and func
fields.
(*) This is an example of a marking scenario and marks are awarded proportionally for each
functionality. If you code only implements the addi and andi insutrctions and a simple loop, then you
will get a C.
Comments/clarity/organization
A Clear structure (and helpful comments) about variable use. Well commented
throughout. Spaced and organised for clarity. Appropriate use of function to organize
code.
B Good use of comments. Reasonable organisation, can follow program reasonably well.
Variable use is sensible.
C Sparse or sometimes unhelpful comments. Some consistency in use of variables.
D No comments. Difficult to read code.
Self-marking
A Clear and concise, functionality is accurate, comments reflect marking criteria
B List of mostly accurate grades, comments are there but not entirely clear or
unnecessarily long, or functionality grade is slightly off
C Just a list of grades, mostly accurate (or close) but no explanation
D Just a list of grades, inaccurate
软件开发、广告设计客服
QQ:99515681
邮箱:99515681@qq.com
工作时间:8:00-23:00
微信:codinghelp
热点项目
更多
代写dts207tc、sql编程语言代做
2024-12-25
cs209a代做、java程序设计代写
2024-12-25
cs305程序代做、代写python程序...
2024-12-25
代写csc1001、代做python设计程...
2024-12-24
代写practice test preparatio...
2024-12-24
代写bre2031 – environmental...
2024-12-24
代写ece5550: applied kalman ...
2024-12-24
代做conmgnt 7049 – measurem...
2024-12-24
代写ece3700j introduction to...
2024-12-24
代做adad9311 designing the e...
2024-12-24
代做comp5618 - applied cyber...
2024-12-24
代做ece5550: applied kalman ...
2024-12-24
代做cp1402 assignment - netw...
2024-12-24
热点标签
mktg2509
csci 2600
38170
lng302
csse3010
phas3226
77938
arch1162
engn4536/engn6536
acx5903
comp151101
phl245
cse12
comp9312
stat3016/6016
phas0038
comp2140
6qqmb312
xjco3011
rest0005
ematm0051
5qqmn219
lubs5062m
eee8155
cege0100
eap033
artd1109
mat246
etc3430
ecmm462
mis102
inft6800
ddes9903
comp6521
comp9517
comp3331/9331
comp4337
comp6008
comp9414
bu.231.790.81
man00150m
csb352h
math1041
eengm4100
isys1002
08
6057cem
mktg3504
mthm036
mtrx1701
mth3241
eeee3086
cmp-7038b
cmp-7000a
ints4010
econ2151
infs5710
fins5516
fin3309
fins5510
gsoe9340
math2007
math2036
soee5010
mark3088
infs3605
elec9714
comp2271
ma214
comp2211
infs3604
600426
sit254
acct3091
bbt405
msin0116
com107/com113
mark5826
sit120
comp9021
eco2101
eeen40700
cs253
ece3114
ecmm447
chns3000
math377
itd102
comp9444
comp(2041|9044)
econ0060
econ7230
mgt001371
ecs-323
cs6250
mgdi60012
mdia2012
comm221001
comm5000
ma1008
engl642
econ241
com333
math367
mis201
nbs-7041x
meek16104
econ2003
comm1190
mbas902
comp-1027
dpst1091
comp7315
eppd1033
m06
ee3025
msci231
bb113/bbs1063
fc709
comp3425
comp9417
econ42915
cb9101
math1102e
chme0017
fc307
mkt60104
5522usst
litr1-uc6201.200
ee1102
cosc2803
math39512
omp9727
int2067/int5051
bsb151
mgt253
fc021
babs2202
mis2002s
phya21
18-213
cege0012
mdia1002
math38032
mech5125
07
cisc102
mgx3110
cs240
11175
fin3020s
eco3420
ictten622
comp9727
cpt111
de114102d
mgm320h5s
bafi1019
math21112
efim20036
mn-3503
fins5568
110.807
bcpm000028
info6030
bma0092
bcpm0054
math20212
ce335
cs365
cenv6141
ftec5580
math2010
ec3450
comm1170
ecmt1010
csci-ua.0480-003
econ12-200
ib3960
ectb60h3f
cs247—assignment
tk3163
ics3u
ib3j80
comp20008
comp9334
eppd1063
acct2343
cct109
isys1055/3412
math350-real
math2014
eec180
stat141b
econ2101
msinm014/msing014/msing014b
fit2004
comp643
bu1002
cm2030
联系我们
- QQ: 9951568
© 2021
www.rj363.com
软件定制开发网!