Планирование сборки MIPS - PullRequest
0 голосов
/ 31 октября 2019

Мне нужно прочитать текстовый файл на ассемблере, а затем вычислить требования к планированию программ на языке ассемблера MIPS. Я могу прочитать файл, но не уверен, что смогу составить график требований MIPS. Я пишу свою программу в Java.

Я должен планировать на основе этого:

  1. Выбор инструкций (IF): получить инструкцию, указанную ПК, а затем обновить ПК, добавив 4к нему (поскольку все инструкции имеют длину 4 байта).
  2. Декодирование инструкции (ID): • Декодировать инструкцию. • Читайте регистры. • Выполнить проверку на равенство содержимого регистров. • Вычислить возможный целевой адрес ветвления, добавив смещение к инкрементному ПК. • Если проверка на равенство истинна и инструкция декодируется в инструкцию ветвления, загрузите целевой адрес ветвления в ПК. Обратите внимание, что все это может быть сделано параллельно, если результаты могут быть сохранены в независимых регистрах, и значительная часть из них может оказаться бесполезной работой, которая стоит энергии и требует аппаратного обеспечения, но не добавляет к необходимому времени.
  3. Выполнить (EX): • Для ссылки на память добавьте базовый регистр и смещение, чтобы создать эффективный адрес. • Для инструкции RR выполните операцию с содержимым, считанным из регистров. • Для инструкции RI выполните операцию с содержимым R1 и непосредственно.
  4. Память (MEM): • Если инструкция является нагрузкой, считайте с действующего адреса. • Если инструкция является магазином, пишите из регистра по фактическому адресу. 2
  5. Обратная запись (WB): • Для инструкции RR или RI запишите результаты обратно в регистр. • Для загрузки инструкции поместите содержимое выбранной памяти в регистр.

Вот мой код:

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.ArrayList;

public class Main {
    public static void main(String[] args) throws Exception {
        ArrayList<String> file = new ArrayList<String>();
        file = getAssembly(read(args[0]));
        for (int i = 0; i < file.size(); ++i) {
            System.out.println(file.get(i));
        }
    }

    public static ArrayList<String> read(String filepath) throws Exception {
        ArrayList<String> result = new ArrayList<String>();
        File file = new File(filepath);
        BufferedReader br = new BufferedReader(new FileReader(file));
        String st = "";
        while ((st = br.readLine()) != null) {
            result.add(st);
        }
        br.close();
        return result;
    }

    public static ArrayList<String> getAssembly(ArrayList<String> input){
        ArrayList<String> result = new ArrayList<String>();
        for (int i = 0; i < input.size(); ++i) {
            if (!input.get(i).contains(".") || input.get(i).contains("#") || input.get(i).contains("\t")) {
                result.add(input.get(i));
            }
        }
        return result;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...