From patchwork Sun May 3 13:00:21 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Olli Salonen X-Patchwork-Id: 29470 Received: from mail.tu-berlin.de ([130.149.7.33]) by www.linuxtv.org with esmtp (Exim 4.72) (envelope-from ) id 1YotVs-0006B6-Th; Sun, 03 May 2015 15:00:52 +0200 X-tubIT-Incoming-IP: 209.132.180.67 Received: from vger.kernel.org ([209.132.180.67]) by mail.tu-berlin.de (exim-4.76/mailfrontend-5) with esmtp id 1YotVr-0006l8-6Y; Sun, 03 May 2015 15:00:52 +0200 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751823AbbECNAs (ORCPT + 1 other); Sun, 3 May 2015 09:00:48 -0400 Received: from mail-lb0-f181.google.com ([209.85.217.181]:35230 "EHLO mail-lb0-f181.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751340AbbECNAr (ORCPT ); Sun, 3 May 2015 09:00:47 -0400 Received: by lbbuc2 with SMTP id uc2so89475159lbb.2 for ; Sun, 03 May 2015 06:00:46 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :in-reply-to:references; bh=YDsy1SixoDIbfWsBp9hd2eHJi9qBRz8wThnkXAxTJvs=; b=d5z8F13atO1MPSXb4TJhEbgrtXQOVTIMGbqsbTTpMHonCqLuxpa2vGaEsFMM9AOM6m 8GjWIXkyDxwRGaRMAWwXwpZbLtHQr+foYASIqAqb6I7lC/dL64XzBjcFPRE1dGVeMIrz +EdMpo6S3ejrIGFYiE3jJSAa/Z0/Vp6YZJPW6G8AGTYPiqYdl4wfiYWULstfk8gQ44gI 1InxS5WPGoXYBUPnzugqAgcm2tggb+TxgZfU6B/0GXnufVXu6H4dd3gIA7MWOrC0Ska7 iGQYDQfIAyKoFadoqvQj7l4P0ij9NXFgi1Eb35KLefqDPtoIfx8c6kK9fWsgUGM6EvJF 9yKA== X-Gm-Message-State: ALoCoQnX+IeWuYUs5Gxb0z4NzmpDN4pzvWi0qe9YYao2KUOMz3AMHBkotNGH2k76GY3CQ80EeQOY X-Received: by 10.113.10.134 with SMTP id ea6mr15520077lbd.29.1430658046030; Sun, 03 May 2015 06:00:46 -0700 (PDT) Received: from dl160.lan (188-67-118-178.bb.dnainternet.fi. [188.67.118.178]) by mx.google.com with ESMTPSA id s8sm2673608las.29.2015.05.03.06.00.44 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Sun, 03 May 2015 06:00:45 -0700 (PDT) From: Olli Salonen To: linux-media@vger.kernel.org Cc: Olli Salonen , Antti Palosaari Subject: [PATCH v3 4/6] rtl28xxu: add I2C read without write Date: Sun, 3 May 2015 16:00:21 +0300 Message-Id: <1430658023-17579-2-git-send-email-olli.salonen@iki.fi> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1430658023-17579-1-git-send-email-olli.salonen@iki.fi> References: <1430658023-17579-1-git-send-email-olli.salonen@iki.fi> Sender: linux-media-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-media@vger.kernel.org X-PMX-Version: 6.0.0.2142326, Antispam-Engine: 2.7.2.2107409, Antispam-Data: 2015.5.3.125717 X-PMX-Spam: Gauge=IIIIIIII, Probability=8%, Report=' MULTIPLE_RCPTS 0.1, HTML_00_01 0.05, HTML_00_10 0.05, BODYTEXTP_SIZE_3000_LESS 0, BODY_SIZE_1100_1199 0, BODY_SIZE_2000_LESS 0, BODY_SIZE_5000_LESS 0, BODY_SIZE_7000_LESS 0, REFERENCES 0, URI_ENDS_IN_HTML 0, __ANY_URI 0, __CP_URI_IN_BODY 0, __DATE_TZ_RU 0, __HAS_FROM 0, __HAS_MSGID 0, __HAS_X_MAILER 0, __HAS_X_MAILING_LIST 0, __IN_REP_TO 0, __MIME_TEXT_ONLY 0, __MULTIPLE_RCPTS_CC_X2 0, __REFERENCES 0, __SANE_MSGID 0, __SUBJ_ALPHA_END 0, __TO_MALFORMED_2 0, __TO_NO_NAME 0, __URI_NO_WWW 0, __URI_NS , __YOUTUBE_RCVD 0' Add support for I2C read operation without a preceeding write. While here, change the error code to EOPNOTSUPP in case an unsupported I2C operation is attempted. Signed-off-by: Olli Salonen --- drivers/media/usb/dvb-usb-v2/rtl28xxu.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/drivers/media/usb/dvb-usb-v2/rtl28xxu.c b/drivers/media/usb/dvb-usb-v2/rtl28xxu.c index f1a7613..5e0c015 100644 --- a/drivers/media/usb/dvb-usb-v2/rtl28xxu.c +++ b/drivers/media/usb/dvb-usb-v2/rtl28xxu.c @@ -232,8 +232,14 @@ static int rtl28xxu_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msg[], req.data = msg[0].buf; ret = rtl28xxu_ctrl_msg(d, &req); } + } else if (num == 1 && (msg[0].flags & I2C_M_RD)) { + req.value = (msg[0].addr << 1); + req.index = CMD_I2C_DA_RD; + req.size = msg[0].len; + req.data = msg[0].buf; + ret = rtl28xxu_ctrl_msg(d, &req); } else { - ret = -EINVAL; + ret = -EOPNOTSUPP; } err_mutex_unlock: