From: Bjorn Helgaas <bhelgaas@google.com>
To: Andreas Noever <andreas.noever@gmail.com>
Cc: linux-kernel@vger.kernel.org,
Matthew Garrett <matthew.garrett@nebula.com>,
Greg KH <greg@kroah.com>,
linux-pci@vger.kernel.org
Subject: Re: [PATCH v3 09/15] thunderbolt: Handle hotplug events
Date: Wed, 28 May 2014 16:26:40 -0600 [thread overview]
Message-ID: <20140528222640.GW11907@google.com> (raw)
In-Reply-To: <1401117492-2870-10-git-send-email-andreas.noever@gmail.com>
On Mon, May 26, 2014 at 05:18:06PM +0200, Andreas Noever wrote:
> We reveive a plug event callback whenever a thunderbolt device is added
s/reveive/receive/
> or removed. This patch fills in the tb_handle_hotplug method and starts
> reacting to these events by adding/removing switches from the hierarchy.
>
> Signed-off-by: Andreas Noever <andreas.noever@gmail.com>
> ---
> drivers/thunderbolt/switch.c | 42 +++++++++++++++++++++++++++++++++++++++-
> drivers/thunderbolt/tb.c | 46 +++++++++++++++++++++++++++++++++++++++++++-
> drivers/thunderbolt/tb.h | 3 +++
> 3 files changed, 89 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/thunderbolt/switch.c b/drivers/thunderbolt/switch.c
> index 279b9c5..c092f7c 100644
> --- a/drivers/thunderbolt/switch.c
> +++ b/drivers/thunderbolt/switch.c
> @@ -195,6 +195,24 @@ static void tb_dump_switch(struct tb *tb, struct tb_regs_switch_header *sw)
> sw->__unknown1, sw->__unknown4);
> }
>
> +struct tb_switch *get_switch_at_route(struct tb_switch *sw, u64 route)
> +{
> + u8 next_port = route; /*
> + * Routes use a stride of 8 bits,
> + * eventhough a port index has 6 bits at most.
> + * */
> + if (route == 0)
> + return sw;
> + if (next_port > sw->config.max_port_number)
> + return 0;
> + if (tb_is_upstream_port(&sw->ports[next_port]))
> + return 0;
> + if (!sw->ports[next_port].remote)
> + return 0;
> + return get_switch_at_route(sw->ports[next_port].remote->sw,
> + route >> TB_ROUTE_SHIFT);
> +}
> +
> /**
> * tb_plug_events_active() - enable/disable plug events on a switch
> *
> @@ -243,7 +261,8 @@ void tb_switch_free(struct tb_switch *sw)
> sw->ports[i].remote = NULL;
> }
>
> - tb_plug_events_active(sw, false);
> + if (!sw->is_unplugged)
> + tb_plug_events_active(sw, false);
>
> kfree(sw->ports);
> kfree(sw);
> @@ -327,3 +346,24 @@ err:
> return NULL;
> }
>
> +/**
> + * tb_sw_set_unpplugged() - set is_unplugged on switch and downstream switches
> + */
> +void tb_sw_set_unpplugged(struct tb_switch *sw)
> +{
> + int i;
> + if (sw == sw->tb->root_switch) {
> + tb_sw_WARN(sw, "cannot unplug root switch\n");
> + return;
> + }
> + if (sw->is_unplugged) {
> + tb_sw_WARN(sw, "is_unplugged already set\n");
> + return;
> + }
> + sw->is_unplugged = true;
> + for (i = 0; i <= sw->config.max_port_number; i++) {
> + if (!tb_is_upstream_port(&sw->ports[i]) && sw->ports[i].remote)
> + tb_sw_set_unpplugged(sw->ports[i].remote->sw);
> + }
> +}
> +
> diff --git a/drivers/thunderbolt/tb.c b/drivers/thunderbolt/tb.c
> index 3b716fd..1efcacc 100644
> --- a/drivers/thunderbolt/tb.c
> +++ b/drivers/thunderbolt/tb.c
> @@ -71,11 +71,55 @@ static void tb_handle_hotplug(struct work_struct *work)
> {
> struct tb_hotplug_event *ev = container_of(work, typeof(*ev), work);
> struct tb *tb = ev->tb;
> + struct tb_switch *sw;
> + struct tb_port *port;
> mutex_lock(&tb->lock);
> if (!tb->hotplug_active)
> goto out; /* during init, suspend or shutdown */
>
> - /* do nothing for now */
> + sw = get_switch_at_route(tb->root_switch, ev->route);
> + if (!sw) {
> + tb_warn(tb,
> + "hotplug event from non existent switch %llx:%x (unplug: %d)\n",
> + ev->route, ev->port, ev->unplug);
> + goto out;
> + }
> + if (ev->port > sw->config.max_port_number) {
> + tb_warn(tb,
> + "hotplug event from non existent port %llx:%x (unplug: %d)\n",
> + ev->route, ev->port, ev->unplug);
> + goto out;
> + }
> + port = &sw->ports[ev->port];
> + if (tb_is_upstream_port(port)) {
> + tb_warn(tb,
> + "hotplug event for upstream port %llx:%x (unplug: %d)\n",
> + ev->route, ev->port, ev->unplug);
> + goto out;
> + }
> + if (ev->unplug) {
> + if (port->remote) {
> + tb_port_info(port, "unplugged\n");
> + tb_sw_set_unpplugged(port->remote->sw);
> + tb_switch_free(port->remote->sw);
> + port->remote = NULL;
> + } else {
> + tb_port_info(port,
> + "got unplug event for disconnected port, ignoring\n");
> + }
> + } else if (port->remote) {
> + tb_port_info(port,
> + "got plug event for connected port, ignoring\n");
> + } else {
> + tb_port_info(port, "hotplug: scanning\n");
> + tb_scan_port(port);
> + if (!port->remote) {
> + tb_port_info(port, "hotplug: no switch found\n");
> + } else if (port->remote->sw->config.depth > 1) {
> + tb_sw_warn(port->remote->sw,
> + "hotplug: chaining not supported\n");
> + }
> + }
> out:
> mutex_unlock(&tb->lock);
> kfree(ev);
> diff --git a/drivers/thunderbolt/tb.h b/drivers/thunderbolt/tb.h
> index 70a66fe..661f182 100644
> --- a/drivers/thunderbolt/tb.h
> +++ b/drivers/thunderbolt/tb.h
> @@ -20,6 +20,7 @@ struct tb_switch {
> struct tb_port *ports;
> struct tb *tb;
> int cap_plug_events; /* offset, zero if not found */
> + bool is_unplugged; /* unplugged, will go away */
> };
>
> /**
> @@ -160,6 +161,8 @@ void thunderbolt_shutdown_and_free(struct tb *tb);
>
> struct tb_switch *tb_switch_alloc(struct tb *tb, u64 route);
> void tb_switch_free(struct tb_switch *sw);
> +void tb_sw_set_unpplugged(struct tb_switch *sw);
> +struct tb_switch *get_switch_at_route(struct tb_switch *sw, u64 route);
>
> int tb_wait_for_port(struct tb_port *port, bool wait_if_unplugged);
>
> --
> 1.9.3
>
next prev parent reply other threads:[~2014-05-28 22:26 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-05-26 15:17 [PATCH v3 00/15] Thunderbolt driver for Apple MacBooks Andreas Noever
2014-05-26 15:17 ` [PATCH v3 01/15] thunderbolt: Add initial cactus ridge NHI support Andreas Noever
2014-05-26 15:17 ` [PATCH v3 02/15] thunderbolt: Add control channel interface Andreas Noever
2014-05-26 15:18 ` [PATCH v3 03/15] thunderbolt: Setup control channel Andreas Noever
2014-05-26 15:18 ` [PATCH v3 04/15] thunderbolt: Add tb_regs.h Andreas Noever
2014-05-26 15:18 ` [PATCH v3 05/15] thunderbolt: Initialize root switch and ports Andreas Noever
2014-05-26 15:18 ` [PATCH v3 06/15] thunderbolt: Add thunderbolt capability handling Andreas Noever
2014-05-26 15:18 ` [PATCH v3 07/15] thunderbolt: Enable plug events Andreas Noever
2014-05-26 15:18 ` [PATCH v3 08/15] thunderbolt: Scan for downstream switches Andreas Noever
2014-05-26 15:18 ` [PATCH v3 09/15] thunderbolt: Handle hotplug events Andreas Noever
2014-05-28 22:26 ` Bjorn Helgaas [this message]
2014-05-26 15:18 ` [PATCH v3 10/15] thunderbolt: Add path setup code Andreas Noever
2014-05-28 22:30 ` Bjorn Helgaas
2014-05-26 15:18 ` [PATCH v3 11/15] thunderbolt: Add support for simple pci tunnels Andreas Noever
2014-05-26 15:18 ` [PATCH v3 12/15] pci: Add pci_fixup_suspend_late quirk pass Andreas Noever
2014-05-28 22:36 ` Bjorn Helgaas
2014-05-30 14:33 ` Andreas Noever
2014-05-30 16:09 ` Greg KH
2014-05-26 15:18 ` [PATCH v3 13/15] pci: Suspend/resume quirks for appel thunderbolt Andreas Noever
2014-05-27 14:07 ` Matthew Garrett
2014-05-27 14:07 ` Matthew Garrett
2014-05-28 22:43 ` Bjorn Helgaas
2014-05-26 15:18 ` [PATCH v3 14/15] thunderbolt: Read switch uid from EEPROM Andreas Noever
2014-05-26 15:18 ` [PATCH v3 15/15] thunderbolt: Add suspend/hibernate support Andreas Noever
2014-05-27 14:09 ` [PATCH v3 00/15] Thunderbolt driver for Apple MacBooks Matthew Garrett
2014-05-27 14:09 ` Matthew Garrett
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=20140528222640.GW11907@google.com \
--to=bhelgaas@google.com \
--cc=andreas.noever@gmail.com \
--cc=greg@kroah.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=matthew.garrett@nebula.com \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.