Commit 23b0e695 authored by Zack Rusin's avatar Zack Rusin

drm/vmwgfx: Allow querying of the SVGA PCI id from the userspace

Mesa3D loaders require knowledge of the devices PCI id. SVGAv2 and v3
have different PCI id's, but the same driver is used to handle them both.
To allow Mesa3D svga driver to be loaded automatically for both SVGAv2
and SVGAv3 make the kernel return the PCI id of the currently running
device.
Signed-off-by: default avatarZack Rusin <zackr@vmware.com>
Reviewed-by: default avatarMartin Krastev <krastevm@vmware.com>
Reviewed-by: default avatarMaaz Mombasawala <mombasawalam@vmware.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220302152426.885214-6-zack@kde.org
parent c593197b
// SPDX-License-Identifier: GPL-2.0 OR MIT // SPDX-License-Identifier: GPL-2.0 OR MIT
/************************************************************************** /**************************************************************************
* *
* Copyright 2009-2015 VMware, Inc., Palo Alto, CA., USA * Copyright 2009-2022 VMware, Inc., Palo Alto, CA., USA
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the * copy of this software and associated documentation files (the
...@@ -27,9 +27,11 @@ ...@@ -27,9 +27,11 @@
#include "vmwgfx_drv.h" #include "vmwgfx_drv.h"
#include "vmwgfx_devcaps.h" #include "vmwgfx_devcaps.h"
#include <drm/vmwgfx_drm.h>
#include "vmwgfx_kms.h" #include "vmwgfx_kms.h"
#include <drm/vmwgfx_drm.h>
#include <linux/pci.h>
int vmw_getparam_ioctl(struct drm_device *dev, void *data, int vmw_getparam_ioctl(struct drm_device *dev, void *data,
struct drm_file *file_priv) struct drm_file *file_priv)
{ {
...@@ -62,17 +64,15 @@ int vmw_getparam_ioctl(struct drm_device *dev, void *data, ...@@ -62,17 +64,15 @@ int vmw_getparam_ioctl(struct drm_device *dev, void *data,
break; break;
case DRM_VMW_PARAM_FIFO_HW_VERSION: case DRM_VMW_PARAM_FIFO_HW_VERSION:
{ {
if ((dev_priv->capabilities & SVGA_CAP_GBOBJECTS)) { if ((dev_priv->capabilities & SVGA_CAP_GBOBJECTS))
param->value = SVGA3D_HWVERSION_WS8_B1; param->value = SVGA3D_HWVERSION_WS8_B1;
break; else
} param->value = vmw_fifo_mem_read(
dev_priv,
param->value = ((vmw_fifo_caps(dev_priv) &
vmw_fifo_mem_read(dev_priv, SVGA_FIFO_CAP_3D_HWVERSION_REVISED) ?
((vmw_fifo_caps(dev_priv) & SVGA_FIFO_3D_HWVERSION_REVISED :
SVGA_FIFO_CAP_3D_HWVERSION_REVISED) ? SVGA_FIFO_3D_HWVERSION));
SVGA_FIFO_3D_HWVERSION_REVISED :
SVGA_FIFO_3D_HWVERSION));
break; break;
} }
case DRM_VMW_PARAM_MAX_SURF_MEMORY: case DRM_VMW_PARAM_MAX_SURF_MEMORY:
...@@ -108,6 +108,9 @@ int vmw_getparam_ioctl(struct drm_device *dev, void *data, ...@@ -108,6 +108,9 @@ int vmw_getparam_ioctl(struct drm_device *dev, void *data,
case DRM_VMW_PARAM_GL43: case DRM_VMW_PARAM_GL43:
param->value = has_gl43_context(dev_priv); param->value = has_gl43_context(dev_priv);
break; break;
case DRM_VMW_PARAM_DEVICE_ID:
param->value = to_pci_dev(dev_priv->drm.dev)->device;
break;
default: default:
return -EINVAL; return -EINVAL;
} }
......
/************************************************************************** /**************************************************************************
* *
* Copyright © 2009-2015 VMware, Inc., Palo Alto, CA., USA * Copyright © 2009-2022 VMware, Inc., Palo Alto, CA., USA
* All Rights Reserved. * All Rights Reserved.
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
...@@ -92,6 +92,12 @@ extern "C" { ...@@ -92,6 +92,12 @@ extern "C" {
* *
* DRM_VMW_PARAM_SM5 * DRM_VMW_PARAM_SM5
* SM5 support is enabled. * SM5 support is enabled.
*
* DRM_VMW_PARAM_GL43
* SM5.1+GL4.3 support is enabled.
*
* DRM_VMW_PARAM_DEVICE_ID
* PCI ID of the underlying SVGA device.
*/ */
#define DRM_VMW_PARAM_NUM_STREAMS 0 #define DRM_VMW_PARAM_NUM_STREAMS 0
...@@ -111,6 +117,7 @@ extern "C" { ...@@ -111,6 +117,7 @@ extern "C" {
#define DRM_VMW_PARAM_SM4_1 14 #define DRM_VMW_PARAM_SM4_1 14
#define DRM_VMW_PARAM_SM5 15 #define DRM_VMW_PARAM_SM5 15
#define DRM_VMW_PARAM_GL43 16 #define DRM_VMW_PARAM_GL43 16
#define DRM_VMW_PARAM_DEVICE_ID 17
/** /**
* enum drm_vmw_handle_type - handle type for ref ioctls * enum drm_vmw_handle_type - handle type for ref ioctls
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment