[PATCH v2 00/15] staging: vc04_services: bcm2835-isp support
Umang Jain
umang.jain at ideasonboard.com
Mon Nov 13 05:38:39 PST 2023
Hi Stefan,
On 11/10/23 4:02 PM, Stefan Wahren wrote:
> Hi Umang,
>
> Am 09.11.23 um 22:02 schrieb Umang Jain:
>> This series aims to upport bcm2835-isp from the RPi kernel.
>> It is developed on top of staging-next which comprises many
>> VC04 changes for it's de-staging. Hence, the merge of this
>> driver is targeted when VC04 is de-staged completely (which I
>> have been pushing), but it can be helped getting reviewed meanwhile.
>> Hence, the reason for posting the series.
>>
>> Patch (01-02)/15 adds a new driver named vc-sm-cma to handle memory
>> sharing
>> with the VC4 VPU.
>>
>> Patch 03/15 adds a small extension to videobuf2 to allow exporting as a
>> dma_buf instead of a file-descriptor.
>>
>> Patch (04-05)/15 adds a couple of improvements/support for
>> bcm2835-isp(event callback and zero-copy) to vchiq-mmal.
>>
>> Patch (06-10)/15 adds the core bcm2835-isp driver along with headers
>> and format defintions. 09/15 is a standalone patch which can be merged
>> independently I believe.
>>
>> Patch (11-12)/15 deals with the colorspace support.
>>
>> Patch 13/15 allows multiple instances of the ISP.
>>
>> Patch 14/15 adds a admin-guide document on bcm2835-isp.
>>
>> Patch 15/15 deals with driver registeration.
>
> since this is V2, i couldn't find a changelog? The first one was one
> year ago, so it's very hard to remember. In such a case a link to the
> last version is also helpful.
I am in your same situation. The changelog won't help here since the I
have too have lost count of the iterations.
In brief, I would say, the patches have further cleaned up and aligned,
rebased over the latest staging-next branch.
That majorly includes work I did for VC04 in general for de-staging.
>
> Recently i saw you have a Github account. For such a complex series it's
> also very helpful to provide a link to a working test branch with this
> series applied. It's not a must, but appreciated.
I actually was going to send test branch but at the last minute I
screwed up my .git repo because of a failed branch checkout.
I had to recreate the branches over the weekend and here they are:
I have tested these branches:
On RPi-3-b 32-bit:
Git branch:
https://git.uk.ideasonboard.com/uajain/linux/commits/branch/uajain/rpi3/staging-next/isp
On RPi-4-b 64-bit:
Git branch:
https://git.uk.ideasonboard.com/uajain/linux/commits/branch/uajain/rpi4/staging-next/isp
Both these branches have been tested with IMX219 sensor (there is a DT
overlay included) and libcamera. These branches have bcm2835-unicam with
streams support (which is handled by Laurent Pinchart as I believe) and
on top sits bcm2835-isp (this series).
You'll find DT and kernel configs I have tested with, in the respective
branches.
As far as libcamera branch goes (it requires a special branch due to
streams support):
https://git.uk.ideasonboard.com/uajain/libcamera/commits/branch/pinchartl/rpi/streams
Let me know how you get on if you are testing. I am happy to answer/help
if you decide to test this.
>
> Best regards
>
>>
>> Dave Stevenson (6):
>> staging: vc04_services: Add new vc-sm-cma driver
>> media: videobuf2: Allow exporting of a struct dmabuf
>> staging: mmal-vchiq: Add support for event callbacks
>> staging: mmal-vchiq: Use vc-sm-cma to support zero copy
>> staging: mmal_vchiq: Add image formats to be used by bcm2835-isp
>> uapi: bcm2835-isp: Add bcm2835-isp uapi header file
>>
>> David Plowman (2):
>> vc04_services: bcm2835-isp: Allow formats with different colour
>> spaces
>> vc04_services: bcm2835-isp: Permit all sRGB colour spaces on ISP
>> outputs
>>
>> Naushir Patuck (4):
>> media: uapi: v4l2-core: Add ISP statistics output V4L2 fourcc type
>> staging: vc04_services: bcm2835-isp: Add a more complex ISP
>> processing
>> component
>> staging: vc04_services: bcm2835_isp: Allow multiple users
>> docs: admin-guide: media: bcm2835-isp: Add documentation for
>> bcm2835-isp
>>
>> Umang Jain (3):
>> staging: vc04_services: vchiq_arm: Register vcsm-cma driver
>> staging: vc04_services: Add helpers for vchiq driver data
>> staging: vc04_services: vchiq: Register bcm2835-isp
>>
>> .../admin-guide/media/bcm2835-isp.rst | 127 ++
>> .../userspace-api/media/drivers/index.rst | 1 +
>> .../userspace-api/media/v4l/meta-formats.rst | 1 +
>> .../v4l/pixfmt-meta-bcm2835-isp-stats.rst | 32 +
>> MAINTAINERS | 9 +
>> .../media/common/videobuf2/videobuf2-core.c | 36 +-
>> drivers/media/v4l2-core/v4l2-ioctl.c | 1 +
>> drivers/staging/vc04_services/Kconfig | 4 +
>> drivers/staging/vc04_services/Makefile | 3 +-
>> .../staging/vc04_services/bcm2835-isp/Kconfig | 14 +
>> .../vc04_services/bcm2835-isp/Makefile | 4 +
>> .../bcm2835-isp/bcm2835-isp-ctrls.h | 72 +
>> .../bcm2835-isp/bcm2835-isp-fmts.h | 559 +++++
>> .../bcm2835-isp/bcm2835-v4l2-isp.c | 1822 +++++++++++++++++
>> .../interface/vchiq_arm/vchiq_arm.c | 6 +
>> .../interface/vchiq_arm/vchiq_bus.h | 10 +
>> .../staging/vc04_services/vc-sm-cma/Kconfig | 10 +
>> .../staging/vc04_services/vc-sm-cma/Makefile | 4 +
>> .../staging/vc04_services/vc-sm-cma/vc_sm.c | 817 ++++++++
>> .../staging/vc04_services/vc-sm-cma/vc_sm.h | 54 +
>> .../vc04_services/vc-sm-cma/vc_sm_cma_vchi.c | 507 +++++
>> .../vc04_services/vc-sm-cma/vc_sm_cma_vchi.h | 63 +
>> .../vc04_services/vc-sm-cma/vc_sm_defs.h | 187 ++
>> .../vc04_services/vc-sm-cma/vc_sm_knl.h | 28 +
>> .../staging/vc04_services/vchiq-mmal/Kconfig | 1 +
>> .../vc04_services/vchiq-mmal/mmal-common.h | 5 +
>> .../vc04_services/vchiq-mmal/mmal-encodings.h | 66 +
>> .../vc04_services/vchiq-mmal/mmal-msg.h | 35 +
>> .../vchiq-mmal/mmal-parameters.h | 165 +-
>> .../vc04_services/vchiq-mmal/mmal-vchiq.c | 253 ++-
>> .../vc04_services/vchiq-mmal/mmal-vchiq.h | 5 +
>> include/media/videobuf2-core.h | 15 +
>> include/uapi/linux/bcm2835-isp.h | 347 ++++
>> include/uapi/linux/v4l2-controls.h | 5 +
>> include/uapi/linux/videodev2.h | 1 +
>> 35 files changed, 5235 insertions(+), 34 deletions(-)
>> create mode 100644 Documentation/admin-guide/media/bcm2835-isp.rst
>> create mode 100644
>> Documentation/userspace-api/media/v4l/pixfmt-meta-bcm2835-isp-stats.rst
>> create mode 100644 drivers/staging/vc04_services/bcm2835-isp/Kconfig
>> create mode 100644 drivers/staging/vc04_services/bcm2835-isp/Makefile
>> create mode 100644
>> drivers/staging/vc04_services/bcm2835-isp/bcm2835-isp-ctrls.h
>> create mode 100644
>> drivers/staging/vc04_services/bcm2835-isp/bcm2835-isp-fmts.h
>> create mode 100644
>> drivers/staging/vc04_services/bcm2835-isp/bcm2835-v4l2-isp.c
>> create mode 100644 drivers/staging/vc04_services/vc-sm-cma/Kconfig
>> create mode 100644 drivers/staging/vc04_services/vc-sm-cma/Makefile
>> create mode 100644 drivers/staging/vc04_services/vc-sm-cma/vc_sm.c
>> create mode 100644 drivers/staging/vc04_services/vc-sm-cma/vc_sm.h
>> create mode 100644
>> drivers/staging/vc04_services/vc-sm-cma/vc_sm_cma_vchi.c
>> create mode 100644
>> drivers/staging/vc04_services/vc-sm-cma/vc_sm_cma_vchi.h
>> create mode 100644
>> drivers/staging/vc04_services/vc-sm-cma/vc_sm_defs.h
>> create mode 100644 drivers/staging/vc04_services/vc-sm-cma/vc_sm_knl.h
>> create mode 100644 include/uapi/linux/bcm2835-isp.h
>>
More information about the linux-arm-kernel
mailing list