Linux USB
 help / color / mirror / Atom feed
From: Alan Stern <stern@rowland.harvard.edu>
To: Michael Grzeschik <mgr@pengutronix.de>
Cc: linux-usb@vger.kernel.org, gregkh@linuxfoundation.org,
	kernel@pengutronix.de
Subject: Re: [PATCH v3] usb: hub: port: add sysfs entry to switch port power
Date: Fri, 3 Jun 2022 15:37:44 -0400	[thread overview]
Message-ID: <YppjCCJrtxc4lEGc@rowland.harvard.edu> (raw)
In-Reply-To: <20220603172209.GD26638@pengutronix.de>

On Fri, Jun 03, 2022 at 07:22:09PM +0200, Michael Grzeschik wrote:
> On Fri, Jun 03, 2022 at 11:58:50AM -0400, Alan Stern wrote:
> > On Fri, Jun 03, 2022 at 01:52:22PM +0200, Michael Grzeschik wrote:

> > > +static ssize_t disable_show(struct device *dev,
> > > +			      struct device_attribute *attr, char *buf)
> > > +{
> > > +	struct usb_port *port_dev = to_usb_port(dev);
> > > +	struct usb_device *hdev = to_usb_device(dev->parent->parent);
> > > +	struct usb_hub *hub = usb_hub_to_struct_hub(hdev);
> > > +	int port1 = port_dev->portnum;
> > > +	bool state = test_bit(port1, hub->power_bits);
> > > +
> > > +	return sprintf(buf, "%s\n", state ? "0" : "1");
> > 
> > Maybe "false" and "true" instead of "0" and "1"?
> 
> I prefer 0 and 1 since we also feed this to the file.

Oops -- I was wrong about "true" or "false" (which is a little odd; 
you'd think a parser for boolean values would certainly recognize those 
words).  However, strtobool() does also recognize "yes", "no", "on", and 
"off".

Using "on" and "off" would lead to confusion, since "on" means 
"disable is turned on", which means the port is off!  "Yes" and "no" 
would be okay, though.

> Also, I just found out that just parsing power_bits is not enough.
> 
> E.g. when we use other tools to set clear PORT_POWER on the hub like
> uhubctl to disable a port. The value does not represent the real state
> of the port.

The value in power_bits is always supposed to match the real state of 
the port.  How does uhubctl manage to get them to disagree?

> I think it is better to use hub_port_status and port_is_power_on from
> hub.c to test the real state by sending a GET_STATUS command.

Maybe.  But if power_bits is working properly, this should not be 
needed.  It would be better to fix the value stored in power_bits.

Alan Stern

> For this, the functions need to be unset static and exported via hub.h.
> 
> I will add this in v4.


  reply	other threads:[~2022-06-03 19:37 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-06-03 11:52 [PATCH v3] usb: hub: port: add sysfs entry to switch port power Michael Grzeschik
2022-06-03 15:58 ` Alan Stern
2022-06-03 17:22   ` Michael Grzeschik
2022-06-03 19:37     ` Alan Stern [this message]
2022-06-03 20:29       ` Michael Grzeschik
2022-06-03 21:24         ` Alan Stern

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=YppjCCJrtxc4lEGc@rowland.harvard.edu \
    --to=stern@rowland.harvard.edu \
    --cc=gregkh@linuxfoundation.org \
    --cc=kernel@pengutronix.de \
    --cc=linux-usb@vger.kernel.org \
    --cc=mgr@pengutronix.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox