[PATCH 1/2] vga_switcheroo: add mux switched interface
Alex Deucher
alexdeucher at gmail.com
Tue Jan 8 06:18:21 PST 2013
On Mon, Jan 7, 2013 at 11:53 PM, Dave Airlie <airlied at gmail.com> wrote:
> From: Dave Airlie <airlied at 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 at redhat.com>
Reviewed-by: Alex Deucher <alexander.deucher at 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 at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel
More information about the dri-devel
mailing list