GNOME Bugzilla – Bug 783417
Add physical memory allocator base class in badallocator
Last modified: 2018-11-03 14:09:13 UTC
These patch can provide a base framework of physical memory allocator which can be used in eg imx6 soc for vpu allocator or g2d allocator.
Created attachment 353161 [details] [review] Add physical memory allocator base class
Created attachment 353162 [details] [review] Add implement of interface "get_phys_addr" to support directviv upload
Review of attachment 353161 [details] [review]: ::: gst-libs/gst/allocators/gstallocatorphymem.h @@ +40,3 @@ + guint8 *caddr; + gsize size; + gpointer *user_data; This is all very specific to how things work on imx6. As such it should live in some imx6 specific library, probably just stay in the gstreamer-imx ( https://github.com/Freescale/gstreamer-imx/ ) repository and be installed as a library from there. The reason why I went with an interface instead of an actual allocator is that this is always going to be very platform specific, and there's probably not going to be much common functionality to share.
(In reply to Sebastian Dröge (slomo) from comment #3) > Review of attachment 353161 [details] [review] [review]: > > ::: gst-libs/gst/allocators/gstallocatorphymem.h > @@ +40,3 @@ > + guint8 *caddr; > + gsize size; > + gpointer *user_data; > > This is all very specific to how things work on imx6. As such it should live > in some imx6 specific library, probably just stay in the gstreamer-imx ( > https://github.com/Freescale/gstreamer-imx/ ) repository and be installed as > a library from there. The reason why I went with an interface instead of an > actual allocator is that this is always going to be very platform specific, > and there's probably not going to be much common functionality to share. It's not specific usage. This is an abstract class for phymem allocator, we derived some phymem allocator from this class such VPU allocator and g2d allocator. These two allocators are specific usage.
Those are all on imx6, so the same hardware in the end. Why would everything using some form of physical memory have 3 pointers, vaddr/paddr/caddr, and what do they mean? For the imx6 you also only have the virtual address and physical address, or also the 3rd? Generally the kernel should also be able to map between virtual and physical address, so having all in there could be redundant on other platforms.
-- GitLab Migration Automatic Message -- This bug has been migrated to freedesktop.org's GitLab instance and has been closed from further activity. You can subscribe and participate further through the new bug through this link to our GitLab instance: https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/issues/563.