Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix RiscV installation/uninstallation #107

Merged
merged 27 commits into from
Dec 23, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
0ae42f5
fix: 🐛 Fix typo
SergioGasquez Dec 22, 2022
1f8a04e
fix: 🐛 Fix riscv uninstallation
SergioGasquez Dec 22, 2022
e2c550f
fix: 🐛 Fix riscv uninstall logs
SergioGasquez Dec 22, 2022
caef1e1
chore: 🎨 Update RISC-V logs to make them consistent
SergioGasquez Dec 22, 2022
70049af
feat: ✨ Use both `imc` and `imac` target for RISC-V targets
SergioGasquez Dec 22, 2022
d63b549
refactor: ♻️ Initial async
SergioGasquez Dec 15, 2022
2ae93f8
refactor: ♻️ Use struct to store RiscV Target info so we can impl Ins…
SergioGasquez Dec 20, 2022
4717922
refactor: ⚡️ Use RiscVTarget constructor
SergioGasquez Dec 20, 2022
c9fbf03
chore: ✨ Initial attemp to paralelize installations
SergioGasquez Dec 20, 2022
8b2fcf9
feat: ✨ Spawn a task for every install
SergioGasquez Dec 21, 2022
b15b7bb
feat: ✨ Await only the len of to_install
SergioGasquez Dec 21, 2022
039d70e
fix: 🐛 Add llvm to to_install
SergioGasquez Dec 21, 2022
ec65811
feat: ✨ Paralelize gcc installation
SergioGasquez Dec 21, 2022
a301fad
fix: 🐛 Fix receiving
SergioGasquez Dec 22, 2022
b0b338e
fix: 🐛 Remove TODO
SergioGasquez Dec 22, 2022
26986b5
fix: 🐛 Remove stopwatch
SergioGasquez Dec 22, 2022
5a322c6
fix: 🐛 Fix Windows build
SergioGasquez Dec 22, 2022
6d16b3f
fix: 🐛 Fix riscv uninstallation
SergioGasquez Dec 22, 2022
d472f26
chore: 🎨 Update RISC-V logs to make them consistent
SergioGasquez Dec 22, 2022
da77129
fix: 🐛 Fix duplicated import
SergioGasquez Dec 23, 2022
adef0ba
feat: ✨ Use both `imc` and `imac` target for RISC-V targets
SergioGasquez Dec 23, 2022
2d837b8
chore: 🎨 Update RISC-V logs to make them consistent
SergioGasquez Dec 23, 2022
e1fc141
Merge branch 'main' into fix/riscv-uninstall
SergioGasquez Dec 23, 2022
3e729ed
fix: 🐛 Export variables even when reusing GCC installation
SergioGasquez Dec 23, 2022
212a384
fix: 🐛 Return result instead of unwrapping
SergioGasquez Dec 23, 2022
25cd4f2
fix: 🐛 Only install `riscv32-esp-elf` once
SergioGasquez Dec 23, 2022
c9306bd
fix: 🐛 Fix clippy
SergioGasquez Dec 23, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ pub enum Error {
WrongWindowsArguments,
#[diagnostic(code(espup::failed_to_remove_directory))]
#[error(
"{} Failed to remove '{0}' direcretory. Please, manually verify that the directory is properly removed and run 'espup uninstall' again.",
"{} Failed to remove '{0}' directory. Please, manually verify that the directory is properly removed and run 'espup uninstall' again.",
emoji::ERROR
)]
FailedToRemoveDirectory(String),
Expand Down
31 changes: 25 additions & 6 deletions src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ use espup::{
},
gcc::{get_toolchain_name, Gcc},
llvm::Llvm,
rust::{check_rust_installation, Crate, RiscVTarget, XtensaRust},
rust::{check_rust_installation, uninstall_riscv_target, Crate, RiscVTarget, XtensaRust},
Installable,
},
update::check_for_update,
Expand Down Expand Up @@ -194,7 +194,7 @@ async fn install(args: InstallOpts) -> Result<()> {

to_install.push(Box::new(llvm));

if targets.contains(&Target::ESP32C3) {
if targets.contains(&Target::ESP32C3) || targets.contains(&Target::ESP32C2) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe a nicer way of handling this (which could be done in a separate PR) would be to implement some helpers on Target to determine the architecture. As we continue to add support for addition devices we're going to keep needing to chain expressions with || here.

Maybe if we do something like this:

impl Target {
    pub fn riscv(&self) -> bool {
        !self.xtensa()
    }

    pub fn xtensa(&self) -> bool {
        matches!(self, Target::Esp32 | Target::Esp32s2 | Target::Esp32s3)
    }
}

We can then change this line (and the others like it) to something like this:

if targets.iter().any(|t| t.riscv()) {
    //
}

Just a thought, doesn't really matter right now but will likely clean things up in the future. If you don't like this idea then that is fine of course too 😁

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the idea! It would definitely things scale better! I will address this on a different PR though. I also plan to install RISC-V GCC toolchain (riscv32-esp-elf) for ESP32-S2 and ESP32-S3 for the ULP coprocessor.

let riscv_target = RiscVTarget::new(&args.nightly_version);
to_install.push(Box::new(riscv_target));
}
Expand All @@ -211,7 +211,14 @@ async fn install(args: InstallOpts) -> Result<()> {
};
} else {
for target in &targets {
let gcc = Gcc::new(target, &host_triple);
if target == &Target::ESP32 || target == &Target::ESP32S2 || target == &Target::ESP32S3
{
let gcc = Gcc::new(target, &host_triple);
to_install.push(Box::new(gcc));
}
}
if targets.contains(&Target::ESP32C3) || targets.contains(&Target::ESP32C2) {
let gcc = Gcc::new(&Target::ESP32C2, &host_triple);
to_install.push(Box::new(gcc));
}
}
Expand All @@ -223,20 +230,19 @@ async fn install(args: InstallOpts) -> Result<()> {
}

