项目实习(二)简单CISC模型机设计

2024-03-17 03:30

本文主要是介绍项目实习(二)简单CISC模型机设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大学期间开始的第二个项目实习,这次是利用Altera MAX+plus Ⅱ设计一个简单的CISC模型机,能实现计算机简单的逻辑运算功能。

设计选题

  1. 设计题目
    输入5个有符号整数(8位二进制补码表示),求最大负数的绝对值并输出显示。
  2. 开发环境
    Altera MAX+plus Ⅱ
  3. 设计完成的内容
    (1)完成系统的总体设计,画出模型机数据通路框图;
    (2)设计微程序控制器(CISC模型计算机)的逻辑结构框图;
    (3)设计机器指令格式和指令系统;
    (4)设计时序产生器电路;
    (5)设计所有机器指令的微程序流程图;
    (6)设计操作控制器单元;在CISC模型计算机中,设计的内容包括微指令格式(建议采用全水平型微指令)、微指令代码表(根据微程序流程图和微指令格式来设计)和微程序控制器硬件电路(包括地址转移逻辑电路、微地址寄存器、微命令寄存器和控制存储器等。具体电路根据微程序控制器的逻辑结构框图、微指令格式和微指令代码来设计)。
    (7)设计模型机的所有单元电路,并用VHDL语言(也可使用GDF文件----图形描述文件)对模型机中的各个部件进行编程,并使之成为一个统一的整体,即形成顶层电路或顶层文件;
    (8)由给出的题目和设计的指令系统编写相应的汇编语言源程序;
    (9)根据设计的指令格式,将汇编语言源程序手工转换成机器语言源程序,并将其设计到模型机中的ROM中去;
    (10)使用EDA软件进行功能仿真,要保证其结果满足题目的要求;(其中要利用EDA软件提供的波形编辑器,选择合适的输入输出信号及中间信号进行调试。)
    (11)器件编程,并在EDA实验平台上进行操作演示。
  4. 设计基本要求
    要求掌握CISC模型机的组成和工作原理(CISC模型机可以是任何计算机组成原理教材上的结构图),学会Altera MAX+plus Ⅱ或Quartus Ⅱ EDA软件的使用,能用EDA软件设计一个能完成一定功能的模型计算机,并通过功能仿真和在EDA实验平台上运行一个程序来验证模型机设计的正确性。

系统总体设计

  1. 设计模型机通路框图
    模型机通路框图
  2. 设计控制器的逻辑结构框图
    逻辑结构框图
  3. 设计机器指令格式和指令系统
    指令格式和指令系统
    说明:15-12位作为指令的操作码字段,11-10位属于源寄存器(Rs),而9-8位属于目的寄存器(Rd),7-0位后八位则是模型机立即数,采用定点整数补码表示。
    对Rs和Rd的规定:
    规定
    模型机规定数据的表示采用定点整数的补码形式表示,单字长为8位:
    数据规定
  4. 设计时序产生器电路
    T1,T2,T3,T4与CLR,Q之间的关系图:
    时序关系图
  5. 设计微程序流程图
    微程序流程图
  6. 设计操作控制器单元
    (1)设计微指令格式和微指令代码表
    CISC模型机系统使用的微指令采用全水平型微指令,字长为25位,其中微命令字段为17位,P字段为2位,后继微地址为6位,其格式如下:
    微指令格式
    微指令格式中的后继微地址从左到右以此为μA5,μA4,μA3,μA2,μA1和
    μA0。
    由微指令格式和微程序流程图编写的微指令代码表如下所示, 在微指令的代码表中微命令字段从左边到右代表的微命令信号依次为:LOAD、LDPC、LDAR、LDIR、LDRi、RD_B、RS_B、S1、S0、ALU_B、LDAC、LDDR、WR、CS、SW_B、LED_B、LDFR。
    微指令代码表1
    微指令代码表2
    (2)设计地址转移逻辑电路
    地址转移逻辑电路是根据微程序流程图中的棱形框部分及多个分支微地址,利用微地址寄存器的异步置“1”端,实现微地址的多路转移。由于是采用逻辑电路来实现的,故而称之为地址转移逻辑电路。在微地址流程图中,P(1)(高电平有效)测试时,根据指令的操作I7~I4强制修改后继地址的低四位;在P(2)(高电平有效)时,根据状态条件进行2路分支,并且都在T4内形成后继微指令的微地址。
    SE5=FS·P(2)·T4
    SE4=I7·P(1)·T4
    SE3=I6·P(1)·T4
    SE2=I5·P(1)·T4
    SE1=I4·P(1)·T4
  7. 设计嵌入式CISI模型计算机的顶层电路图

这篇关于项目实习(二)简单CISC模型机设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/eck_777/article/details/100848583
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/817661

相关文章

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

SpringBoot整合Sa-Token实现RBAC权限模型的过程解析

《SpringBoot整合Sa-Token实现RBAC权限模型的过程解析》:本文主要介绍SpringBoot整合Sa-Token实现RBAC权限模型的过程解析,本文给大家介绍的非常详细,对大家的学... 目录前言一、基础概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 环境准备二、表结

eclipse如何运行springboot项目

《eclipse如何运行springboot项目》:本文主要介绍eclipse如何运行springboot项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目js录当在eclipse启动spring boot项目时出现问题解决办法1.通过cmd命令行2.在ecl

SpringBoot项目Web拦截器使用的多种方式

《SpringBoot项目Web拦截器使用的多种方式》在SpringBoot应用中,Web拦截器(Interceptor)是一种用于在请求处理的不同阶段执行自定义逻辑的机制,下面给大家介绍Sprin... 目录一、实现 HandlerInterceptor 接口1、创建HandlerInterceptor实

Maven项目打包时添加本地Jar包的操作步骤

《Maven项目打包时添加本地Jar包的操作步骤》在Maven项目开发中,我们经常会遇到需要引入本地Jar包的场景,比如使用未发布到中央仓库的第三方库或者处理版本冲突的依赖项,本文将详细介绍如何通过M... 目录一、适用场景说明​二、核心操作命令​1. 命令格式解析​2. 实战案例演示​三、项目配置步骤​1

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen