Library changes for Blender 4.2 #118455
Labels
No Label
Interest
Alembic
Interest
Animation & Rigging
Interest
Asset System
Interest
Audio
Interest
Automated Testing
Interest
Blender Asset Bundle
Interest
BlendFile
Interest
Collada
Interest
Compatibility
Interest
Compositing
Interest
Core
Interest
Cycles
Interest
Dependency Graph
Interest
Development Management
Interest
EEVEE
Interest
Freestyle
Interest
Geometry Nodes
Interest
Grease Pencil
Interest
ID Management
Interest
Images & Movies
Interest
Import Export
Interest
Line Art
Interest
Masking
Interest
Metal
Interest
Modeling
Interest
Modifiers
Interest
Motion Tracking
Interest
Nodes & Physics
Interest
OpenGL
Interest
Overlay
Interest
Overrides
Interest
Performance
Interest
Physics
Interest
Pipeline, Assets & IO
Interest
Platforms, Builds & Tests
Interest
Python API
Interest
Render & Cycles
Interest
Render Pipeline
Interest
Sculpt, Paint & Texture
Interest
Text Editor
Interest
Translations
Interest
Triaging
Interest
Undo
Interest
USD
Interest
User Interface
Interest
UV Editing
Interest
VFX & Video
Interest
Video Sequencer
Interest
Viewport & EEVEE
Interest
Virtual Reality
Interest
Vulkan
Interest
Wayland
Interest
Workbench
Interest: X11
Legacy
Asset Browser Project
Legacy
Blender 2.8 Project
Legacy
Milestone 1: Basic, Local Asset Browser
Legacy
OpenGL Error
Meta
Good First Issue
Meta
Papercut
Meta
Retrospective
Meta
Security
Module
Animation & Rigging
Module
Core
Module
Development Management
Module
Grease Pencil
Module
Modeling
Module
Nodes & Physics
Module
Pipeline, Assets & IO
Module
Platforms, Builds & Tests
Module
Python API
Module
Render & Cycles
Module
Sculpt, Paint & Texture
Module
Triaging
Module
User Interface
Module
VFX & Video
Module
Viewport & EEVEE
Platform
FreeBSD
Platform
Linux
Platform
macOS
Platform
Windows
Severity
High
Severity
Low
Severity
Normal
Severity
Unbreak Now!
Status
Archived
Status
Confirmed
Status
Duplicate
Status
Needs Info from Developers
Status
Needs Information from User
Status
Needs Triage
Status
Resolved
Type
Bug
Type
Design
Type
Known Issue
Type
Patch
Type
Report
Type
To Do
No Milestone
No project
No Assignees
12 Participants
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: blender/blender#118455
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Here is the list of all changes to our libraries for the Blender 4.2 release.
Note: now that we are in the LTS maintenance phase, the checklist has changed
To Do
Done 24-08-06
dfc341ab0b3b23
UpdateN/Ainstall_linux_packages
Done 24-07-08
880193d689
)install_linux_packages
script (N/A)Windows ARM64(n/a, Windows ARM64 does not yet ship with OpenPGL)install_linux_packages
scriptinstall_linux_packages
script (8501472c81
)e8fe320ea0
)install_linux_packages
script (8501472c81
)8db709e149
) (8082d92273
)install_linux_packages
script (8501472c81
)install_linux_packages
script (N/A)8db709e149
)install_linux_packages
script (8501472c81
)8db709e149
)install_linux_packages
script (N/A)install_linux_packages
script (N/A)d690b08c1f
-8fa578dcc2
-d8b3f852b9
)install_linux_packages
script (8501472c81
)d690b08c1f
-8fa578dcc2
-d8b3f852b9
)install_linux_packages
script (8501472c81
)d690b08c1f
-8fa578dcc2
-d8b3f852b9
)Windows ARM64(n/a Windows ARM64 does not use DPCPP)install_linux_packages
script (N/A)f510722a20
)install_linux_packages
script (N/A)3aa00e14e4
)install_linux_packages
script (N/A)bb4946135a
)install_linux_packages
script (N/A)bb4946135a
)install_linux_packages
script (N/A)bb4946135a
)install_linux_packages
script (N/A)bb4946135a
)install_linux_packages
script (N/A)Rejected
skipped 24.03 directly to 24.05
CC @farsthary @LazyDodo @ideasman42, you might want to subscribe to this issue.
The OpenPGL library update is not urgent at all, and may be more convenient to do after 4.1 is out.
is there a module ticket/request for libx265 support or is it more of a if we will add it, someone will integrate it?
edit:
I'm scripting it currently, given the origin of this request is unknown, i'll drop the questions over here:
x265 supports 8/10/12 bits bit depths, but you'll have to build the lib 3 times if you want all three, what do we want to do here? supporting 8/10/12 sounds like the most future proof way to go about it but it may bloat the final binary a tiny bit (guessing it'll come in well below 10MiB though, do note: guessing as i haven't done the work yet)
@LazyDodo There is a ticket to support high bit depth for videos #118493. Having x265 would improve interoperability. However, the resources for supporting new formats are a bit limited, and for the technical changes on Blender side h264/AV1 seems to be sufficient for developers to work.
So if you have time, having a compiled library will definitely be welcome and will help with moving forward, but if you don't have time then there is no rush with it.
@brecht Would you be interested in integrating an OIDN 2.3 beta release into Blender 4.2 alpha? I think this way we could catch and fix issues (e.g. HIP) much earlier than last time, and the upgrade to final OIDN 2.3 should be much smoother.
@aafra if there are changes in 2.3 that have some risk of causing system or platform specific issues, then it seems useful indeed to integrate the beta.
@brecht Yes, there will be such changes in 2.3. Thanks!
Brecht Van Lommel referenced this issue2024-05-02 18:48:30 +02:00
How would we feel about just bumping OpenImageIO to 2.5.11? It contains the mentioned patch from above as well as the one inside our
oiio_4044.diff
(so we can drop those 2). It also contains a few DDS related fix/improvements that might be good to have for LTS.fine with me, i may also want to bump libtiff/openexr to resolve to cve's probably best to do that in one go so we don't have to rebuild oiio over and over
Upgrading OIIO is fine with me.
I'll get that going
+1 for OIIO upgrade.
@brecht I just downloaded the latest 4.2 alpha build and I noticed that it's still built with OIDN 2.2.2 instead of 2.3.0-beta. This means that Blender users cannot test the new features and changes in OIDN 2.3.0, some of which are exposed through the Blender UI. The main reason why we released a beta version was to catch potential issues early in Blender, so we could fix them on time for the final release. Would it be still possible to upgrade now to 2.3.0-beta and then later upgrade again to final 2.3.0? Thanks!
@aafra Yes, it's taking longer than I expected to update the libraries. I think the platform maintainers have been rather busy, but it should happen in the next two weeks since this is usually done before the end of bcon2.
@brecht OK, thanks. And when should the upgrade to final OIDN 2.3.0 happen? Before the end of bcon3?
Preferably before the end of bcon2 (June 5). The end of bcon3 (July 10) is just 1 week before the release, so that's too late. Between that it's fuzzier, but I prefer not to bother platform maintainers with last minute updates if we can avoid it.
I'm not sure what to do then. It sounds like you would need the final 2.3.0 by the time you could upgrade to the beta, so there's no point upgrading to the beta at all. I was hoping we could get at least a couple of weeks of testing of the beta before moving forward with the final release but it seems this won't be possible.
The platform maintainers (@LazyDodo @farsthary @ideasman42) could upgrade e.g. tomorrow if they have time, but I can't speak for them. If they don't then indeed we won't be able to test the beta, sorry about that.
There must have been a miscommunication somewhere down the line, while my schedule was action packed, I wasn't aware OIDN wanted the update asap, and had the work scheduled with the rest of the lib updates (tail end of bcon2) .OIDN is pretty easy i could get it done today if need to be.
@LazyDodo The idea was to upgrade to the OIDN beta first, have a few weeks of testing, fix any potential issues, and then upgrade to the final version. Blender 4.2 final shouldn't be released with a beta version of OIDN.
@aafra On macOS there is an OIDN build error due to missing
#include <thread>
indevices/cpu/cpu_engine.h
. Adding that include makes the build pass. We can patch this locally for now, but would be good to fix.Since there were no test failures, I updated the windows x64 libs they should be in the next nightly build, sorry for the delay
Thanks! Strangely I cannot reproduce this on our machines but the include is indeed missing and will be fixed in the final version.
We'd need to upgrade DPC++ (5.2) and Embree (4.3.2) to get latest improvements and fixes, I've opened a PR for this here: #122242
I updated Windows ARM64 last week, but didn't update this issue - now updated
A heads up that there's likely a re-build necessary for OIIO due to a bug from the version we took: https://github.com/AcademySoftwareFoundation/OpenImageIO/issues/4298 (#123218)
I'll provide a patch on our side sometime soon. It will either revert the problematic change entirely or fix the issue.
There is the upgrade of OIDN from beta to final as well, I added it in the issue description.
Attached is the OpenImageIO diff that was reviewed and committed to fix the PSD file loading issue.
OIIO bug/PR: https://github.com/AcademySoftwareFoundation/OpenImageIO/issues/4298 / https://github.com/AcademySoftwareFoundation/OpenImageIO/pull/4302
It doesn't have the cmake changes though. @LazyDodo do you have those by chance since you were able to get me a build last week? There were no relevant changes since then.
I didn't keep them, blew them away when i had to do some oidn work, it's not much work, i'll integrate it for you
That OIIO patch has integrated in both 4.2 and main branches, and windows x64 libs have been updated, all other platforms still require a rebuild of oiio, top post has been updated to signify this.
Bumped Wayland libraries, as they're dynamically loaded it's mainly to avoid complications if we need to back-port fixes to 4.2 that depend on newer protocols/API's.
The only remaining changes are to update
install_linux_packages
- see version changes inbb4946135a
, CC @mont29.@ideasman42 thanks for the poke. We don't track Wayland versions currently in
install_linux_package
, just use whatever is available as dev packages. Updated the task.@Anthony-Roberts think we are only missing the rebuild for the patched OIIO on MacOS to be complete?
@mont29 MacOS? No idea
I can do an update for Windows ARM64 today, though
@Anthony-Roberts Woops sorry...
@farsthary poke, to rebuild OSX OIIO libraries? Or has it been done already? Then could update the task ;)
I'll rebuild all macos libs again today (x86 and arm) but it will take me some time since
space is limited for me I wipe the results after pushing.
and seems to have problems downloading the library sources
@farsthary I'll do the libraries update. Should be easier for me since we have dedicated machine here.
Due to my stupidity there's an OpenCollada bug that breaks import of animated things (#124859). To fix the issue, OpenCOLLADA needs to be updated to version
dfc341ab0b3b23
(commit) and all the platform libraries rebuilt and comitted. @LazyDodo said to just add a comment about all that here.Added a section for 4.2.1 updates with a check-list to track the progress.
We didn't ship 4.2 for WoA, but the library would need to be updated for 4.3 anyway, so the WoA is on the list.
@LazyDodo What would be the best process in your experience? Commit libraries to 4.3/main, and cherry-pick/copy-over to 4.2? Or commit to 4.2, and merge to 4.3/main?
Add it to the top under todo instead (moved it for you), no one wants to scroll 2 miles to see if there's work to be done, this is also the location release managers also check there to see if there's work still to be done, the person who puts the lack checkmark in, may move the work from the todo section to the
Done yy-mm-dd
section just below it, and fill in the actual date the work was completed.The workflow for LTS tickets is almost identical to the route a normal fix takes with some notable changes for scheduling purposes.
Backport for OpenCollada is in https://projects.blender.org/blender/blender/commit/af5ff37dd5f , so libs should/could be updated