// With a list of applications to install, install them all in parallel.
let (tx, mut rx) = mpsc::channel::<Vec<String>>(32);
let (tx, mut rx) = mpsc::channel::<Result<Vec<String>, Error>>(32);
let installable_items = to_install.len();
for app in to_install {
let tx = tx.clone();
tokio::spawn(async move {
let res = app.install().await;
let res = res.unwrap();
tx.send(res).await.unwrap();
});
}

// Read the results of the install tasks as they complete.
for _ in 0..installable_items {
let names = rx.recv().await.unwrap();
let names = rx.recv().await.unwrap()?;
exports.extend(names);
}

Expand Down Expand Up @@ -302,6 +308,10 @@ async fn uninstall(args: UninstallOpts) -> Result<()> {
.map_err(|_| Error::FailedToRemoveDirectory(llvm_path.display().to_string()))?;
}

if config.targets.contains(&Target::ESP32C3) || config.targets.contains(&Target::ESP32C2) {
uninstall_riscv_target(&config.nightly_version)?;
}

if let Some(esp_idf_version) = config.esp_idf_version {
info!("{} Deleting ESP-IDF {}", emoji::WRENCH, esp_idf_version);
config.esp_idf_version = None;
Expand All @@ -322,6 +332,15 @@ async fn uninstall(args: UninstallOpts) -> Result<()> {
})?;
} else {
info!("{} Deleting GCC targets", emoji::WRENCH);
if config.targets.contains(&Target::ESP32C3) || config.targets.contains(&Target::ESP32C2) {
config.targets.remove(&Target::ESP32C3);
config.targets.remove(&Target::ESP32C2);
config.save()?;
// All RISC-V targets use the same GCC toolchain
let riscv_gcc_path = get_tool_path(&get_toolchain_name(&Target::ESP32C3));
remove_dir_all(&riscv_gcc_path)
.map_err(|_| Error::FailedToRemoveDirectory(riscv_gcc_path))?;
}
for target in &config.targets.clone() {
config.targets.remove(target);
config.save()?;
Expand Down
34 changes: 17 additions & 17 deletions src/toolchain/gcc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,24 +67,24 @@ impl Installable for Gcc {
emoji::WARN,
&gcc_path
);
return Ok(vec![]); // No exports
} else {
let gcc_file = format!(
"{}-gcc{}-{}-{}.{}",
self.toolchain_name,
self.version,
self.release,
get_arch(&self.host_triple).unwrap(),
extension
);
let gcc_dist_url = format!("{}/{}/{}", self.repository_url, self.release, gcc_file);
download_file(
gcc_dist_url,
&format!("{}.{}", &self.toolchain_name, extension),
&gcc_path,
true,
)
.await?;
}
let gcc_file = format!(
"{}-gcc{}-{}-{}.{}",
self.toolchain_name,
self.version,
self.release,
get_arch(&self.host_triple).unwrap(),
extension
);
let gcc_dist_url = format!("{}/{}/{}", self.repository_url, self.release, gcc_file);
download_file(
gcc_dist_url,
&format!("{}.{}", &self.toolchain_name, extension),
&gcc_path,
true,
)
.await?;
let mut exports: Vec<String> = Vec::new();

#[cfg(windows)]
Expand Down
20 changes: 19 additions & 1 deletion src/toolchain/rust.rs
Original file line number Diff line number Diff line change
Expand Up @@ -266,7 +266,7 @@ impl RiscVTarget {
#[async_trait]
impl Installable for RiscVTarget {
async fn install(&self) -> Result<Vec<String>, Error> {
info!("{} Installing RiscV target", emoji::WRENCH);
info!("{} Installing RISC-V target", emoji::WRENCH);
cmd!(
"rustup",
"component",
Expand All @@ -282,6 +282,7 @@ impl Installable for RiscVTarget {
"add",
"--toolchain",
&self.nightly_version,
"riscv32imc-unknown-none-elf",
"riscv32imac-unknown-none-elf"
)
.run()?;
Expand Down Expand Up @@ -429,6 +430,23 @@ fn install_rust_nightly(version: &str) -> Result<()> {
Ok(())
}

/// Uninstalls the RISC-V target.
pub fn uninstall_riscv_target(nightly_version: &str) -> Result<()> {
info!("{} Uninstalling RISC-V target", emoji::WRENCH);
cmd!(
"rustup",
"target",
"remove",
"--toolchain",
nightly_version,
"riscv32imc-unknown-none-elf",
"riscv32imac-unknown-none-elf"
SergioGasquez marked this conversation as resolved.
Show resolved Hide resolved
)
.run()
.into_diagnostic()?;
Ok(())
}

#[cfg(test)]
mod tests {
use crate::toolchain::rust::{Crate, XtensaRust};
Expand Down