Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp3241878imm; Fri, 25 May 2018 02:10:40 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpebUZMaqpj3W/SbqjIzPncS/gnwl3NizQmViMIz5CHW2F8uQ603xhIXINLaO5AGyda52Ce X-Received: by 2002:a17:902:ac8d:: with SMTP id h13-v6mr1764479plr.338.1527239440808; Fri, 25 May 2018 02:10:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527239440; cv=none; d=google.com; s=arc-20160816; b=WIOgEnz8OruVyDipLSaUwkGqmQWsyMRG53ok9FQcbIx6mz8m0lPSBgvwbV7ncfc48j 5dkZDpgGah+fN9wDLdtahvT0Zgxg2Jt4AsO4iBBQxapmt2s4G9UDWTdyzIbT0fYf/7vN ScpRN4q3bERf5CmnT6iNOZBkJIYa0leUlwM/m63ZDZw+gfe507f/ej5u14/VssGxJLKY E07xo4YpD8De87sJPszHPrNAQNc4Ihxue4EOKAPM3AZyrleSDCLlQHUmaStsSEehFgNw CKVJT11tEM7mpwDJa/uF3bendsGIoHCisWiSqPnxtcLKNFPLuCljpueO5+NmIKzx3l+m Ybyw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=KY4eeNqyP7MvH+oA31JoZUEStMWcBDfSWYAUpVl/ThA=; b=vuVGY2WCMjr0sYSBDk2JDSZbfd/J0lzCZrPfT7AgQ5QMjbEZ6xsxygbqikwmLMl1qI Z7K3A2v6LyeU1KY/jHDp88odOz7VaQnbhMq4b/8rlyXyb51PTKIH2aqYu2LzWAYzMg26 YK3zHrBQg5B5SVh3m9x1wPYn4A0cUbMelpM8v/4MeASLh+SwsQtmkj6odBxU7E3DthVW TAd2Um/2q2PxYTrMH/3TpGSsirDaq020Vsh0BXnsCNO09r7wkX8riqgZz6pU3GSvfGyz ngQoNTFKCUfPoL45js8RuiiSpjZ5dK3E1ixFPjIQWdQPbHh3nAPpiYqW/F52ManKbmbU B3Cw== ARC-Authentication-Results: i=1; mx.google.com; dkim=temperror (no key for signature) header.i=@rainbow-software.org header.s=atlsmtp header.b=QB1hRrjZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b17-v6si2727974pgw.440.2018.05.25.02.10.25; Fri, 25 May 2018 02:10:40 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=temperror (no key for signature) header.i=@rainbow-software.org header.s=atlsmtp header.b=QB1hRrjZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965247AbeEYJIt (ORCPT + 99 others); Fri, 25 May 2018 05:08:49 -0400 Received: from smtp-1b.atlantis.sk ([80.94.52.26]:39261 "EHLO smtp-1b.atlantis.sk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S964960AbeEYJIr (ORCPT ); Fri, 25 May 2018 05:08:47 -0400 Received: from gsql.ggedos.sk (off-7.infotel.telecom.sk [212.5.213.7]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp-1b.atlantis.sk (Postfix) with ESMTPSA id C7E388346C4E; Fri, 25 May 2018 11:08:45 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=rainbow-software.org; s=atlsmtp; t=1527239325; bh=6BByyzO8p2pd6iLlMhlX3/94Yko90rOOoXdze4JZ5q0=; h=From:To:Cc:Subject:Date; b=QB1hRrjZa4gxTv+CXaR7uNl5ccZwgTrNvIcizOIPMNhU0LMO0yV8q0HxWvjoG2JAm rxBH/Al2fH2I3vcOZV/M5j4G1Tas9N0R1pNAexMqFDhUSdciUK7NU9s1rcrUbRB4qU gXGnXkU611IUSLryUR8chA5DNNmZQYGs8J4Hqijo= From: Ondrej Zary To: Hans Verkuil Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/3] gspca_zc3xx: Implement proper autogain and exposure control for OV7648 Date: Fri, 25 May 2018 11:08:41 +0200 Message-Id: <20180525090843.31735-1-linux@rainbow-software.org> X-Mailer: git-send-email 2.11.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The ZS0211 internal autogain causes pumping and flickering with OV7648 sensor on 0ac8:307b webcam. Implement OV7648 autogain and exposure control and use that instead. Signed-off-by: Ondrej Zary --- drivers/media/usb/gspca/zc3xx.c | 42 +++++++++++++++++++++++++++++++++-------- 1 file changed, 34 insertions(+), 8 deletions(-) diff --git a/drivers/media/usb/gspca/zc3xx.c b/drivers/media/usb/gspca/zc3xx.c index 25b4dbe8e049..992918b3ad0c 100644 --- a/drivers/media/usb/gspca/zc3xx.c +++ b/drivers/media/usb/gspca/zc3xx.c @@ -5778,16 +5778,34 @@ static void setcontrast(struct gspca_dev *gspca_dev, static s32 getexposure(struct gspca_dev *gspca_dev) { - return (i2c_read(gspca_dev, 0x25) << 9) - | (i2c_read(gspca_dev, 0x26) << 1) - | (i2c_read(gspca_dev, 0x27) >> 7); + struct sd *sd = (struct sd *) gspca_dev; + + switch (sd->sensor) { + case SENSOR_HV7131R: + return (i2c_read(gspca_dev, 0x25) << 9) + | (i2c_read(gspca_dev, 0x26) << 1) + | (i2c_read(gspca_dev, 0x27) >> 7); + case SENSOR_OV7620: + return i2c_read(gspca_dev, 0x10); + default: + return -1; + } } static void setexposure(struct gspca_dev *gspca_dev, s32 val) { - i2c_write(gspca_dev, 0x25, val >> 9, 0x00); - i2c_write(gspca_dev, 0x26, val >> 1, 0x00); - i2c_write(gspca_dev, 0x27, val << 7, 0x00); + struct sd *sd = (struct sd *) gspca_dev; + + switch (sd->sensor) { + case SENSOR_HV7131R: + i2c_write(gspca_dev, 0x25, val >> 9, 0x00); + i2c_write(gspca_dev, 0x26, val >> 1, 0x00); + i2c_write(gspca_dev, 0x27, val << 7, 0x00); + break; + case SENSOR_OV7620: + i2c_write(gspca_dev, 0x10, val, 0x00); + break; + } } static void setquality(struct gspca_dev *gspca_dev) @@ -5918,7 +5936,12 @@ static void setlightfreq(struct gspca_dev *gspca_dev, s32 val) static void setautogain(struct gspca_dev *gspca_dev, s32 val) { - reg_w(gspca_dev, val ? 0x42 : 0x02, 0x0180); + struct sd *sd = (struct sd *) gspca_dev; + + if (sd->sensor == SENSOR_OV7620) + i2c_write(gspca_dev, 0x13, val ? 0xa3 : 0x80, 0x00); + else + reg_w(gspca_dev, val ? 0x42 : 0x02, 0x0180); } /* @@ -6439,6 +6462,9 @@ static int sd_init_controls(struct gspca_dev *gspca_dev) if (sd->sensor == SENSOR_HV7131R) sd->exposure = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops, V4L2_CID_EXPOSURE, 0x30d, 0x493e, 1, 0x927); + else if (sd->sensor == SENSOR_OV7620) + sd->exposure = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops, + V4L2_CID_EXPOSURE, 0, 255, 1, 0x41); sd->autogain = v4l2_ctrl_new_std(hdl, &zcxx_ctrl_ops, V4L2_CID_AUTOGAIN, 0, 1, 1, 1); if (sd->sensor != SENSOR_OV7630C) @@ -6458,7 +6484,7 @@ static int sd_init_controls(struct gspca_dev *gspca_dev) return hdl->error; } v4l2_ctrl_cluster(3, &sd->gamma); - if (sd->sensor == SENSOR_HV7131R) + if (sd->sensor == SENSOR_HV7131R || sd->sensor == SENSOR_OV7620) v4l2_ctrl_auto_cluster(2, &sd->autogain, 0, true); return 0; } -- Ondrej Zary