Chris Frantz | 79b4e40 | 2021-07-19 10:56:25 -0700 | [diff] [blame] | 1 | // Copyright lowRISC contributors. |
| 2 | // Licensed under the Apache License, Version 2.0, see LICENSE for details. |
| 3 | // SPDX-License-Identifier: Apache-2.0 |
| 4 | |
| 5 | use anyhow::Result; |
Jes B. Klinke | 3f05591 | 2022-02-11 10:49:35 -0800 | [diff] [blame^] | 6 | use crate::transport::verilator::{Options, Verilator}; |
| 7 | use crate::transport::Transport; |
Chris Frantz | 79b4e40 | 2021-07-19 10:56:25 -0700 | [diff] [blame] | 8 | use structopt::StructOpt; |
| 9 | |
| 10 | #[derive(Debug, StructOpt)] |
| 11 | pub struct VerilatorOpts { |
| 12 | #[structopt(long, default_value)] |
| 13 | verilator_bin: String, |
| 14 | |
| 15 | #[structopt(long, default_value)] |
| 16 | verilator_rom: String, |
| 17 | #[structopt(long, default_value)] |
| 18 | verilator_flash: String, |
| 19 | #[structopt(long, default_value)] |
| 20 | verilator_otp: String, |
| 21 | |
| 22 | #[structopt(long, required = false)] |
| 23 | verilator_args: Vec<String>, |
| 24 | } |
| 25 | |
| 26 | pub fn create(args: &VerilatorOpts) -> Result<Box<dyn Transport>> { |
| 27 | let options = Options { |
| 28 | executable: args.verilator_bin.clone(), |
| 29 | rom_image: args.verilator_rom.clone(), |
| 30 | flash_image: args.verilator_flash.clone(), |
| 31 | otp_image: args.verilator_otp.clone(), |
| 32 | extra_args: args.verilator_args.clone(), |
| 33 | }; |
| 34 | Ok(Box::new(Verilator::from_options(options)?)) |
| 35 | } |