aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/vga/vgaarb.c11
-rw-r--r--include/linux/vgaarb.h49
2 files changed, 32 insertions, 28 deletions
diff --git a/drivers/gpu/vga/vgaarb.c b/drivers/gpu/vga/vgaarb.c
index 199138f241e0..1ac0c93603c9 100644
--- a/drivers/gpu/vga/vgaarb.c
+++ b/drivers/gpu/vga/vgaarb.c
@@ -609,7 +609,6 @@ void vga_set_legacy_decoding(struct pci_dev *pdev, unsigned int decodes)
609} 609}
610EXPORT_SYMBOL(vga_set_legacy_decoding); 610EXPORT_SYMBOL(vga_set_legacy_decoding);
611 611
612/* return number of active VGA devices */
613/* call with NULL to unregister */ 612/* call with NULL to unregister */
614int vga_client_register(struct pci_dev *pdev, void *cookie, 613int vga_client_register(struct pci_dev *pdev, void *cookie,
615 void (*irq_set_state)(void *cookie, bool state), 614 void (*irq_set_state)(void *cookie, bool state),
@@ -831,7 +830,7 @@ static ssize_t vga_arb_write(struct file *file, const char __user * buf,
831 curr_pos += 5; 830 curr_pos += 5;
832 remaining -= 5; 831 remaining -= 5;
833 832
834 pr_devel("client 0x%X called 'lock'\n", (int)priv); 833 pr_devel("client 0x%p called 'lock'\n", priv);
835 834
836 if (!vga_str_to_iostate(curr_pos, remaining, &io_state)) { 835 if (!vga_str_to_iostate(curr_pos, remaining, &io_state)) {
837 ret_val = -EPROTO; 836 ret_val = -EPROTO;
@@ -867,7 +866,7 @@ static ssize_t vga_arb_write(struct file *file, const char __user * buf,
867 curr_pos += 7; 866 curr_pos += 7;
868 remaining -= 7; 867 remaining -= 7;
869 868
870 pr_devel("client 0x%X called 'unlock'\n", (int)priv); 869 pr_devel("client 0x%p called 'unlock'\n", priv);
871 870
872 if (strncmp(curr_pos, "all", 3) == 0) 871 if (strncmp(curr_pos, "all", 3) == 0)
873 io_state = VGA_RSRC_LEGACY_IO | VGA_RSRC_LEGACY_MEM; 872 io_state = VGA_RSRC_LEGACY_IO | VGA_RSRC_LEGACY_MEM;
@@ -917,7 +916,7 @@ static ssize_t vga_arb_write(struct file *file, const char __user * buf,
917 curr_pos += 8; 916 curr_pos += 8;
918 remaining -= 8; 917 remaining -= 8;
919 918
920 pr_devel("client 0x%X called 'trylock'\n", (int)priv); 919 pr_devel("client 0x%p called 'trylock'\n", priv);
921 920
922 if (!vga_str_to_iostate(curr_pos, remaining, &io_state)) { 921 if (!vga_str_to_iostate(curr_pos, remaining, &io_state)) {
923 ret_val = -EPROTO; 922 ret_val = -EPROTO;
@@ -960,7 +959,7 @@ static ssize_t vga_arb_write(struct file *file, const char __user * buf,
960 959
961 curr_pos += 7; 960 curr_pos += 7;
962 remaining -= 7; 961 remaining -= 7;
963 pr_devel("client 0x%X called 'target'\n", (int)priv); 962 pr_devel("client 0x%p called 'target'\n", priv);
964 /* if target is default */ 963 /* if target is default */
965 if (!strncmp(buf, "default", 7)) 964 if (!strncmp(buf, "default", 7))
966 pdev = pci_dev_get(vga_default_device()); 965 pdev = pci_dev_get(vga_default_device());
@@ -1014,7 +1013,7 @@ static ssize_t vga_arb_write(struct file *file, const char __user * buf,
1014 } else if (strncmp(curr_pos, "decodes ", 8) == 0) { 1013 } else if (strncmp(curr_pos, "decodes ", 8) == 0) {
1015 curr_pos += 8; 1014 curr_pos += 8;
1016 remaining -= 8; 1015 remaining -= 8;
1017 pr_devel("vgaarb: client 0x%X called 'decodes'\n", (int)priv); 1016 pr_devel("vgaarb: client 0x%p called 'decodes'\n", priv);
1018 1017
1019 if (!vga_str_to_iostate(curr_pos, remaining, &io_state)) { 1018 if (!vga_str_to_iostate(curr_pos, remaining, &io_state)) {
1020 ret_val = -EPROTO; 1019 ret_val = -EPROTO;
diff --git a/include/linux/vgaarb.h b/include/linux/vgaarb.h
index 68229ce80fde..e81c64af80c1 100644
--- a/include/linux/vgaarb.h
+++ b/include/linux/vgaarb.h
@@ -46,9 +46,9 @@ extern void vga_set_legacy_decoding(struct pci_dev *pdev,
46/** 46/**
47 * vga_get - acquire & locks VGA resources 47 * vga_get - acquire & locks VGA resources
48 * 48 *
49 * pdev: pci device of the VGA card or NULL for the system default 49 * @pdev: pci device of the VGA card or NULL for the system default
50 * rsrc: bit mask of resources to acquire and lock 50 * @rsrc: bit mask of resources to acquire and lock
51 * interruptible: blocking should be interruptible by signals ? 51 * @interruptible: blocking should be interruptible by signals ?
52 * 52 *
53 * This function acquires VGA resources for the given 53 * This function acquires VGA resources for the given
54 * card and mark those resources locked. If the resource requested 54 * card and mark those resources locked. If the resource requested
@@ -81,19 +81,19 @@ extern int vga_get(struct pci_dev *pdev, unsigned int rsrc,
81 */ 81 */
82 82
83static inline int vga_get_interruptible(struct pci_dev *pdev, 83static inline int vga_get_interruptible(struct pci_dev *pdev,
84 unsigned int rsrc) 84 unsigned int rsrc)
85{ 85{
86 return vga_get(pdev, rsrc, 1); 86 return vga_get(pdev, rsrc, 1);
87} 87}
88 88
89/** 89/**
90 * vga_get_interruptible 90 * vga_get_uninterruptible
91 * 91 *
92 * Shortcut to vga_get 92 * Shortcut to vga_get
93 */ 93 */
94 94
95static inline int vga_get_uninterruptible(struct pci_dev *pdev, 95static inline int vga_get_uninterruptible(struct pci_dev *pdev,
96 unsigned int rsrc) 96 unsigned int rsrc)
97{ 97{
98 return vga_get(pdev, rsrc, 0); 98 return vga_get(pdev, rsrc, 0);
99} 99}
@@ -165,28 +165,33 @@ static inline int vga_conflicts(struct pci_dev *p1, struct pci_dev *p2)
165} 165}
166#endif 166#endif
167 167
168/* 168/**
169 * Register a client with the VGA arbitration logic 169 * vga_client_register
170 * return value: number of VGA devices in system. 170 *
171 * 171 * @pdev: pci device of the VGA client
172 * Clients have two callback mechanisms they can use. 172 * @cookie: client cookie to be used in callbacks
173 * irq enable/disable callback - 173 * @irq_set_state: irq state change callback
174 * If a client can't disable its GPUs VGA resources, then we 174 * @set_vga_decode: vga decode change callback
175 * need to be able to ask it to turn off its irqs when we 175 *
176 * turn off its mem and io decoding. 176 * return value: 0 on success, -1 on failure
177 * set_vga_decode 177 * Register a client with the VGA arbitration logic
178 * If a client can disable its GPU VGA resource, it will 178 *
179 * get a callback from this to set the encode/decode state 179 * Clients have two callback mechanisms they can use.
180 * 180 * irq enable/disable callback -
181 * Clients with disable abilities should check the return value 181 * If a client can't disable its GPUs VGA resources, then we
182 * of this function and if the VGA device count is > 1, should 182 * need to be able to ask it to turn off its irqs when we
183 * disable VGA decoding resources. 183 * turn off its mem and io decoding.
184 * set_vga_decode
185 * If a client can disable its GPU VGA resource, it will
186 * get a callback from this to set the encode/decode state
184 * 187 *
185 * Rationale: we cannot disable VGA decode resources unconditionally 188 * Rationale: we cannot disable VGA decode resources unconditionally
186 * some single GPU laptops seem to require ACPI or BIOS access to the 189 * some single GPU laptops seem to require ACPI or BIOS access to the
187 * VGA registers to control things like backlights etc. 190 * VGA registers to control things like backlights etc.
188 * Hopefully newer multi-GPU laptops do something saner, and desktops 191 * Hopefully newer multi-GPU laptops do something saner, and desktops
189 * won't have any special ACPI for this. 192 * won't have any special ACPI for this.
193 * They driver will get a callback when VGA arbitration is first used
194 * by userspace since we some older X servers have issues.
190 */ 195 */
191int vga_client_register(struct pci_dev *pdev, void *cookie, 196int vga_client_register(struct pci_dev *pdev, void *cookie,
192 void (*irq_set_state)(void *cookie, bool state), 197 void (*irq_set_state)(void *cookie, bool state),