-
Notifications
You must be signed in to change notification settings - Fork 88
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
Install overhaul #165
Install overhaul #165
Conversation
i like the idea 👍 cant wait to see this merged in! |
387defb
to
de214f5
Compare
Getting close to done with the overhaul: compiles and executes on both my Pi 3 and 4 with no hitches outside of the resource pinch on the 3. AA connection to the phone works over USB and Wireless (haven't tested wireless on the 3). The RPi autostart methods all work, system daemon and desktop icon assuming the default DE package I haven't tested the memory split or krnbt flags, they seem to be for even older boards than the 3. From here I need to test ofono/noise cancellation, then clean up and prettify parts that lack "echo" outputs and comments. |
dd63bb1
to
8a37462
Compare
This has hit a brick wall at 46% - (Pi 4 1GB) Went unresponsive for about 20min, and ticked over to 47% at which 762MB/907MB RAM utilization at this point, and has entered another period of unresponsiveness (for at least the last 7min). The main branch would only make it to ~650MB utilization before freezing. |
It has been tested on both physical and virtual. Few questions for you,
what OS are you using? What is the error you received if any when it
freezes? If there is no error, what is the last few lines of the install?
The installer was created and tested against Raspberry Pi OS 32-bit before
the 64-bit OS was released and on most models of the Rpi 3 and 4. I don't
recall anyone using a pi4 1gb so perhaps that is an issue as there was a
portion that was different per model which we tried to capture every model
# in use.
It isn't. So much of a surprise that the install failed as it does all the
time depending on the board model, OS, package changes in the repos of the
different os versions. There are many factors and we've dealt with them as
they come up.
Robert Crowley
…On Mon, Jun 10, 2024, 12:27 PM parad0xnasha ***@***.***> wrote:
This has hit a brick wall at 46% - (Pi 4 1GB) Went unresponsive for about
20min, and ticked over to 47% at which 762MB/907MB RAM utilization at this
point, and has entered another period of unresponsiveness (for at least the
last 7min). The main branch would only make it to ~650MB utilization before
freezing.
Was your testing performed on physical devices, or
dev-environment-emulators? (dev-emulation seems to be a rather exhaustive
workaround to compiling directly on the Pi).
I'm quite surprised that this issue took so long to be reported as an
actual problem that needed addressing. Willing to assist in any manner
possible in relation to this issue, if that would be of assistance.
—
Reply to this email directly, view it on GitHub
<#165 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/ABLUDVFX7JREOM3U2DZUPQTZGXHXHAVCNFSM6AAAAABHNJRFR2VHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDCNJYHAYTSNBSGM>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
Hello all, thanks for testing! To note, I have tested exclusively on Pi4 2GB and Pi3 1GB hardware with the same image (apart from an early VM test with 2GB RAM). I have a feeling the reason it's failing earlier on this branch is due to me raising the parallel make jobs ( I did find that raising swap space on the 1GB model to 1000M allowed it to finish the build, at the cost of long build time (over hour and a half on the Pi3 versus 25-30mins on Pi4 2GB). Without the extra memory, build would fail on the AASDK, qt-gstreamer, and Openauto builds, where qt-gstreamer seems to be the most resource intensive. A few more details here: #162 (comment). Also, wasn't aware they manufactured 1GB Pi4 models! The resource advisory at the start of the script filters out Pi4 and up, I need to remove that distinction so there's visibility on the memory requirements. |
Much appreciated for the extremely prompt reply. Since posting this, i went looking at various other implementations, and it seems that a Pi 4 2GB is the bare minimum as the "accepted norm". This would explain the behaviour i'm seeing - I think it's swapping to SD REALLY REALLY slowly. I have chugged along to 52% now... I'd suggest a hardware requirement be set with a higher RAM level, but you initially approached this problem getting 3B+'s which also have 1GB across the line. Knowing what i didn't know 24hrs ago, i'd purchase a Pi 4 4GB to approach this task. I'm going to purchase one, and happy to report back, but i suspect my SD-card is getting hammered to an inevitable demise! This is running latest Raspbian OS 64bit (Full desktop), and i did try the main branch with Raspbian Lite CLI also, which got me a little further than the GUI version. I feel like if i let this run for another 8hrs or so, I wouldn't be surprised if it does eventually complete. Just a matter of whether everything else stays running alongside it (it's continued to suffer repeated periods of non-responsiveness) - measured by the time on the clock - last update was 17min prior to current. |
For me, I always had trouble with adding the -j2 or -j4 so I always removed
it and just used the make command. It worked every time without specifying
that. It obviously took a longer time but I figured it was just my board
or something like that. Perhaps it's worth a try.
Robert Crowley
…On Mon, Jun 10, 2024, 1:02 PM Blazer the Lazer ***@***.***> wrote:
Hello all, thanks for testing! To note, I have tested exclusively on Pi4
2GB and Pi3 1GB hardware with the same image (apart from an early VM test
with 2GB RAM). I have a feeling the reason it's failing earlier on this
branch is due to me raising the parallel make jobs (-j4). We may still
need to lower this to -j2 for some packages.
I did find that raising swap space on the 1GB model to 1000M allowed it to
finish the build, at the cost of long build time (over hour and a half on
the Pi3 versus 25-30mins on Pi4 2GB). Without the extra memory, build would
fail on the AASDK, qt-gstreamer, and Openauto builds, where qt-gstreamer
seems to be the most resource intensive. A few more details here: #162
(comment)
<#162 (comment)>.
Also, wasn't aware they manufactured 1GB Pi4 models! The resource advisory
at the start of the script filters out Pi4 and up, I need to remove that
distinction so there's visibility on the memory requirements.
—
Reply to this email directly, view it on GitHub
<#165 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/ABLUDVDRCRCUV7E6PA4E6TLZGXL3TAVCNFSM6AAAAABHNJRFR2VHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDCNJYHA4DAMRVGI>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
For now i'll stick to the advice offered by the man himself, dropping the concurrent jobs AND increasing the swap space in order to at least get a feel for this dashboard solution, but i think the inevitable outcome would be using a 4GB Pi. I think you've checked off the box of PI integration issues now, and without seeing 1GB operating beside a 2GB/4GB, I can't say for certain, but it does seem that a minimum requirement suggestion be placed somewhere more prominent (not only as remnants of an issue that once upon a time on Github), but if it is indeed the case then it needs to be said loud enough to drown mention of lesser HW unless knowingly stepping into that arena, |
I've just learned that
😂 As a former user of said software, no comment. |
I assume this isn't very far from being merged into the openDsh/dash tree? Given the info learned, and potential hazards sufficiently handled |
8a37462
to
b4c9d31
Compare
It was so moving, it put you onto a course of developing your own free alternative... Wow, i must really be in for a treat hahah! Foolishly i purchased, so i'll give it a run, but it's unlikely to be the deployment choice. I should've dug deeper before making that terrible decision. |
Just pushed the branch here, it now excludes the -j flags except on AASDK as before. Will test it on my Pi3 real quick with the raised swap. I tested Ofono this weekend (was under the impression it was needed for Bluetooth HSF), and failing step is only for the noise cancellation module. Still need to write in the fix to insert the block into pulse config, and then write it into the uninstaller as well. |
6f0a7a0
to
19af5fc
Compare
have been following along, just wanted to say appreciate all the work youve been putting in 🙌 like the direction this is going in |
I'm glad I could help! Installer just needed a spruce-up, the core application works great. Making some last minute line and comment cleanups tonight as I test in a fast VM, I'll mark the PR as ready once it's done. It'll be tested on: |
I'll probably be testing on my Pi4 4gb.
Robert Crowley
…On Tue, Jun 11, 2024, 10:13 PM Blazer the Lazer ***@***.***> wrote:
I'm glad I could help! Installer just needed a spruce-up, the core
application works great. Making some last minute line and comment cleanups
tonight as I test in a fast VM, I'll mark the PR as ready once it's done.
It'll be tested on:
-Rpi4 2GB
-Ppi3 1GB+1GB swap
-Github Actions (Ubuntu 22.04)
-Base Ubuntu 22.04 Desktop VM (GNOME)
—
Reply to this email directly, view it on GitHub
<#165 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/ABLUDVFYE7XXU6BEOBXZXK3ZG6VDLAVCNFSM6AAAAABHNJRFR2VHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDCNRRHE3TCMJUHA>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
19af5fc
to
1139173
Compare
Decided to move many of the "Rpi" options into an autostart.sh, they also work fine on the default Ubuntu desktop. rpi.sh only contains options specific to these units now. The uninstaller should be safer and I eliminated usage of Confirmed thee three autostart options work well in Ubuntu, and just xinit for the Pi image (no need to install full DE). Huge push, but this should be the final one for now unless we come up with oddities in testing. 👍 |
1139173
to
0b51f09
Compare
Great work! I put my Pi back together on a fresh new dash fascia and will be testing it out today or tomorrow. |
Uh oh, so i'm not sure if it's my BT adapter, Bluez, Ofono, or Pulse: turns out enabling Noise Cancellation causes the system to drop Handsfree calls 3 out of 4 times. With just Before the setup overhaul, the noise cancellation step would fail due to shell permissions, so my system lacked that module all this time. My plan is to test picking and installing an older ofono version against the older pulseaudio (v12) to see if I can get both to work with no issues. If it's not clear, then I may consider commenting out the noise cancellation step until it's fixed. |
I was able to clone the repo last night and let it install with no changes
at all. Great work! I tested withPi4 2gb. I have a 4gb model as well and
can probably test that as well but I'm not sure when I'll get the time
until next week.
Robert Crowley
…On Thu, Jun 13, 2024, 11:54 PM Blazer the Lazer ***@***.***> wrote:
Uh oh, so i'm not sure if it's my BT adapter, Ofono, or Pulse: turns out
enabling Noise Cancellation causes the system to drop Handsfree calls 3 out
of 4 times.
With just the Ofono system in place, Handsfree works each time (and is
required), it's the noise cancellation module that seems to have trouble.
The times it does engage, there's no noticeable difference in call quality
(recordings to myself on google voice with the tiny car mic). I had only
tested it with two calls earlier this week on the road and got lucky.
Before the setup overhaul, the noise cancellation step would fail due to
shell permissions, so my system lacked that buggy module all this time.
My plan is to test picking and installing an older ofono version against
the older pulseaudio (v12) to see if I can get both to work with no issues.
If it's not clear, then I may consider commenting out the noise
cancellation step until it's fixed.
—
Reply to this email directly, view it on GitHub
<#165 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/ABLUDVAKBQFPVAREN4DBDJ3ZHJSN3AVCNFSM6AAAAABHNJRFR2VHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDCNRXGE3DCMZTGI>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
* Target Debian 12 and Ubuntu 22.04 * Address current build issues for aasdk and qt-gstreamer via patches * Advise on memory limit on <2GB build * Move all RPi helpers into their own file * Move all autostart helpers into their own file * Dependency folder cleanup, formatting and labels * Provide uninstall.sh to remove links and build dirs * Line up Github Actions/testing * Disable Ofono due to issues initiating calls on Bluetooth
0b51f09
to
186bb8f
Compare
One more small fix that I found today after driving on a fresh install: the xinit dependencies lacked The Ofono component is much more confusing. I was under the impression that it was required for specific bluetooth handsfree modes on the Pi, but it looks like Pulse+Bluez are handling this: When Ofono is enabled in pulse config, I get output in dmesg like I can completely remove Ofono from the system and still make/receive calls inside wireless AA, so maybe HSP isn't necessary. Anyone else equipped to test handsfree calling with Wireless AA? |
can't speak to ofono myself... if @icecube45 is around he might be able to say more about it 🙂 |
Didn't get an update from the user but #168 was closed working after reference to this branch. |
Great to see that report knocked right out 😁 I'm not privvy to the discussion on Slack, are there any suggestions from that side? The only thing that kept me from saying that this is 100% ready to go: fully inspecting the uninstall.sh output from more than just a glance, making sure it actually removes only what was installed from the build and doesn't touch anything else. Just checked, every built dependency seems to properly live in |
Weirdly yes I believe. Removing ofono from the system has fixed handsfree calling for people, so yes, it might be best to remove it by default. I have a Pi 5 for the first time and I'm working out some kinks but I will update with testing results if/when I have some. |
I also noticed this recent Wiki page highlight removing Ofono. It's settled then! Looking forward to the Pi 5 results |
I have some issues on the 5 that I believe are unrelated to the work in this branch. Install works well and I'm in favor of merge. |
I'm ready for merge too, if we missed something or there's an edge case, we can tackle it in a smaller PR. |
I don't have any powers here so all we can do is say @icecube45 three times in the mirror. |
I believe @rsjudka has merge permissions as well 😁 Thanks y'all! |
love to see it 🥲 |
Various improvements and restructuring of the install process. Targeting Ubuntu 22.04 and Debian 12 (Raspberry Pi OS 2024-03).
DONE:
Address known build issues by including patches from Add initial nix build support #156 (thanks!). Fixes Support for Ubuntu 22.04 #127
Identify exact RPi model, and advise remediation to prevent known OOM freeze on lower models. Fixes RasberryPi freezes during install #162.
Ensure system apt package deps are correct (especially gstreamer and Xorg). Should fix Blackscreen on installation on raspi-os lite #63 as well as automated Github Actions build/testing
Collect all software deps checked out by install.sh into the dash project folder (some of these were being checked out to $HOME like aasdk, h264bitstream, gstreamer). This helps keep things manageable and tidy.
Correct other script oddities (
sudo cat
failing whensudo tee
works fine)Move all RPi and autostart enhancements from install.sh and src/bash/*.sh to
rpi.sh
andautostart.sh
. Present usage at end of setup.Provide an uninstall.sh to reverse linked
make install
and remove build folders.Bonus idea:
Guide user through setting up wireless AA on RPi OS: nmcli and openauto.ini for hotspot, bluetoothctl and disable onboard BT via /boot/config.txt (This can be wiki page)
Prompt or instruct user to apply potential whitescreen fix (RTAudio /
OutputBackendType=1
in openauto.ini). Not sure if this can be done before first execution (also can be noted on wiki)Related issue (if applicable): fixes #
#63
#127
#162