From patchwork Thu Apr 2 18:34:27 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alex Riesen X-Patchwork-Id: 202511 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id EF5A8C43331 for ; Thu, 2 Apr 2020 18:48:00 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id CB001206E9 for ; Thu, 2 Apr 2020 18:48:00 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388658AbgDBSsA (ORCPT ); Thu, 2 Apr 2020 14:48:00 -0400 Received: from mout.kundenserver.de ([212.227.126.134]:58681 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387819AbgDBSr7 (ORCPT ); Thu, 2 Apr 2020 14:47:59 -0400 Received: from mail.cetitecgmbh.com ([87.190.42.90]) by mrelayeu.kundenserver.de (mreue010 [212.227.15.167]) with ESMTPSA (Nemesis) id 1N1fzM-1jDev00EVk-011ziZ for ; Thu, 02 Apr 2020 20:47:58 +0200 Received: from pflvmailgateway.corp.cetitec.com (unknown [127.0.0.1]) by mail.cetitecgmbh.com (Postfix) with ESMTP id CF305650525 for ; Thu, 2 Apr 2020 18:47:57 +0000 (UTC) X-Virus-Scanned: amavisd-new at cetitec.com Received: from mail.cetitecgmbh.com ([127.0.0.1]) by pflvmailgateway.corp.cetitec.com (pflvmailgateway.corp.cetitec.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id dlFIptyuThon for ; Thu, 2 Apr 2020 20:47:57 +0200 (CEST) Received: from pfwsexchange.corp.cetitec.com (unknown [10.10.1.99]) by mail.cetitecgmbh.com (Postfix) with ESMTPS id 7415964E968 for ; Thu, 2 Apr 2020 20:47:57 +0200 (CEST) Received: from pflmari.corp.cetitec.com (10.8.5.12) by PFWSEXCHANGE.corp.cetitec.com (10.10.1.99) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Thu, 2 Apr 2020 20:47:57 +0200 Received: by pflmari.corp.cetitec.com (Postfix, from userid 1000) id E554580501; Thu, 2 Apr 2020 20:34:27 +0200 (CEST) Date: Thu, 2 Apr 2020 20:34:27 +0200 From: Alex Riesen To: Kieran Bingham CC: Geert Uytterhoeven , Mauro Carvalho Chehab , Hans Verkuil , "Laurent Pinchart" , Rob Herring , Mark Rutland , Kuninori Morimoto , , , , , Subject: [PATCH v5 4/9] media: adv748x: add definitions for audio output related registers Message-ID: <26573ecdb48aa816f802b9d8bbe5f74157248021.1585852001.git.alexander.riesen@cetitec.com> Mail-Followup-To: Alex Riesen , Kieran Bingham , Geert Uytterhoeven , Mauro Carvalho Chehab , Hans Verkuil , Laurent Pinchart , Rob Herring , Mark Rutland , Kuninori Morimoto , devel@driverdev.osuosl.org, linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, linux-renesas-soc@vger.kernel.org References: MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: X-Originating-IP: [10.8.5.12] X-ClientProxiedBy: PFWSEXCHANGE.corp.cetitec.com (10.10.1.99) To PFWSEXCHANGE.corp.cetitec.com (10.10.1.99) X-EsetResult: clean, is OK X-EsetId: 37303A290D7F536A6C7266 X-Provags-ID: V03:K1:yhEc8oTgCJhXSjxps0cMs2zuE1EXk49krcKESmkgfeWhxoSNOvx nRHdBGrhklKvXinZJdusczt/4saPMR3A7zPVTMaBSiMG+SxYf+eyy+uzlzZz3BdQU5y7lwB 7hC4WgAHqVhAsP25zG70rVrbtDo/vW3Rna16whILCVqmypJaAlGtDFct7iy0rMoGWR2zRkO nfheHcqQuAbDSAaWg/WuA== X-UI-Out-Filterresults: notjunk:1; V03:K0:qMpwwVE6TPA=:RQZR/kxzLllmfayO3Y53Lv RIza1XuSGcPfhZjrg9yJq16csBu/KOkU9F3XVQb5HBd9auvdVALHpmS+8BIO40nyoal5mJ55F WJKXtD/eVHmJIw3ngeylmyg4S8yV3Km5zbQizMyDid1HdIzYp/ihEdN+5WGXVU/7tQtO9mvVF sAmJ6yyIx8neYsfIGjMRSbIUDBSqCPPtUX0P2xw2MsFYyWliZlNCsAwVLuvYAwwoUXJO2jWp/ k2q7wTUwg0QHZEWe26R7tnrqFBLexIDzaN7N1OCq4qxw9iyyIu6l0DWue6FZynDvK9/APKF8b JCYIPNZZwsUXrw88+h/4Yr+Ese3SIT+OtD6udVVwIVqXSzXmBOSwWwHbt4ifPqRB/SWwejTjp pCnPDQsK8+f29g4QtbGjeo3Jvu1YHXsiXOMT69Imk2SJpZGcrDrnsPskrnYLcHVXO0STgpBoo Ha73ZxxHlGVd6G8WoUfI3hBqeHgNZbo4B+NfvmhDA2KSG0mPrH5nHSb1Vxmb4QNslUX6LrIrN c4nBdK+T55GF9iGfAssvoNEb5q9qM5bQlAAJgAyJQpmot4sk+exZUOZ8t2kBtAcGJKXGJ5qoF k6vFXlbCAllFSauL42sqq5Z3EhbRhPlSuQzBb91i9GEZxJvszG5KFYcey1WPLJFDxcn0Yjx+o yRVTs76Nncqe2VJOFsQOI524XtSHXYLdRfAwOQhRfW2O3dJ1P7BqZdYl/HNjU3t+i/KlcRmfk UeWwaB5uwQV4Tur7i0sGhcUHW4Ek1Jc7u4d2JpxAfmjyRitkXUMmvkSmunFGZ/fE9XJGLT/xz 4W8Jg6jC2cuhHI+VfP/2mi9pWThBol+r2i0X2p1CcCVj6YbAt6kc/L/5DbU3ge2BOkT+hkm Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Signed-off-by: Alexander Riesen --- drivers/media/i2c/adv748x/adv748x.h | 32 +++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/drivers/media/i2c/adv748x/adv748x.h b/drivers/media/i2c/adv748x/adv748x.h index 0a9d78c2870b..1a1ea70086c6 100644 --- a/drivers/media/i2c/adv748x/adv748x.h +++ b/drivers/media/i2c/adv748x/adv748x.h @@ -226,6 +226,11 @@ struct adv748x_state { #define ADV748X_IO_VID_STD 0x05 +#define ADV748X_IO_PAD_CONTROLS 0x0e +#define ADV748X_IO_PAD_CONTROLS_TRI_AUD BIT(5) +#define ADV748X_IO_PAD_CONTROLS_PDN_AUD BIT(1) +#define ADV748X_IO_PAD_CONTROLS1 0x1d + #define ADV748X_IO_10 0x10 /* io_reg_10 */ #define ADV748X_IO_10_CSI4_EN BIT(7) #define ADV748X_IO_10_CSI1_EN BIT(6) @@ -248,7 +253,21 @@ struct adv748x_state { #define ADV748X_IO_REG_FF 0xff #define ADV748X_IO_REG_FF_MAIN_RESET 0xff +/* DPLL Map */ +#define ADV748X_DPLL_MCLK_FS 0xb5 +#define ADV748X_DPLL_MCLK_FS_N_MASK GENMASK(2, 0) + /* HDMI RX Map */ +#define ADV748X_HDMI_I2S 0x03 /* I2S mode and width */ +#define ADV748X_HDMI_I2SBITWIDTH_MASK GENMASK(4, 0) +#define ADV748X_HDMI_I2SOUTMODE_SHIFT 5 +#define ADV748X_HDMI_I2SOUTMODE_MASK \ + GENMASK(6, ADV748X_HDMI_I2SOUTMODE_SHIFT) +#define ADV748X_I2SOUTMODE_I2S 0 +#define ADV748X_I2SOUTMODE_RIGHT_J 1 +#define ADV748X_I2SOUTMODE_LEFT_J 2 +#define ADV748X_I2SOUTMODE_SPDIF 3 + #define ADV748X_HDMI_LW1 0x07 /* line width_1 */ #define ADV748X_HDMI_LW1_VERT_FILTER BIT(7) #define ADV748X_HDMI_LW1_DE_REGEN BIT(5) @@ -260,6 +279,16 @@ struct adv748x_state { #define ADV748X_HDMI_F1H1 0x0b /* field1 height_1 */ #define ADV748X_HDMI_F1H1_INTERLACED BIT(5) +#define ADV748X_HDMI_MUTE_CTRL 0x1a +#define ADV748X_HDMI_MUTE_CTRL_MUTE_AUDIO BIT(4) +#define ADV748X_HDMI_MUTE_CTRL_WAIT_UNMUTE_MASK GENMASK(3, 1) +#define ADV748X_HDMI_MUTE_CTRL_NOT_AUTO_UNMUTE BIT(0) + +#define ADV748X_HDMI_AUDIO_MUTE_SPEED 0x0f +#define ADV748X_HDMI_AUDIO_MUTE_SPEED_MASK GENMASK(4, 0) +#define ADV748X_MAN_AUDIO_DL_BYPASS BIT(7) +#define ADV748X_AUDIO_DELAY_LINE_BYPASS BIT(6) + #define ADV748X_HDMI_HFRONT_PORCH 0x20 /* hsync_front_porch_1 */ #define ADV748X_HDMI_HFRONT_PORCH_MASK 0x1fff @@ -281,6 +310,9 @@ struct adv748x_state { #define ADV748X_HDMI_TMDS_1 0x51 /* hdmi_reg_51 */ #define ADV748X_HDMI_TMDS_2 0x52 /* hdmi_reg_52 */ +#define ADV748X_HDMI_REG_6D 0x6d /* hdmi_reg_6d */ +#define ADV748X_I2S_TDM_MODE_ENABLE BIT(7) + /* HDMI RX Repeater Map */ #define ADV748X_REPEATER_EDID_SZ 0x70 /* primary_edid_size */ #define ADV748X_REPEATER_EDID_SZ_SHIFT 4