Merge branch 'broccoli' into develop

This commit is contained in:
Edward Arthur Bingham 2024-06-05 16:51:53 -04:00
commit 5e20312750
2 changed files with 69 additions and 45 deletions

View File

@ -7,7 +7,9 @@ act - circuit design and digital simulation<br>
prspice - configure digital/analog circuit co-simulation<br> prspice - configure digital/analog circuit co-simulation<br>
Xyce - analog circuit simulation<br> Xyce - analog circuit simulation<br>
gaw - analog waveform viewer<br> gaw - analog waveform viewer<br>
klayout - circuit layout<br>
magic - circuit layout<br> magic - circuit layout<br>
OpenROAD - physical design<br>
Semiconductor PDKs are in /opt/cad/conf<br> Semiconductor PDKs are in /opt/cad/conf<br>
Packages may be installed with 'sudo apt install <package>'<br> Packages may be installed with 'sudo apt install <package>'<br>
@ -22,7 +24,7 @@ mkdir ~/tech; tar -xzvf sky130.tar.gz -C ~/tech
``` ```
Pull the docker image for the broccoli command line interface, and configure it. Pull the docker image for the broccoli command line interface, and configure it.
``` ```
docker pull public.ecr.aws/l5h5o6z4/broccoli-cli:latest docker pull broccolimicro/broccoli-cli:latest
git clone https://git.broccolimicro.io/Broccoli/broccoli-cli.git git clone https://git.broccolimicro.io/Broccoli/broccoli-cli.git
source broccoli-cli/bcli-develop.sh source broccoli-cli/bcli-develop.sh
export BCLI_TECH="$HOME/tech" export BCLI_TECH="$HOME/tech"
@ -57,6 +59,29 @@ bcli down
## Troubleshooting ## Troubleshooting
This script runs the docker container with the following commands:
```
# This produces a list of groups and their gids like so:
# 1000 nbingham
# 138 docker
# ...
MEMBERS="$(groups | sed 's/ /\n/g' | xargs -I{} getent group {} | sed 's/\([^:]*\):[^:]*:\([^:]*\):.*/\2 \1/g')"
docker run --rm -d --net=host \
-v $HOME:/host \
-v "${BCLI_TECH:-/opt/tech}:/opt/cad/conf" \
--name "bcli-$USER" \
-h "bcli-$USER" \
-e USER=$USER \
-e USER_ID=$(id -u) \
-e GROUP_ID=$(id -g) \
-e DISPLAY=$DISPLAY \
-e MEMBERS="$MEMBERS" \
-v "/tmp/.X11-unix:/tmp/.X11-unix:rw" \
broccolimicro/broccoli-cli:latest > /dev/null
```
There are multiple versions of docker, the one that seems to work best for this is `docker.io`. `docker-ce` seems to have trouble writing files in the container. There are multiple versions of docker, the one that seems to work best for this is `docker.io`. `docker-ce` seems to have trouble writing files in the container.
``` ```
sudo apt install docker.io sudo apt install docker.io

View File

