-
Notifications
You must be signed in to change notification settings - Fork 10
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
[build] Add script for Deeploy environment variables and Makefile info #5
base: main
Are you sure you want to change the base?
Conversation
Signed-off-by: Viviane <[email protected]>
Signed-off-by: Viviane <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey Viviane, thanks for your contribution.
I personally don't like sourcing bash scripts to set up the environment. Offering as an alternative is probably okay, though. In any case, please use the tool-specific path variables rather than DEEPLOY_INSTALL_DIR
export PULP_SDK_HOME=${DEEPLOY_INSTALL_DIR}/pulp-sdk | ||
export LLVM_INSTALL_DIR=${DEEPLOY_INSTALL_DIR}/llvm | ||
export PULP_RISCV_GCC_TOOLCHAIN= | ||
export MEMPOOL_HOME=${DEEPLOY_INSTALL_DIR}/mempool |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You shouldn't just set all these paths relative to DEEPLOY_INSTALL_DIR
. The Makefile is set up such that previous installations may be reused, and each tool gets its own DIR
variable.
@@ -72,12 +72,15 @@ echo-bash: | |||
@echo "TL/DR: add these lines to run ~/.bashrc" | |||
@echo "export PULP_SDK_HOME=${PULP_SDK_INSTALL_DIR}" | |||
@echo "export LLVM_INSTALL_DIR=${LLVM_INSTALL_DIR}" | |||
@echo "export PULP_RISCV_GCC_TOOLCHAIN=/PULP_SDK_IS_A_MESS" | |||
@echo "export PULP_RISCV_GCC_TOOLCHAIN=" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not completely remove this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The pulp-sdk needs the environment variable set afaik but @Scheremo could confirm.
I would prefer if the contents of the variable stay untouched 😏
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes but it gets set when you source the platform specific setup script in the PULP SDK. I am certain that PULP_SDK_IS_A_MESS
won't fix any problems 😉
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here is a diff of my environment with/without the PULP_RISCV_GCC_TOOLCHAIN environment variable:
46d45
< PULP_RISCV_GCC_TOOLCHAIN=/PULP_SDK_IS_A_MESS
59c58
< GAP_RISCV_GCC_TOOLCHAIN=/PULP_SDK_IS_A_MESS
---
> GAP_RISCV_GCC_TOOLCHAIN=
83c82
< PATH=/home/lmacan/Deeploy/install/pulp-sdk/tools/gapy:/home/lmacan/Deeploy/install/pulp-sdk/install/workstation/bin:/PULP_SDK_IS_A_MESS/bin:/home/lmacan/Deeploy/install/pulp-sdk/tools/bin:/home/lmacan/.local/bin:/home/lmacan/micromamba/condabin:/home/lmacan/.local/bin:/home/lmacan/.cargo/bin:/home/lmacan/.local/bin:/home/lmacan/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
---
> PATH=/home/lmacan/Deeploy/install/pulp-sdk/tools/gapy:/home/lmacan/Deeploy/install/pulp-sdk/install/workstation/bin:/bin:/home/lmacan/Deeploy/install/pulp-sdk/tools/bin:/home/lmacan/.local/bin:/home/lmacan/micromamba/condabin:/home/lmacan/.local/bin:/home/lmacan/.cargo/bin:/home/lmacan/.local/bin:/home/lmacan/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
The issue is that the pulp-sdk adds stuff into your PATH variable (that seems like fun 😃), specifically this part (the diff doesn't show it quite nicely so I cut just the scary piece):
+ /PULP_SDK_IS_A_MESS/bin
- /bin
Pulp-sdk basically adds /bin
into your path in front of your other search paths which might mess up your environment. I think this was the reason to put the "/PULP_SDK_IS_A_MESS" because it's a non-existant path and doesn't screw up your environment. Bonus points for a funny name.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is some deep PULP lore material here 😁
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
WTF, I guess I was wrong 😂 Fight fire with fire...
I thought this was just a rant, but it is actually a fix 😂
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Xeratec you underestimated pulp and Moritz, tsk tsk tsk
Ciao Viviane, I'd be happy to merge this PR once the feedback from Moritz and Philip is applied and the bash script is moved to the |
@viv-eth What is the status of that PR? Should I implement the requested changes? |
This PR introduces a new script (
deeploy.sh
) that sets up essential environment variables for the Deeploy project. TheMakefile
has been updated to reference this script, providing users an easy way to source environment variables directly fromdeeploy.sh
after setting up the PULP SDK.Changes:
deeploy.sh
script for defining paths to critical tools (LLVM, PULP SDK, QEMU, etc.)Makefile
to include instructions on sourcing thedeeploy.sh
script for proper environment configurationThis update simplifies the setup process by centralizing environment variables, reducing the need for manual configuration.