-
Notifications
You must be signed in to change notification settings - Fork 4
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
Some fixes for building synApps on a fresh Ubuntu 22 successfully #6
Open
ibressler
wants to merge
12
commits into
EPICS-synApps:main
Choose a base branch
from
BAMresearch:pullrequest0
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
12 commits
Select commit
Hold shift + click to select a range
bce3090
get_repo(): remove duplicate code
ibressler 7d16e33
measComp needs to be installed as root
ibressler c250666
set EPICS_BASE in all modules to sth. reasonable
ibressler 3c390a6
let output and errors of final make release be visible
ibressler 987cd35
fixes for building Galil on Ubuntu 22 x86_64 successfully
ibressler 16b22b6
Using recent V3-6 of the Galil package
ibressler f12128d
reverting Galil version back to V3-5 for Windows compat.
ibressler 3f78db7
Github Action workflow for testing synApps build
ibressler 8024559
Switch to Galil V3-6 again
ibressler ae0ba18
Fix Galil build issues by creating RULES which forward to EPICS RULES
ibressler 53189e1
Fixes to Galil setup by the original author
ibressler 56fddaa
readme: added setup instructions
ibressler File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
name: build | ||
|
||
# Controls when the action will run. | ||
on: | ||
# Triggers the workflow on push or pull request events but only for the main branch | ||
push: | ||
branches: [main pullrequest0] | ||
pull_request: | ||
branches: [main] | ||
|
||
# Allows you to run this workflow manually from the Actions tab | ||
workflow_dispatch: | ||
|
||
jobs: | ||
build: | ||
# convert this to a matrix if builds differ between platforms | ||
runs-on: ${{ matrix.os }} | ||
strategy: | ||
matrix: | ||
os: ['ubuntu-latest'] | ||
steps: | ||
|
||
- name: Install required packages | ||
run: | | ||
sudo apt-get install -y git build-essential curl libusb-dev libusb-1.0-0-dev re2c x11proto-dev libx11-dev libxext-dev | ||
|
||
# get & build EPICS first | ||
- name: Restore cached EPICS | ||
id: cache-epics | ||
uses: actions/cache/restore@v4 | ||
with: | ||
path: epics-base | ||
key: ${{ runner.os }}-epics-base | ||
|
||
- name: Check out epics | ||
if: steps.cache-epics.outputs.cache-hit != 'true' | ||
uses: actions/checkout@v4 | ||
with: | ||
repository: epics-base/epics-base | ||
ref: '7.0' | ||
submodules: recursive | ||
path: epics-base | ||
|
||
- name: Build EPICS | ||
if: steps.cache-epics.outputs.cache-hit != 'true' | ||
run: | | ||
cd epics-base | ||
make distclean | ||
make | ||
|
||
- name: Cache EPICS | ||
uses: actions/cache/save@v4 | ||
with: | ||
path: epics-base | ||
key: ${{ steps.cache-epics.outputs.cache-primary-key }} | ||
|
||
- name: Check out assemble_synApps | ||
uses: actions/checkout@v4 | ||
with: | ||
path: assemble_synApps | ||
|
||
- name: Build synApps | ||
run: | | ||
./assemble_synApps/assemble_synApps --base="$(pwd)/epics-base" --dir="$(pwd)/synapps" 2>&1 | tee assemble.log | ||
cd synapps/support | ||
make 2>&1 | tee ../../make.log | ||
|
||
- name: Check Galil created files | ||
run: | | ||
cd synapps/support | ||
echo Listing all files in Galil-* directory | ||
find Galil-* -type f | ||
|
||
- name: Store logs as artifacts | ||
if: success() || failure() # always store the logs | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: build_logs | ||
path: | | ||
assemble.log | ||
make.log | ||
|
||
- name: Store build results as artifacts | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: synApps+epics | ||
path: | | ||
assemble_synApps | ||
epics-base | ||
synapps |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
What is requiring root access here? The point of line 585 is that 'make install' will install everything into its own directory. I just ran the script on Ubuntu 22 and there were no root requirements.
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.
When running this in a fresh system with a regular unprivileged user, it tries to install udev rules and modifying ld.so.cache.
Here, this first example is from the Github Action runner:
This happens after the permissions to udev are fixed:
To be sure, I removed sudo in my main branch and let it build as Github Action, the logs should be accessible for this job: https://github.com/BAMresearch/EPICS-synApps-assemble/actions/runs/8023437425/job/21919899065
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.
Edit: The build logs and artifacts are listed at the bottom of the summary of a build job, here: https://github.com/BAMresearch/EPICS-synApps-assemble/actions/runs/8023437425