@ -1,49 +1,48 @@
bcli() { bcli() {
if [ "$1" = "up" ]; then if [ "$1" = "up" ]; then
MEMBERS="$(groups | sed 's/ /\n/g' | xargs -I{} getent group {} | sed 's/\([^:]*\):[^:]*:\([^:]*\):.*/\2 \1/g')" MEMBERS="$(groups | sed 's/ /\n/g' | xargs -I{} getent group {} | sed 's/\([^:]*\):[^:]*:\([^:]*\):.*/\2 \1/g')"
docker run --rm -d --net=host -v $HOME:/host -v "${BCLI_TECH:-/opt/tech}:/opt/cad/conf" --name "bcli-$USER" -h "bcli-$USER" -e USER=$USER -e USER_ID=$(id -u) -e GROUP_ID=$(id -g) -e DISPLAY=$DISPLAY -e MEMBERS="$MEMBERS" -v "/tmp/.X11-unix:/tmp/.X11-unix:rw" public.ecr.aws/l5h5o6z4/broccoli-cli:latest > /dev/null docker run --rm -d --net=host -v $HOME:/host -v "${BCLI_TECH:-/opt/tech}:/opt/cad/conf" --name "bcli-$USER" -h "bcli-$USER" -e USER=$USER -e USER_ID=$(id -u) -e GROUP_ID=$(id -g) -e DISPLAY=$DISPLAY -e MEMBERS="$MEMBERS" -v "/tmp/.X11-unix:/tmp/.X11-unix:rw" broccolimicro/broccoli-cli:latest > /dev/null
#docker run --rm -d -v $HOME:/host -v "${BCLI_TECH:/opt/tech}:/opt/cad/conf" --name "bcli-$USER" -h "bcli-$USER" -e USER=$USER -e USER_ID=$(id -u) -e GROUP_ID=$(id -g) -e DISPLAY=$DISPLAY -v "/tmp/.X11-unix:/tmp/.X11-unix:rw" ${BCLI_IMAGE:-public.ecr.aws/l5h5o6z4/broccoli-cli:latest} > /dev/null echo "bcli-$USER started"
echo "bcli-$USER started" elif [ "$1" = "down" ]; then
elif [ "$1" = "down" ]; then docker stop "bcli-$USER" > /dev/null
docker stop "bcli-$USER" > /dev/null echo "bcli-$USER stopped"
echo "bcli-$USER stopped"
#legacy, or if server files change faster than a new download #legacy, or if server files change faster than a new download
elif [ "$1" = "mount" ]; then elif [ "$1" = "mount" ]; then
if [ -z "$BROCCOLI_USER" ]; then if [ -z "$2" ]; then
echo "Please set the BROCCOLI_USER environment variable for ssh access." echo "expected an ssh path to a tech directory (user@server:path/to/tech)."
else
mkdir -p $HOME/tech
sshfs $2 $HOME/tech/
fi
elif [ "$1" = "unmount" ]; then
shift
if [ "$1" = "-f" ]; then
pkill -KILL sshfs
fusermount -u $HOME/tech
else
umount $HOME/tech
fi
rmdir $HOME/tech
elif [ "$#" -eq 0 ]; then
WD="/host"
if [[ "$PWD" = "$HOME/"* ]]; then
WD="/host${PWD#$HOME}"
fi
XAUTH_TOKEN="$(xauth list | sed 's/^[^:]*/localhost/g' | sed 's/localhost: /localhost:0 /g')"
docker exec -u $(id -u) -e XAUTH_TOKEN="$XAUTH_TOKEN" -it "bcli-$USER" /bin/bash -c "echo \"$XAUTH_TOKEN\" | xargs -n 3 xauth add"
docker exec -u $(id -u) -w $WD -e DISPLAY=$DISPLAY -it "bcli-$USER" /bin/bash
else else
mkdir -p $HOME/tech if [ "$1" != "--help" ]; then
sshfs $BROCCOLI_USER@broccolimicro.io:/opt/tech $HOME/tech/ echo "error: unrecognized command '$1'"
fi echo ""
elif [ "$1" = "unmount" ]; then fi
shift
if [ "$1" = "-f" ]; then
pkill -KILL sshfs
fusermount -u $HOME/tech
else
umount $HOME/tech
fi
rmdir $HOME/tech
elif [ "$#" -eq 0 ]; then
WD="/host"
if [[ "$PWD" = "$HOME/"* ]]; then
WD="/host${PWD#$HOME}"
fi
XAUTH_TOKEN="$(xauth list | sed 's/^[^:]*/localhost/g' | sed 's/localhost: /localhost:0 /g')"
docker exec -u $(id -u) -e XAUTH_TOKEN="$XAUTH_TOKEN" -it "bcli-$USER" /bin/bash -c "echo \"$XAUTH_TOKEN\" | xargs -n 3 xauth add"
docker exec -u $(id -u) -w $WD -e DISPLAY=$DISPLAY -it "bcli-$USER" /bin/bash
else
if [ "$1" != "--help" ]; then
echo "error: unrecognized command '$1'"
echo ""
fi
echo "usage: bcli <command>" echo "usage: bcli <command>"
echo "If command is empty, then start a terminal logged into the toolset." echo "If command is empty, then start a terminal logged into the toolset."
echo " up - launch the toolset" echo " up - launch the toolset"
echo " down - shutdown the toolset" echo " down - shutdown the toolset"
echo " mount - legacy command; mount the technology files from broccolimicro.io" echo " mount - legacy command; mount the technology files from broccolimicro.io"
echo " unmount - legacy command; unmount the technology files" echo " unmount - legacy command; unmount the technology files"
echo " -f - legacy option; force the unmount if the connection has been broken" echo " -f - legacy option; force the unmount if the connection has been broken"
fi fi
} }