From patchwork Thu Aug 17 19:36:45 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jemma Denson X-Patchwork-Id: 9907019 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 6A7D360386 for ; Thu, 17 Aug 2017 19:37:06 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 5BA7528B98 for ; Thu, 17 Aug 2017 19:37:06 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 4EFD728B9B; Thu, 17 Aug 2017 19:37:06 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.5 required=2.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, FREEMAIL_FROM, RCVD_IN_DNSWL_HI, RCVD_IN_SORBS_SPAM autolearn=ham version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 5C0B528B98 for ; Thu, 17 Aug 2017 19:37:05 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753259AbdHQThD (ORCPT ); Thu, 17 Aug 2017 15:37:03 -0400 Received: from mail-wr0-f194.google.com ([209.85.128.194]:36108 "EHLO mail-wr0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753144AbdHQThD (ORCPT ); Thu, 17 Aug 2017 15:37:03 -0400 Received: by mail-wr0-f194.google.com with SMTP id f8so1631400wrf.3 for ; Thu, 17 Aug 2017 12:37:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=7RNJ4m8Zcx9yn3wx3Cyan3ppGaF9tVfT2mLs7OVXS1E=; b=lSr7kUFKn+9NsK6kJ/zYDTfBiMl1KwqJ6FSJEDZa8sknhjFt/aAsNnWuPGpDJMRQQI vaROf6JtRfGpYCTDEC39GVddpoEv8djjKDtLA2Kfm5lDV9tcsOvUX3fneGlracqxEhZx 3g7TXh/zZ+0KACxyu269roA6rR2nanD/a8gL3KquVrmGfzlauh+g+BHslHAYDQOmmzxW FgK2NdHsnH6YbT2+0E6EuddobnWMJLF9KjffXIzxovgE8SsOZJsPj5DIfvXyPSOITnx4 uV9giOxpjfG3SbK5sUyOPlc4dP5f0mR/vZkBxwU0zK6niXa47AiE2Dkc83hLESNRi5bY S6Bg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=7RNJ4m8Zcx9yn3wx3Cyan3ppGaF9tVfT2mLs7OVXS1E=; b=M4fl4Dtx2tRkyT51Vhg2NqqPTsin7s2LrWxnaP8zEDidrxbD47qW+e3y+fB5derxgK EBOkBta/0bM2fidcS5H9qNwxghvY60KhhfLq53vXCPEx5zGZ15p09qcUVlHLYU3Cy09h AuyVMnPgLG1dLZs38tCCfNJUoGmj4YWzuVGx+Xb2zxAQIqMnVOslqI4VSp27k7wjzo7Z xGPLHdyOyncAQucGazlAYOWi8b0TDSz7lquyDexmeExTTJAINsMO/S3qRlAfmxfczOmG ji5SU4PVrN/V5EPfd/LgrAVER3OTnkkcztjaVYea6DKWcvl/TTEchTB1VIdInL7x/5FX AF8w== X-Gm-Message-State: AHYfb5gARP8HnaTh+bT4z5paB+yUlol6hv767AqHUnNE42YJRg4MMJmU huTsAUsorod/Fjfx X-Received: by 10.28.133.73 with SMTP id h70mr37993wmd.134.1502998621567; Thu, 17 Aug 2017 12:37:01 -0700 (PDT) Received: from jemma-pc.denson.org.uk ([2001:470:6ad2:1:beae:c5ff:fe8c:e4a7]) by smtp.gmail.com with ESMTPSA id g18sm4771251wrg.69.2017.08.17.12.37.00 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 17 Aug 2017 12:37:00 -0700 (PDT) From: Jemma Denson To: Linux Media Mailing List Cc: Mauro Carvalho Chehab , Patrick Boettcher , Mauro Carvalho Chehab Subject: [PATCH v3] media: isl6421: add checks for current overflow Date: Thu, 17 Aug 2017 20:36:45 +0100 Message-Id: <20170817193645.6159-1-jdenson@gmail.com> X-Mailer: git-send-email 2.13.4 In-Reply-To: <06047fe2c30107f01f2484c9d72acfb5abeca158.1502625545.git.mchehab@s-opensource.com> References: <06047fe2c30107f01f2484c9d72acfb5abeca158.1502625545.git.mchehab@s-opensource.com> Sender: linux-media-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-media@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP This Kaffeine's BZ: https://bugs.kde.org/show_bug.cgi?id=374693 affects SkyStar S2 PCI DVB-S/S2 rev 3.3 device. It could be due to a Kernel bug. While checking the Isil 6421, comparing with its manual, available at: http://www.intersil.com/content/dam/Intersil/documents/isl6/isl6421a.pdf It was noticed that, if the output load is highly capacitive, a different approach is recomended when energizing the LNBf. Also, it is possible to detect if a current overload is happening, by checking an special flag. Add support for it. Tested on Skystar S2. Changes respect override_or option so should still work fine on cx88 based cards which disable dynamic current limit. Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Jemma Denson --- drivers/media/dvb-frontends/isl6421.c | 77 +++++++++++++++++++++++++++++++++-- 1 file changed, 73 insertions(+), 4 deletions(-) diff --git a/drivers/media/dvb-frontends/isl6421.c b/drivers/media/dvb-frontends/isl6421.c index 838b42771a05..f58590fe71f5 100644 --- a/drivers/media/dvb-frontends/isl6421.c +++ b/drivers/media/dvb-frontends/isl6421.c @@ -38,35 +38,102 @@ struct isl6421 { u8 override_and; struct i2c_adapter *i2c; u8 i2c_addr; + bool is_off; }; static int isl6421_set_voltage(struct dvb_frontend *fe, enum fe_sec_voltage voltage) { + int ret; + u8 buf; + bool is_off; struct isl6421 *isl6421 = (struct isl6421 *) fe->sec_priv; - struct i2c_msg msg = { .addr = isl6421->i2c_addr, .flags = 0, - .buf = &isl6421->config, - .len = sizeof(isl6421->config) }; + struct i2c_msg msg[2] = { + { + .addr = isl6421->i2c_addr, + .flags = 0, + .buf = &isl6421->config, + .len = 1, + }, { + .addr = isl6421->i2c_addr, + .flags = I2C_M_RD, + .buf = &buf, + .len = 1, + } + + }; isl6421->config &= ~(ISL6421_VSEL1 | ISL6421_EN1); switch(voltage) { case SEC_VOLTAGE_OFF: + is_off = true; break; case SEC_VOLTAGE_13: + is_off = false; isl6421->config |= ISL6421_EN1; break; case SEC_VOLTAGE_18: + is_off = false; isl6421->config |= (ISL6421_EN1 | ISL6421_VSEL1); break; default: return -EINVAL; } + /* + * If LNBf were not powered on, disable dynamic current limit, as, + * according with datasheet, highly capacitive load on the output may + * cause a difficult start-up. + */ + if (isl6421->is_off && !is_off) + isl6421->config |= ISL6421_DCL; + isl6421->config |= isl6421->override_or; isl6421->config &= isl6421->override_and; - return (i2c_transfer(isl6421->i2c, &msg, 1) == 1) ? 0 : -EIO; + ret = i2c_transfer(isl6421->i2c, msg, 2); + if (ret < 0) + return ret; + if (ret != 2) + return -EIO; + + /* Store off status now incase future commands fail */ + isl6421->is_off = is_off; + + /* On overflow, the device will try again after 900 ms (typically) */ + if (!(isl6421->config & ISL6421_DCL) && (buf & ISL6421_OLF1)) + msleep(1000); + + /* Re-enable dynamic current limit after a certain amount of time */ + if ((isl6421->config & ISL6421_DCL) && + !(isl6421->override_or & ISL6421_DCL)) { + msleep(200); + isl6421->config &= ~ISL6421_DCL; + + ret = i2c_transfer(isl6421->i2c, msg, 2); + if (ret < 0) + return ret; + if (ret != 2) + return -EIO; + } + + /* Check if overload flag is active. If so, disable power */ + if (!is_off && (buf & ISL6421_OLF1)) { + isl6421->config &= ~(ISL6421_VSEL1 | ISL6421_EN1); + ret = i2c_transfer(isl6421->i2c, msg, 1); + if (ret < 0) + return ret; + if (ret != 1) + return -EIO; + isl6421->is_off = true; + + dev_warn(&isl6421->i2c->dev, + "Overload current detected. disabling LNBf power\n"); + return -EINVAL; + } + + return 0; } static int isl6421_enable_high_lnb_voltage(struct dvb_frontend *fe, long arg) @@ -148,6 +215,8 @@ struct dvb_frontend *isl6421_attach(struct dvb_frontend *fe, struct i2c_adapter return NULL; } + isl6421->is_off = true; + /* install release callback */ fe->ops.release_sec = isl6421_release;