blob: 9b8dc89c6b7af0c96cc90d6cea97dc9b88faa1db [file] [log] [blame]
// Copyright lowRISC contributors.
// Licensed under the Apache License, Version 2.0, see LICENSE for details.
// SPDX-License-Identifier: Apache-2.0
use anyhow::Result;
use structopt::StructOpt;
use thiserror::Error;
use opentitanlib::transport::{EmptyTransport, Transport};
pub mod verilator;
#[derive(Debug, StructOpt)]
pub struct BackendOpts {
#[structopt(long, default_value)]
interface: String,
#[structopt(flatten)]
verilator_opts: verilator::VerilatorOpts,
}
#[derive(Error, Debug)]
pub enum Error {
#[error("unknown interface {0}")]
UnknownInterface(String),
}
/// Creates the requested backend interface according to [`BackendOpts`].
pub fn create(args: &BackendOpts) -> Result<Box<dyn Transport>> {
match args.interface.as_str() {
"" => Ok(Box::new(EmptyTransport)),
"verilator" => verilator::create(&args.verilator_opts),
_ => Err(Error::UnknownInterface(args.interface.clone()).into()),
}
}