Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp4468201ybi; Tue, 11 Jun 2019 07:10:09 -0700 (PDT) X-Google-Smtp-Source: APXvYqyP0lKCIC38fu8Zbd3qGKSgPin7IDw+BvlyXNrTLNW4V5ExV88SwL+uhKOO6rxNvd/Cm4a/ X-Received: by 2002:a17:90a:3aed:: with SMTP id b100mr27386091pjc.63.1560262209417; Tue, 11 Jun 2019 07:10:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560262209; cv=none; d=google.com; s=arc-20160816; b=vVSCvtxrvk/jJdBrdDesp37WgMgoF2Vki3Xh5RBJDfkPOdsoJSXf40thM5NAVBSwN3 NRihfo3aYr8jU7bixqJOWUYnczU/StIrwQQJnfJZcFEtE0PHgkEnlOu0ZRVvbA4bErks wPBJfr7qHXIM+MEDGmtFIYAZGao02pMu9iw0AMLN9eRIiNFROHxSIm3S4w5n5GmEJ/YT PYC6RKebdVaqYyYWVkhDVXeGiKa+2YL3qfw3gSOdd5qYfjFiQMeCm0JCnh3FR1w2RL0H S7HLSeH2hDXeVoiFN94h1fUxZXJKjrFhhsM1/wlxcSWyBPOuJAbgToLENTJyvCSCWEw/ aK9g== 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; bh=MVpm+sDJDsHnr9cIwN2Yus4/LtnflNLMWErDC4o/a5U=; b=UHR/igw8Mzugf5M63lqMjXddSRC9gP7XIFbUJjjBlcfqs1A5e2B7EQ9PXw/RTBCUmh es527WLs2ncLBXOtYgL+FAPeTVCk0Gc8XsBmDwhWtmZ9WTgfEKxBBeEjmDc78sdLXNej CFxMb4gOKh/4LsFCYJTWZss8tYCxy3TWvt70P8aQHTHgvQFfiDitxuBWGF/wZVAuiyDM c+3prNp8e/EVXgroJdnZm6NsCY57t10JlozMyITL6F4wwV8rlz7YdH0el13X1Yu7qIC2 23ppV+3eGjlJy6OenYX4E9P4lwuzvMqTSKgFMBPxM5Wg30y7Rkb6wc7RY4iYz1ts3GrI XqQQ== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=codethink.co.uk Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s17si2505419pjp.26.2019.06.11.07.09.53; Tue, 11 Jun 2019 07:10:09 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=codethink.co.uk Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391587AbfFKOFc (ORCPT + 99 others); Tue, 11 Jun 2019 10:05:32 -0400 Received: from imap1.codethink.co.uk ([176.9.8.82]:55736 "EHLO imap1.codethink.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390003AbfFKOFC (ORCPT ); Tue, 11 Jun 2019 10:05:02 -0400 Received: from [167.98.27.226] (helo=happy.office.codethink.co.uk) by imap1.codethink.co.uk with esmtpsa (Exim 4.84_2 #1 (Debian)) id 1hahOU-0003vU-5F; Tue, 11 Jun 2019 15:04:58 +0100 From: Michael Drake To: Andrzej Hajda , Laurent Pinchart , dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Michael Drake Cc: David Airlie , Daniel Vetter , Rob Herring , Mark Rutland , linux-kernel@lists.codethink.co.uk, Patrick Glaser , Nate Case Subject: [PATCH v1 07/11] ti948: Add sysfs node for alive attribute Date: Tue, 11 Jun 2019 15:04:08 +0100 Message-Id: <20190611140412.32151-8-michael.drake@codethink.co.uk> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190611140412.32151-1-michael.drake@codethink.co.uk> References: <20190611140412.32151-1-michael.drake@codethink.co.uk> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This may be used by userspace to determine the state of the device. Signed-off-by: Michael Drake Cc: Patrick Glaser Cc: Nate Case --- drivers/gpu/drm/bridge/ti948.c | 28 ++++++++++++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/bridge/ti948.c b/drivers/gpu/drm/bridge/ti948.c index b5c766711c4b..b624eaeabb43 100644 --- a/drivers/gpu/drm/bridge/ti948.c +++ b/drivers/gpu/drm/bridge/ti948.c @@ -412,6 +412,16 @@ static void ti948_alive_check(struct work_struct *work) schedule_delayed_work(&ti948->alive_check, TI948_ALIVE_CHECK_DELAY); } +static ssize_t alive_show(struct device *dev, + struct device_attribute *attr, char *buf) +{ + struct ti948_ctx *ti948 = ti948_ctx_from_dev(dev); + + return scnprintf(buf, PAGE_SIZE, "%u\n", (unsigned int)ti948->alive); +} + +static DEVICE_ATTR_RO(alive); + static int ti948_pm_resume(struct device *dev) { struct ti948_ctx *ti948 = ti948_ctx_from_dev(dev); @@ -614,17 +624,31 @@ static int ti948_probe(struct i2c_client *client, i2c_set_clientdata(client, ti948); + ret = device_create_file(&client->dev, &dev_attr_alive); + if (ret) { + dev_err(&client->dev, "Could not create alive attr\n"); + return ret; + } + ret = ti948_pm_resume(&client->dev); - if (ret != 0) - return -EPROBE_DEFER; + if (ret != 0) { + ret = -EPROBE_DEFER; + goto error; + } dev_info(&ti948->i2c->dev, "End probe (addr: %x)\n", ti948->i2c->addr); return 0; + +error: + device_remove_file(&client->dev, &dev_attr_alive); + return ret; } static int ti948_remove(struct i2c_client *client) { + device_remove_file(&client->dev, &dev_attr_alive); + return ti948_pm_suspend(&client->dev); } -- 2.20.1