 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			67 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 6a0ae67b699bef301e835b814a416067567ecd39 Mon Sep 17 00:00:00 2001
 | |
| From: Dave Stevenson <dave.stevenson@raspberrypi.com>
 | |
| Date: Wed, 3 Apr 2024 16:06:08 +0100
 | |
| Subject: [PATCH 1039/1085] media: bcm2835-unicam: Add option for a GPIO to
 | |
|  reflect FS/FE timing
 | |
| 
 | |
| The legacy stack had an option to have a GPIO track frame start and
 | |
| end events to give basic synchronisation to the incoming image stream.
 | |
| https://forums.raspberrypi.com/viewtopic.php?t=190314
 | |
| 
 | |
| Replicate this in the kernel Unicam driver.
 | |
| 
 | |
| Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com>
 | |
| ---
 | |
|  drivers/media/platform/bcm2835/bcm2835-unicam.c | 12 ++++++++++++
 | |
|  1 file changed, 12 insertions(+)
 | |
| 
 | |
| --- a/drivers/media/platform/bcm2835/bcm2835-unicam.c
 | |
| +++ b/drivers/media/platform/bcm2835/bcm2835-unicam.c
 | |
| @@ -49,6 +49,7 @@
 | |
|  #include <linux/device.h>
 | |
|  #include <linux/dma-mapping.h>
 | |
|  #include <linux/err.h>
 | |
| +#include <linux/gpio/consumer.h>
 | |
|  #include <linux/init.h>
 | |
|  #include <linux/interrupt.h>
 | |
|  #include <linux/io.h>
 | |
| @@ -543,6 +544,8 @@ struct unicam_device {
 | |
|  	struct v4l2_device v4l2_dev;
 | |
|  	struct media_device mdev;
 | |
|  
 | |
| +	struct gpio_desc *sync_gpio;
 | |
| +
 | |
|  	/* parent device */
 | |
|  	struct platform_device *pdev;
 | |
|  	/* subdevice async Notifier */
 | |
| @@ -943,6 +946,8 @@ static irqreturn_t unicam_isr(int irq, v
 | |
|  	if (fe) {
 | |
|  		bool inc_seq = unicam->frame_started;
 | |
|  
 | |
| +		if (unicam->sync_gpio)
 | |
| +			gpiod_set_value(unicam->sync_gpio, 0);
 | |
|  		/*
 | |
|  		 * Ensure we have swapped buffers already as we can't
 | |
|  		 * stop the peripheral. If no buffer is available, use a
 | |
| @@ -1003,6 +1008,10 @@ static irqreturn_t unicam_isr(int irq, v
 | |
|  		 * aka frame start.
 | |
|  		 */
 | |
|  		ts = ktime_get_ns();
 | |
| +
 | |
| +		if (unicam->sync_gpio)
 | |
| +			gpiod_set_value(unicam->sync_gpio, 1);
 | |
| +
 | |
|  		for (i = 0; i < ARRAY_SIZE(unicam->node); i++) {
 | |
|  			if (!unicam->node[i].streaming)
 | |
|  				continue;
 | |
| @@ -3407,6 +3416,9 @@ static int unicam_probe(struct platform_
 | |
|  		goto err_unicam_put;
 | |
|  	}
 | |
|  
 | |
| +	unicam->sync_gpio = devm_gpiod_get_optional(&pdev->dev, "sync",
 | |
| +						    GPIOD_OUT_LOW);
 | |
| +
 | |
|  	ret = platform_get_irq(pdev, 0);
 | |
|  	if (ret <= 0) {
 | |
|  		dev_err(&pdev->dev, "No IRQ resource\n");
 |