Message ID | 1357620829-24526-1-git-send-email-airlied@gmail.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Mon, Jan 7, 2013 at 11:53 PM, Dave Airlie <airlied@gmail.com> wrote: > From: Dave Airlie <airlied@redhat.com> > > this tells the drivers when the mux is switch to/from it, can be used > to report outputs as disconnected to userspace etc. > > Signed-off-by: Dave Airlie <airlied@redhat.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com> > --- > drivers/gpu/vga/vga_switcheroo.c | 19 +++++++++++++++++++ > include/linux/vga_switcheroo.h | 1 + > 2 files changed, 20 insertions(+) > > diff --git a/drivers/gpu/vga/vga_switcheroo.c b/drivers/gpu/vga/vga_switcheroo.c > index fa60add..2362175 100644 > --- a/drivers/gpu/vga/vga_switcheroo.c > +++ b/drivers/gpu/vga/vga_switcheroo.c > @@ -93,6 +93,9 @@ static void vga_switcheroo_enable(void) > return; > > client->id = ret; > + > + if (client->ops->mux_switched) > + client->ops->mux_switched(client->pdev, client->active ? VGA_SWITCHEROO_ON : VGA_SWITCHEROO_OFF); > } > vga_switcheroo_debugfs_init(&vgasr_priv); > vgasr_priv.active = true; > @@ -345,6 +348,13 @@ static int vga_switchto_stage2(struct vga_switcheroo_client *new_client) > if (ret) > return ret; > > + /* call mux switched callbacks */ > + if (active->ops->mux_switched) > + active->ops->mux_switched(active->pdev, VGA_SWITCHEROO_OFF); > + > + if (new_client->ops->mux_switched) > + new_client->ops->mux_switched(new_client->pdev, VGA_SWITCHEROO_ON); > + > if (new_client->ops->reprobe) > new_client->ops->reprobe(new_client->pdev); > > @@ -452,7 +462,16 @@ vga_switcheroo_debugfs_write(struct file *filp, const char __user *ubuf, > vgasr_priv.delayed_switch_active = false; > > if (just_mux) { > + struct vga_switcheroo_client *active; > + active = find_active_client(&vgasr_priv.clients); > + if (!active) > + return 0; > ret = vgasr_priv.handler->switchto(client_id); > + > + if (active->ops->mux_switched) > + active->ops->mux_switched(active->pdev, VGA_SWITCHEROO_OFF); > + if (client->ops->mux_switched) > + client->ops->mux_switched(client->pdev, VGA_SWITCHEROO_ON); > goto out; > } > > diff --git a/include/linux/vga_switcheroo.h b/include/linux/vga_switcheroo.h > index ddb419c..6275719 100644 > --- a/include/linux/vga_switcheroo.h > +++ b/include/linux/vga_switcheroo.h > @@ -40,6 +40,7 @@ struct vga_switcheroo_client_ops { > void (*set_gpu_state)(struct pci_dev *dev, enum vga_switcheroo_state); > void (*reprobe)(struct pci_dev *dev); > bool (*can_switch)(struct pci_dev *dev); > + void (*mux_switched)(struct pci_dev *dev, enum vga_switcheroo_state); > }; > > #if defined(CONFIG_VGA_SWITCHEROO) > -- > 1.8.1 > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/dri-devel
diff --git a/drivers/gpu/vga/vga_switcheroo.c b/drivers/gpu/vga/vga_switcheroo.c index fa60add..2362175 100644 --- a/drivers/gpu/vga/vga_switcheroo.c +++ b/drivers/gpu/vga/vga_switcheroo.c @@ -93,6 +93,9 @@ static void vga_switcheroo_enable(void) return; client->id = ret; + + if (client->ops->mux_switched) + client->ops->mux_switched(client->pdev, client->active ? VGA_SWITCHEROO_ON : VGA_SWITCHEROO_OFF); } vga_switcheroo_debugfs_init(&vgasr_priv); vgasr_priv.active = true; @@ -345,6 +348,13 @@ static int vga_switchto_stage2(struct vga_switcheroo_client *new_client) if (ret) return ret; + /* call mux switched callbacks */ + if (active->ops->mux_switched) + active->ops->mux_switched(active->pdev, VGA_SWITCHEROO_OFF); + + if (new_client->ops->mux_switched) + new_client->ops->mux_switched(new_client->pdev, VGA_SWITCHEROO_ON); + if (new_client->ops->reprobe) new_client->ops->reprobe(new_client->pdev); @@ -452,7 +462,16 @@ vga_switcheroo_debugfs_write(struct file *filp, const char __user *ubuf, vgasr_priv.delayed_switch_active = false; if (just_mux) { + struct vga_switcheroo_client *active; + active = find_active_client(&vgasr_priv.clients); + if (!active) + return 0; ret = vgasr_priv.handler->switchto(client_id); + + if (active->ops->mux_switched) + active->ops->mux_switched(active->pdev, VGA_SWITCHEROO_OFF); + if (client->ops->mux_switched) + client->ops->mux_switched(client->pdev, VGA_SWITCHEROO_ON); goto out; } diff --git a/include/linux/vga_switcheroo.h b/include/linux/vga_switcheroo.h index ddb419c..6275719 100644 --- a/include/linux/vga_switcheroo.h +++ b/include/linux/vga_switcheroo.h @@ -40,6 +40,7 @@ struct vga_switcheroo_client_ops { void (*set_gpu_state)(struct pci_dev *dev, enum vga_switcheroo_state); void (*reprobe)(struct pci_dev *dev); bool (*can_switch)(struct pci_dev *dev); + void (*mux_switched)(struct pci_dev *dev, enum vga_switcheroo_state); }; #if defined(CONFIG_VGA_SWITCHEROO)