Received: by 10.223.185.116 with SMTP id b49csp5082788wrg; Tue, 27 Feb 2018 07:32:09 -0800 (PST) X-Google-Smtp-Source: AG47ELsNf1HIbYpDe1Yyp1hc7Y8mZCQS+VBacayRberKRvnrZ+FGujAZ1+2UkG5PT3xnBRi9ivzF X-Received: by 2002:a17:902:5984:: with SMTP id p4-v6mr10274389pli.38.1519745529414; Tue, 27 Feb 2018 07:32:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519745529; cv=none; d=google.com; s=arc-20160816; b=Z2GpQyYssZOTjqTGdmpuQjKlivEHB0JvjafrJisH4Rtkio5C3KFUsAsUzTA9pfAdOI BgBFeJrhq3ViczKWTKNqibMfpoa1eUAi1Cp25NZK1kJL/tFOGIIr5lDbdnoMiE9MwVd/ 2SKcANM1siKPsgc+fKvblNkZ8RZSkFWFMKKpHQqBojKm66YPkCumDTh/y7lx9YR3YToU 87AzuJ+z0lHlAbSZjbkOu2v3uMucK7UAZGV39P1jrgeXT6Zc3U7Offz+0/EcUK2YCH8Q a5NOmuDrjbOxt8qh+3BGTJV4b2KcC463PPpS9xK6fNRpH8VUkxq+3gDxo4rzMJwElVYe K+BA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=WGBqVPU8Eo3IEx6b1FMOnzEPAYs7/BhxuJlFgnIRAds=; b=01AF75ivUU6X7Jk7YbVuqavvAWe892xW/5St8xzJkPxvjjGiz6CDMrJpsOX0vOvnD1 8b26zIG7toSwRBQMvQKmgv27b+ziD8YOZirqJMXAYSO6cEMnLnjtt/VrE/cbyw3i4E1M a/CEZTs0Z8T/34rY0BF1ykGSb9F0S/ChTL0C/qUgw3tr5PXpdsKThM8wBcBsdduqL+K1 ywuGm/JAMTJlZCNFCC0Y5xobHCqc1JTVb6Aca0tp9QRiuNgt2EyguKjPycEZTDYt5l/l YyvvN1wM1W0qTsvxof/X4KXOcKFu4Dv1Ep34mlX0OFVvv59aSm2vlStwcBDYcShHKki4 fEsw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=iBgWCvwt; 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 1-v6si8784268plo.230.2018.02.27.07.31.55; Tue, 27 Feb 2018 07:32:09 -0800 (PST) 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=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=iBgWCvwt; 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 S1754136AbeB0PHA (ORCPT + 99 others); Tue, 27 Feb 2018 10:07:00 -0500 Received: from galahad.ideasonboard.com ([185.26.127.97]:33192 "EHLO galahad.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753996AbeB0PF7 (ORCPT ); Tue, 27 Feb 2018 10:05:59 -0500 Received: from localhost.localdomain (cpc89242-aztw30-2-0-cust488.18-1.cable.virginm.net [86.31.129.233]) by galahad.ideasonboard.com (Postfix) with ESMTPSA id D87C6203A0; Tue, 27 Feb 2018 16:04:05 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1519743846; bh=Nzt8jAQ883QtpV7suSLepSIg+RWKZMbxevAyR913l+U=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=iBgWCvwtYcFPELOKdEa4CW4SqLPawgsHbjuMx5KSSi+to03dc3WpRdx3iX1Qgi3d/ OI0JOaOv2uZqsaIeE8oDrAXijnLZhgly+ZSSH4mXkrol3eOjC1qgeMKf+pjEehR3G1 644YVaix/ZMxuHYU4fob9PJo+weY9nyEut3DwvLo= From: Kieran Bingham To: linux-renesas-soc@vger.kernel.org, linux-media@vger.kernel.org, Kieran Bingham Cc: niklas.soderlund@ragnatech.se, Mauro Carvalho Chehab , linux-kernel@vger.kernel.org (open list) Subject: [PATCH v2 2/3] media: i2c: adv748x: Add missing CBUS page Date: Tue, 27 Feb 2018 15:05:49 +0000 Message-Id: <1519743950-28346-3-git-send-email-kieran.bingham+renesas@ideasonboard.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1519743950-28346-1-git-send-email-kieran.bingham+renesas@ideasonboard.com> References: <1519743950-28346-1-git-send-email-kieran.bingham+renesas@ideasonboard.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Kieran Bingham The ADV748x has 12 pages mapped onto I2C addresses. In the existing implementation only 11 are mapped correctly in the page enumerations, which causes an off-by-one fault on pages above the infoframe definition due to a missing 'CBUS' page. This causes the address for the CEC, SDP, TXA, and TXB to be incorrectly programmed during the iterations in adv748x_initialise_clients(). Until now this has gone un-noticed due to the fact that following the creation of the clients - the device is reset and the addresses are reprogrammed in manually by the call to "adv748x_write_regs(state, adv748x_set_slave_address);" As part of moving to dynamic i2c address allocations repair this by providing the missing CBUS page definition. Signed-off-by: Kieran Bingham Reviewed-by: Niklas Söderlund --- v2 - Remove period from commit title. - Collect Niklas' RB tag. drivers/media/i2c/adv748x/adv748x-core.c | 3 +++ drivers/media/i2c/adv748x/adv748x.h | 2 ++ 2 files changed, 5 insertions(+) diff --git a/drivers/media/i2c/adv748x/adv748x-core.c b/drivers/media/i2c/adv748x/adv748x-core.c index faf73949962b..9dcaadaca217 100644 --- a/drivers/media/i2c/adv748x/adv748x-core.c +++ b/drivers/media/i2c/adv748x/adv748x-core.c @@ -52,6 +52,7 @@ static const struct regmap_config adv748x_regmap_cnf[] = { ADV748X_REGMAP_CONF("edid"), ADV748X_REGMAP_CONF("repeater"), ADV748X_REGMAP_CONF("infoframe"), + ADV748X_REGMAP_CONF("cbus"), ADV748X_REGMAP_CONF("cec"), ADV748X_REGMAP_CONF("sdp"), ADV748X_REGMAP_CONF("txa"), @@ -89,6 +90,7 @@ static int adv748x_i2c_addresses[ADV748X_PAGE_MAX] = { ADV748X_I2C_EDID, ADV748X_I2C_REPEATER, ADV748X_I2C_INFOFRAME, + ADV748X_I2C_CBUS, ADV748X_I2C_CEC, ADV748X_I2C_SDP, ADV748X_I2C_TXB, @@ -352,6 +354,7 @@ static const struct adv748x_reg_value adv748x_set_slave_address[] = { {ADV748X_PAGE_IO, 0xf6, ADV748X_I2C_EDID << 1}, {ADV748X_PAGE_IO, 0xf7, ADV748X_I2C_REPEATER << 1}, {ADV748X_PAGE_IO, 0xf8, ADV748X_I2C_INFOFRAME << 1}, + {ADV748X_PAGE_IO, 0xf9, ADV748X_I2C_CBUS << 1}, {ADV748X_PAGE_IO, 0xfa, ADV748X_I2C_CEC << 1}, {ADV748X_PAGE_IO, 0xfb, ADV748X_I2C_SDP << 1}, {ADV748X_PAGE_IO, 0xfc, ADV748X_I2C_TXB << 1}, diff --git a/drivers/media/i2c/adv748x/adv748x.h b/drivers/media/i2c/adv748x/adv748x.h index 6789e2f3bc8c..725662edc4b8 100644 --- a/drivers/media/i2c/adv748x/adv748x.h +++ b/drivers/media/i2c/adv748x/adv748x.h @@ -35,6 +35,7 @@ #define ADV748X_I2C_EDID 0x36 /* EDID Map */ #define ADV748X_I2C_REPEATER 0x32 /* HDMI RX Repeater Map */ #define ADV748X_I2C_INFOFRAME 0x31 /* HDMI RX InfoFrame Map */ +#define ADV748X_I2C_CBUS 0x30 /* CBUS MHL Map */ #define ADV748X_I2C_CEC 0x41 /* CEC Map */ #define ADV748X_I2C_SDP 0x79 /* SDP Map */ #define ADV748X_I2C_TXB 0x48 /* CSI-TXB Map */ @@ -48,6 +49,7 @@ enum adv748x_page { ADV748X_PAGE_EDID, ADV748X_PAGE_REPEATER, ADV748X_PAGE_INFOFRAME, + ADV748X_PAGE_CBUS, ADV748X_PAGE_CEC, ADV748X_PAGE_SDP, ADV748X_PAGE_TXB, -- 2.7.4