mirror of
git://nv-tegra.nvidia.com/tegra/kernel-src/nv-kernel-display-driver.git
synced 2025-12-24 10:41:52 +03:00
af3ee56442f16029cb9b13537477c384226b22fc - CODE_OF_CONDUCT.md ac7f91dfb6c5c469d2d8196c6baebe46ede5aee0 - CHANGELOG.md 1b03ad8c20ddb6d129ade64846377cc86ce4c1de - README.md d13779dbbab1c776db15f462cd46b29f2c0f8c7c - Makefile ec5f1eb408e0b650158e0310fb1ddd8e9b323a6f - CONTRIBUTING.md 5728867ce2e96b63b29367be6aa1c0e47bcafc8f - SECURITY.md 7d577fdb9594ae572ff38fdda682a4796ab832ca - COPYING 6b73bf6a534ddc0f64e8ba88739381c3b7fb4b5c - nv-compiler.sh 7ad4bb8aebd57a9be26329a611b14c5a70ccf2b7 - nouveau/extract-firmware-nouveau.py 36f9753dbbef7dd5610312d5b14bffac1a93cee4 - nouveau/nouveau_firmware_layout.ods 80545889e3c9967fd0ae12a65005be31bac354f2 - src/nvidia-modeset/Makefile 80c2c9a2a05beb0202239db8b0dd7080ff21c194 - src/nvidia-modeset/kapi/interface/nvkms-kapi-private.h 36c20e9c111e66601b025802f840e7b87d09cdde - src/nvidia-modeset/kapi/interface/nvkms-kapi.h 27612b72a77ac67cd468ac7f15948d2ad78defed - src/nvidia-modeset/kapi/include/nvkms-kapi-internal.h 727bd77cfbc9ac4989c2ab7eec171ceb516510aa - src/nvidia-modeset/kapi/include/nvkms-kapi-notifiers.h 01d943d6edb0c647c2b8dbc44460948665b03e7a - src/nvidia-modeset/kapi/src/nvkms-kapi-notifiers.c ce42ceac4c4cf9d249d66ab57ae2f435cd9623fc - src/nvidia-modeset/kapi/src/nvkms-kapi-sync.c 67fe73dc7149daf807194bd9a0f96252cb452179 - src/nvidia-modeset/kapi/src/nvkms-kapi.c 2ea1436104463c5e3d177e8574c3b4298976d37e - src/nvidia-modeset/interface/nvkms-ioctl.h 8e3e74d2b3f45381e7b0012d930cf451cbd1728f - src/nvidia-modeset/interface/nvkms-sync.h d51449fa2fd19748007f2e98f0233c92b45f9572 - src/nvidia-modeset/interface/nvkms-api-types.h 4da2125966732a80fc154cea4b18b2372b12501e - src/nvidia-modeset/interface/nvkms-api.h b986bc6591ba17a74ad81ec4c93347564c6d5165 - src/nvidia-modeset/interface/nvkms-format.h f5f3b11c78a8b0eef40c09e1751615a47f516edb - src/nvidia-modeset/include/nvkms-hal.h ebafc51b2b274cd1818e471850a5efa9618eb17d - src/nvidia-modeset/include/nvkms-prealloc.h 118d0ea84ff81de16fbdc2c7daf249ee5c82ed6e - src/nvidia-modeset/include/nvkms-modepool.h 6e3681d5caa36312804c91630eaaf510eda897d2 - src/nvidia-modeset/include/nvkms-dma.h 1b75646c99c748f9070208eb58f0082812eabbd9 - src/nvidia-modeset/include/nvkms-private.h 412d8028a548e67e9ef85cb7d3f88385e70c56f9 - src/nvidia-modeset/include/nvkms-console-restore.h 6b21a68e254becdd2641bc456f194f54c23abe51 - src/nvidia-modeset/include/nvkms-framelock.h 4a33d410f090fd4f4dfc9a6de285f8e8fb1c9ced - src/nvidia-modeset/include/nvkms-surface.h c90e4393f568d96bc98cb52a93bfc3fdea10658d - src/nvidia-modeset/include/nvkms-modeset-workarea.h 8c7e0e15c1038fe518e98d8f86fafb250b10a1d2 - src/nvidia-modeset/include/nvkms-stereo.h fa829f1cd3b73f194f39879c48962b703f640b65 - src/nvidia-modeset/include/nvkms-vrr.h c869ccfcda419d80b6691d3667c4e9196493065e - src/nvidia-modeset/include/nvkms-modeset-types.h ec1374d339746b73bc7c7614695fde68c156074a - src/nvidia-modeset/include/nvkms-rm.h 07ac47b52b1b42c143501c4a95a88a3f86f5be03 - src/nvidia-modeset/include/nvkms-hdmi.h 11bae7c491bbb0ba4cad94b645d47c384191fa5c - src/nvidia-modeset/include/nvkms-flip.h 70d9251f331bbf28f5c5bbdf939ebad94db9362d - src/nvidia-modeset/include/nvkms-softfloat.h cdf54b0d423f94f04d6f33b672c131125c13d260 - src/nvidia-modeset/include/nvkms-hw-flip.h 377dd4a29b2ea5937a9b8fc3fba0c9e4ef92992e - src/nvidia-modeset/include/nvkms-cursor.h 260b6ef87c755e55a803adad4ce49f2d57315f9a - src/nvidia-modeset/include/nvkms-event.h 8a0ced82697c32b97a80fa3366704014879610e7 - src/nvidia-modeset/include/nvkms-flip-workarea.h b0d407b0413453ec71481f84cc448d090b90d609 - src/nvidia-modeset/include/nvkms-evo3.h 496b94af536dd912866a05f7b2da53050b50c2f5 - src/nvidia-modeset/include/nvkms-prealloc-types.h 35fa1444c57f7adbbddddc612237f3ad38cdd78f - src/nvidia-modeset/include/nvkms-rmapi.h 15dddd9307fa7ac201bd9ebc1e35e6ac0d2cf6c9 - src/nvidia-modeset/include/nvkms-evo.h b8854261256a801af52d1201081afa9c17486a96 - src/nvidia-modeset/include/nvkms-3dvision.h c1c7047929aafc849a924c7fa9f8bc206b8e7524 - src/nvidia-modeset/include/g_nvkms-evo-states.h 49af4a8fa95d0e595deacadbca5360f097722e7f - src/nvidia-modeset/include/nvkms-evo1.h eb5248c4b0b51e7aecd2de87e496253b3b235c70 - src/nvidia-modeset/include/nvkms-utils-flip.h 4a94381bd8c24b09193577d3f05d6d61f178e1cf - src/nvidia-modeset/include/nvkms-ctxdma.h be6e0e97c1e7ffc0daa2f14ef7b05b9f9c11dc16 - src/nvidia-modeset/include/nvkms-attributes.h d05ef9a837f2927fe387e7d157ea76c7ef567807 - src/nvidia-modeset/include/nvkms-lut.h d57ae79509c667e8d16a4756d85e3564c1b1ac34 - src/nvidia-modeset/include/nvkms-modeset.h ae03509966df56d98fa72b7528ab43ec2b258381 - src/nvidia-modeset/include/nvkms-utils.h 81fcc817dfb8ae1f98b63d2c1acacc303fedb554 - src/nvidia-modeset/include/nvkms-dpy-override.h fa8dbffe58d345634ab1ea8743ed29c9ec169f36 - src/nvidia-modeset/include/nvkms-dpy.h 691731826d6daa3bb5a3847a3dd2424d513113c4 - src/nvidia-modeset/include/nvkms-types.h a79cfb74026085b0aa612c0ae6789083e196bbc2 - src/nvidia-modeset/include/nvkms-evo-states.h a8fbb7a071c0e7b326f384fed7547e7b6ec81c3e - src/nvidia-modeset/include/dp/nvdp-timer.h 4625828efd425e1b29835ab91fcc3d2d85e92389 - src/nvidia-modeset/include/dp/nvdp-connector-event-sink.h ae43c46687d16b93189047d9eeed933a67e5571f - src/nvidia-modeset/include/dp/nvdp-connector.h c386632dbdc0e89019d5618f132dbcb3dff4dafb - src/nvidia-modeset/include/dp/nvdp-device.h bd2e4a6102432d4ac1faf92b5d3db29e9e3cfafc - src/nvidia-modeset/src/nvkms-utils.c 30ad7839985dea46e6b6d43499210a3056da51ad - src/nvidia-modeset/src/nvkms-utils-flip.c 2b304663f2a005b5ccdecfafb69a3407f2feeb18 - src/nvidia-modeset/src/nvkms-evo2.c fd64ffbcc1efd446fb3352ceaa8bd4221b23a1d2 - src/nvidia-modeset/src/nvkms-modeset.c 3e723edf2a0a2f4f93032feb4aeaaf7fd0acddfa - src/nvidia-modeset/src/g_nvkms-evo-states.c 2fabe1c14116a2b07f24d01710394ee84a6e3914 - src/nvidia-modeset/src/nvkms-3dvision.c 488724910d9a3bf530303a4fa0889983d11ce5c0 - src/nvidia-modeset/src/nvkms-hdmi.c 761c8540278a1ffb9fe4aa0adb1b4ee95524787a - src/nvidia-modeset/src/nvkms-hal.c 54b41301663dc9fdc45d24c7a43ad4a980821f9d - src/nvidia-modeset/src/nvkms-attributes.c 3261fd9a1eb14f7f3fb0917757b1e2704d4abbd2 - src/nvidia-modeset/src/nvkms-hw-states.c 6d41c9f84cc9ce2d16812e94a3fba055b3fc7308 - src/nvidia-modeset/src/nvkms-conf.c 7d0e38f9d79e0c928bdc67276b8ecb0c18470b88 - src/nvidia-modeset/src/nvkms-hw-flip.c 03fb499633c485e0559da79500d4e66ea50e8d8f - src/nvidia-modeset/src/nvkms-framelock.c 05ca4acdfeb9b99eccc7e222846fc688473322ae - src/nvidia-modeset/src/nvkms-rmapi-dgpu.c 65b02b48caff2a9100b8c5614f91d42fb20da9c0 - src/nvidia-modeset/src/nvkms-dpy-override.c dff88ceaf95239b51b60af915f92e389bb844425 - src/nvidia-modeset/src/nvkms-cursor.c f754a27436fd1e1fa103de6110224c21ad7ea9f4 - src/nvidia-modeset/src/nvkms-pow.c 4d81c3052a0793d180642e3367b7870863015ef2 - src/nvidia-modeset/src/nvkms-rm.c 9a8746ee4a4e772b8ac13f06dc0de8a250fdb4c7 - src/nvidia-modeset/src/nvkms-ctxdma.c 403e6dbff0a607c2aecf3204c56633bd7b612ae2 - src/nvidia-modeset/src/nvkms-stereo.c da726d20eea99a96af4c10aace88f419e8ee2a34 - src/nvidia-modeset/src/nvkms-event.c b890da1d428f30483d6f69e662218f19c074d011 - src/nvidia-modeset/src/nvkms-evo3.c c799d52bdc792efc377fb5cd307b0eb445c44d6a - src/nvidia-modeset/src/nvkms-cursor2.c b7232f4b4b8f0d4c395c241c451fc17b6ab84d7f - src/nvidia-modeset/src/nvkms-evo.c 6f2eb25d57d2dc3c1e5db869cfbdf556878d3332 - src/nvidia-modeset/src/nvkms-console-restore.c 94e9c19b7b6a5e56fd46b0885e7dd6fe698fe2df - src/nvidia-modeset/src/nvkms-prealloc.c bf1b007fceaa1c38771f9e7d1130f9c0c3eddd80 - src/nvidia-modeset/src/nvkms-lut.c e13960662d872f84dd77f36f778aee0521b4ff54 - src/nvidia-modeset/src/nvkms-modepool.c b13bd89b5ac60ceab56e9c2398cf7668375ab7ad - src/nvidia-modeset/src/nvkms-flip.c 9fea40b7b55d6ebf3f73b5d469751c873ffbe7c0 - src/nvidia-modeset/src/nvkms-dma.c df59641109db4529eed62cf156b1815a3e67ba05 - src/nvidia-modeset/src/nvkms-vrr.c f4a02d5b6cb1fa5d461514b21e13002ad9cfa1a4 - src/nvidia-modeset/src/nvkms-evo1.c 9e4d3e3505a84d8634a2ef2307628a8fe551a4c3 - src/nvidia-modeset/src/nvkms-surface.c 2fa9d9b3cbeeb9406f2dd51a4f4a5d53844a31c9 - src/nvidia-modeset/src/nvkms-dpy.c a49319a235d8746b771a7c418277e168a291259f - src/nvidia-modeset/src/nvkms.c 6a35b80a6995777dc9500cac9659e6f0f0c12d23 - src/nvidia-modeset/src/nvkms-cursor3.c a90b2c295271631b4c3abe6afb8dfd92d6b429c8 - src/nvidia-modeset/src/dp/nvdp-connector.cpp c19775aebdaaaee3500378d47af6ff0b8eb486b8 - src/nvidia-modeset/src/dp/nvdp-device.cpp 51af3c1ee6b74ee0c9add3fb7d50cbc502980789 - src/nvidia-modeset/src/dp/nvdp-evo-interface.hpp 69fed95ab3954dd5cb26590d02cd8ba09cdff1ac - src/nvidia-modeset/src/dp/nvdp-connector-event-sink.hpp f96cd982b4c05351faa31d04ac30d6fa7c866bcb - src/nvidia-modeset/src/dp/nvdp-timer.cpp 535ce9f743903eb83a341eef1be812f4e4b50887 - src/nvidia-modeset/src/dp/nvdp-evo-interface.cpp a2a4b7063fa903cc434163ebceb7c8d48f703c33 - src/nvidia-modeset/src/dp/nvdp-connector-event-sink.cpp 6b985fc50b5040ce1a81418bed73a60edb5d3289 - src/nvidia-modeset/src/dp/nvdp-timer.hpp 110ac212ee8832c3fa3c4f45d6d33eed0301e992 - src/nvidia-modeset/src/dp/nvdp-host.cpp 252660f72b80add6f6071dd0b86288dda8dbb168 - src/nvidia-modeset/os-interface/include/nvkms.h 6e4ae13d024a1df676736752df805b6f91511009 - src/nvidia-modeset/os-interface/include/nvidia-modeset-os-interface.h c3ab6005d7083e90145cac66addf815c4f93d9a0 - src/nvidia-modeset/lib/nvkms-format.c 7e1249c1d187aec5891eabe5bacae2189d33dc55 - src/nvidia-modeset/lib/nvkms-sync.c b9fd15957f7ae5effeccb5d8adaa7434b43f44e1 - src/common/softfloat/source/s_roundToUI64.c d0f8f08c225b60d88b6358d344404ba9df3038ec - src/common/softfloat/source/s_normSubnormalF32Sig.c 824383b03952c611154bea0a862da2b9e2a43827 - src/common/softfloat/source/s_subMagsF32.c 729e790328168c64d65a1355e990274c249bbb3a - src/common/softfloat/source/f32_to_i32_r_minMag.c 68843a93e1f46195243ef1164f611b759cf19d17 - src/common/softfloat/source/f32_le_quiet.c 4445b1fbbd507144f038fd939311ff95bc2cf5f1 - src/common/softfloat/source/ui64_to_f64.c daeb408588738b3eb4c8b092d7f92ac597cf1fc6 - src/common/softfloat/source/f32_rem.c aaf6ccb77a1a89fa055a0fb63513297b35e2e54b - src/common/softfloat/source/f64_le_quiet.c 0bf499c0e3a54186fa32b38b310cc9d98ccdcfe3 - src/common/softfloat/source/f32_eq.c 6fa7493285fe2f7fdc0ac056a6367e90327905c2 - src/common/softfloat/source/f32_sub.c 54cbeb5872a86e822bda852ec15d3dcdad4511ce - src/common/softfloat/source/f64_add.c d4b26dc407a891e9ff5324853f1845a99c5d5cd2 - src/common/softfloat/source/f32_to_i32.c e4930e155580a0f5aa7f3694a6205bc9aebfe7aa - src/common/softfloat/source/f32_to_f64.c 5a5e0d9f1ee7e8c0d1d4f9fbcf6eba330a5f1792 - src/common/softfloat/source/f32_isSignalingNaN.c ce37cdce572a3b02d42120e81c4969b39d1a67b6 - src/common/softfloat/source/f64_to_i32.c 5e6f9e120a17cc73297a35e4d57e4b9cbce01780 - src/common/softfloat/source/s_mul64To128.c b22876b0695f58ee56143c9f461f1dde32fefbf3 - src/common/softfloat/source/f64_to_ui64.c 23b76c1d0be64e27a6f7e2ea7b8919f1a45a8e7c - src/common/softfloat/source/f32_to_ui32_r_minMag.c dde685423af544e5359efdb51b4bf9457c67fa3b - src/common/softfloat/source/f32_sqrt.c 21a6232d93734b01692689258a3fdfbbf4ff089d - src/common/softfloat/source/s_roundToUI32.c 0108fe6f0d394ad72083aff9bb58507f97a0b669 - src/common/softfloat/source/ui32_to_f64.c 871cb1a4037d7b4e73cb20ad18390736eea7ae36 - src/common/softfloat/source/f32_to_ui64_r_minMag.c 84b0a01ba2a667eb28b166d45bd91352ead83e69 - src/common/softfloat/source/i64_to_f32.c d701741d8d6a92bb890e53deda1b795f5787f465 - src/common/softfloat/source/f64_le.c 1ff879eca2a273293b5cd6048419b2d2d8063b93 - src/common/softfloat/source/f64_mulAdd.c 00c612847b3bd227a006a4a2697df85866b80315 - src/common/softfloat/source/s_mulAddF32.c da3b3f94a817909a3dc93ca5fa7675805c7979e0 - src/common/softfloat/source/f64_isSignalingNaN.c bc992c88f3de09e3a82447cf06dbde7c6604f7f8 - src/common/softfloat/source/f64_to_f32.c c29536f617d71fe30accac44b2f1df61c98a97dc - src/common/softfloat/source/f64_div.c 50b3147f8413f0595a4c3d6e6eeab84c1ffecada - src/common/softfloat/source/s_normRoundPackToF32.c 1484fc96d7731695bda674e99947280a86990997 - src/common/softfloat/source/f32_to_i64.c b8c5ccc1e511637d8b2ba2657de4937b80c01c07 - src/common/softfloat/source/f32_le.c 6f83fa864007e8227ae09bb36a7fdc18832d4445 - src/common/softfloat/source/f32_mul.c 00ab2120f71117161d4f6daaa9b90a3036a99841 - src/common/softfloat/source/f32_to_ui32.c 86fdc2472526375539216461732d1db6a9f85b55 - src/common/softfloat/source/s_roundPackToF32.c 38bd00e9c4d2f1354c611404cca6209a6c417669 - src/common/softfloat/source/s_countLeadingZeros64.c 2960704c290f29aae36b8fe006884d5c4abcabb4 - src/common/softfloat/source/f32_div.c fd40a71c7ebf9d632a384fadf9487cfef4f3ea98 - src/common/softfloat/source/s_shiftRightJam128.c c3ce12c227d25bc0de48fbcf914fc208e2448741 - src/common/softfloat/source/f64_sub.c 29396b7c23941024a59d5ea06698d2fbc7e1a6ca - src/common/softfloat/source/f64_to_i64.c 5c4ee32cc78efc718aaa60ec31d0b00b1bee3c2c - src/common/softfloat/source/f64_to_ui64_r_minMag.c c951c9dffa123e4f77ed235eca49ef9b67f9f3d2 - src/common/softfloat/source/s_subMagsF64.c d19ff7dfece53875f2d6c6f7dd9e7772f7b0b7ec - src/common/softfloat/source/f32_to_i64_r_minMag.c dafa667ee5dd52c97fc0c3b7144f6b619406c225 - src/common/softfloat/source/s_mulAddF64.c ab19c6b50c40b8089cb915226d4553d1aa902b0e - src/common/softfloat/source/f64_to_i32_r_minMag.c 2e0fec421f4defd293cf55c5f3af7d91f4b7d2cc - src/common/softfloat/source/ui64_to_f32.c fe06512577e642b09196d46430d038d027491e9f - src/common/softfloat/source/f32_eq_signaling.c e7890082ce426d88b4ec93893da32e306478c0d1 - src/common/softfloat/source/s_approxRecipSqrt32_1.c 296c40b0589536cb9af3231ad3dcd7f2baaa6887 - src/common/softfloat/source/f64_lt.c fb062ecbe62a1f5878fd47f0c61490f2bde279dd - src/common/softfloat/source/s_roundToI32.c ec1a797b11f6e846928a4a49a8756f288bda1dfa - src/common/softfloat/source/i32_to_f64.c 0e9694d551848d88531f5461a9b3b91611652e9a - src/common/softfloat/source/f64_to_ui32_r_minMag.c a94c8c2bd74633027e52e96f41d24714d8081eb4 - src/common/softfloat/source/s_approxRecipSqrt_1Ks.c baa7af4eea226140c26ffe6ab02a863d07f729fb - src/common/softfloat/source/f64_eq_signaling.c f6d98979ab2d1e2b0d664333104130af6abbcad5 - src/common/softfloat/source/f64_to_i64_r_minMag.c 5c1026617c588bcf5f1e59230bd5bb900600b9ac - src/common/softfloat/source/f64_mul.c 0d8e42636a3409a647291fdb388001c2b11bba07 - src/common/softfloat/source/f32_to_f16.c 9f4d355d85fbe998e243fe4c7bbf8ad23062b6e2 - src/common/softfloat/source/i64_to_f64.c d9a86343e6cc75714f65f690082dd4b0ba724be9 - src/common/softfloat/source/s_roundPackToF16.c 1a86a6948bf6768bd23a19f1f05d40968c1d2b15 - src/common/softfloat/source/f64_rem.c e0ad81cfb5d2c0e74dc4ece9518ca15ffc77beaf - src/common/softfloat/source/f32_roundToInt.c 50daf9186bc5d0180d1453c957164b136d5ffc89 - src/common/softfloat/source/f64_eq.c 2db07bbb8242bc55a24ef483af6d648db0660de0 - src/common/softfloat/source/f32_add.c 760fd7c257a1f915b61a1089b2acb143c18a082e - src/common/softfloat/source/s_addMagsF64.c 4b37be398b3e73ae59245f03b2ba2394fc902b4d - src/common/softfloat/source/s_normSubnormalF64Sig.c 69dc4cc63b2a9873a6eb636ee7cb704cbd502001 - src/common/softfloat/source/f64_to_ui32.c 9266c83f3e50093cc45d7be6ab993a0e72af1685 - src/common/softfloat/source/s_roundPackToF64.c 7c8e5ab3f9bf6b2764ce5fffe80b2674be566a12 - src/common/softfloat/source/softfloat_state.c 9a5b93459ace2da23964da98617d6b18006fab86 - src/common/softfloat/source/s_countLeadingZeros8.c 108eec2abf1cddb397ce9f652465c2e52f7c143b - src/common/softfloat/source/f64_roundToInt.c 09cb0cdb90eb23b53cd9c1a76ba26021084710d1 - src/common/softfloat/source/s_addMagsF32.c ae25eea499b3ea5bdd96c905fd0542da11083048 - src/common/softfloat/source/s_normRoundPackToF64.c 2e5c29d842a8ebc5fbf987068dc9394cee609cc7 - src/common/softfloat/source/f32_to_ui64.c 7bc81f5bc894118c08bfd52b59e010bc068ed762 - src/common/softfloat/source/ui32_to_f32.c 513a7d1c3053fc119efcd8ae1bcc9652edc45315 - src/common/softfloat/source/f32_lt.c bbc70102b30f152a560eb98e7a1a4b11b9ede85e - src/common/softfloat/source/f64_sqrt.c 0adfa7e174cdb488bb22b06642e14e7fc6f49c67 - src/common/softfloat/source/s_roundToI64.c ebb4f674b6213fec29761fc4e05c1e3ddeda6d17 - src/common/softfloat/source/f32_mulAdd.c 29321080baa7eab86947ac825561fdcff54a0e43 - src/common/softfloat/source/i32_to_f32.c 8e58f0258218475616ff4e6317516d40ad475626 - src/common/softfloat/source/f32_lt_quiet.c 054b23a974fc8d0bab232be433c4e516e6c1250a - src/common/softfloat/source/f64_lt_quiet.c 4cd1d6cfca3936a39aab9bc0eb622f5c7c848be1 - src/common/softfloat/source/include/softfloat_types.h de09949a0ca5cd2a84b882b5b5c874d01d3ae11a - src/common/softfloat/source/include/primitives.h f36c896cfa01f1de9f9420189319e4e00c7fc52a - src/common/softfloat/source/include/internals.h 1ded4df85ff5fa904fa54c27d681265425be1658 - src/common/softfloat/source/include/primitiveTypes.h 9645e179cf888bcd0e3836e8126b204b4b42b315 - src/common/softfloat/source/include/softfloat.h 21a11759ed2afd746a47c4d78b67640c2d052165 - src/common/softfloat/source/8086-SSE/s_commonNaNToF32UI.c 252c816378fddab616b1f2a61e9fedd549224483 - src/common/softfloat/source/8086-SSE/s_commonNaNToF64UI.c 0cbae7a5abc336331d460cbd3640d2cda02af434 - src/common/softfloat/source/8086-SSE/softfloat_raiseFlags.c a6d5c83f6a0542b33ac9c23ac65ef69002cfff9d - src/common/softfloat/source/8086-SSE/s_propagateNaNF32UI.c 86cda6550cb02bbf595d1667573e4be83702a95e - src/common/softfloat/source/8086-SSE/specialize.h d8b0c55a49c4fa0b040541db6d5ff634d7d103e7 - src/common/softfloat/source/8086-SSE/s_propagateNaNF64UI.c 3d0dbc0a672d039a6346e1c21ddf87ffc9181978 - src/common/softfloat/source/8086-SSE/s_f32UIToCommonNaN.c d152bc457b655725185bdff42b36bb96d6e6715e - src/common/softfloat/source/8086-SSE/s_commonNaNToF16UI.c 1dd1b424087d9c872684df0c1b4063b077992d5f - src/common/softfloat/source/8086-SSE/s_f64UIToCommonNaN.c b882497ae393bf66a728dae395b64ac53602a1a5 - src/common/softfloat/nvidia/nv-softfloat.h be9407a273620c0ba619b53ed72d59d52620c3e4 - src/common/softfloat/nvidia/platform.h 70b155b0da07a92ede884a9cec715f67e6b5c3e8 - src/common/displayport/src/dp_list.cpp 9f31213ab8037d7bb18c96a67d2630d61546544a - src/common/displayport/src/dp_mst_edid.cpp 818efd113374de206a36ccf2bf594b4e433a0b85 - src/common/displayport/src/dp_evoadapter.cpp e874ffeaeb6deec57605bf91eaa2af116a9762bd - src/common/displayport/src/dp_bitstream.cpp de264916d0e3e873a4c624f237ea228469d0a980 - src/common/displayport/src/dp_watermark.cpp 554e6b7dadbb68ac0f3d2e368ca3fd90832ea254 - src/common/displayport/src/dp_discovery.cpp fea946e5320e7de8e9229bca8d4a6a14b9e8db59 - src/common/displayport/src/dp_crc.cpp 4803cde0fffcf89fed46d6deaeba5c96c669a908 - src/common/displayport/src/dp_messageheader.cpp ca92fed27d4c5ca5e9495df08e63d5f446e7f24b - src/common/displayport/src/dp_deviceimpl.cpp d2f8d43d650d9c0b4a8d9b8070087f13efdaac79 - src/common/displayport/src/dp_connectorimpl.cpp b18924b1d50232b92223355f608fcca1b6d7ff46 - src/common/displayport/src/dp_configcaps.cpp f4493ab7efc7030b4cd17bf792981a9dca497e29 - src/common/displayport/src/dp_groupimpl.cpp 37eabb1ab51cb38660eb24e294c63c8320750b96 - src/common/displayport/src/dp_sst_edid.cpp fa4f4869d3d63c0180f30ae3736600a6627284c6 - src/common/displayport/src/dp_merger.cpp 98cec6b663cf630c789e9823675cbb4948e1ba5e - src/common/displayport/src/dp_edid.cpp fbd877bac2efc8ee33e4e108e61c961e1fc42f44 - src/common/displayport/src/dp_messagecodings.cpp aa2e56f6c66bf91c2b4a6030de2d29480f69710e - src/common/displayport/src/dp_wardatabase.cpp 1543bbaba8f3e149239cf44be3c0d080c624d5ba - src/common/displayport/src/dp_buffer.cpp f56f92e32710b0342805b785d34ba1a9f2a54ed3 - src/common/displayport/src/dp_guid.cpp 45da2aabdaf6b5b2bf17a3deeb045feed1545415 - src/common/displayport/src/dp_messages.cpp f83b3c17e9f26651f12c8835a682abdd66aed3a2 - src/common/displayport/src/dp_splitter.cpp 56ee9318a7b51a04baa1d25d7d9a798c733dc1bc - src/common/displayport/src/dp_vrr.cpp d991afdb694634e9df756184b5951739fc3fd0ab - src/common/displayport/src/dp_auxretry.cpp 719d2ddbfb8555636496cb5dd74ee6776059db92 - src/common/displayport/src/dp_timer.cpp fe8007b3d98dad71b17595ecb67af77b198827a0 - src/common/displayport/src/dptestutil/dp_testmessage.cpp 36e80dd13c5adc64c3adc9a931d5ebbf922e9502 - src/common/displayport/inc/dp_groupimpl.h d876d77caef3541ae05f310857f3d32e642fba04 - src/common/displayport/inc/dp_auxdefs.h 070b4f6216f19feebb6a67cbb9c3eb22dc60cf74 - src/common/displayport/inc/dp_buffer.h cca426d571c6b01f7953180e2e550e55c629f0f4 - src/common/displayport/inc/dp_auxretry.h e2075486b392d6b231f2f133922ac096ca4bc095 - src/common/displayport/inc/dp_ringbuffer.h 80380945c76c58648756446435d615f74630f2da - src/common/displayport/inc/dp_timeout.h 2f134665b274bb223c3f74e0ec5c6a0392fa6387 - src/common/displayport/inc/dp_discovery.h 72f91aac76264d34ce778489f5ce839e03833db8 - src/common/displayport/inc/dp_messages.h 2067e2ca3b86014c3e6dfc51d6574d87ae12d907 - src/common/displayport/inc/dp_timer.h 325818d0a4d1b15447923e2ed92c938d293dc079 - src/common/displayport/inc/dp_hostimp.h 9a0aa25938adf3bda9451aeab67fb04e266d771d - src/common/displayport/inc/dp_deviceimpl.h df11366a5bcfb641025f12cddf9b5e8c2ed008de - src/common/displayport/inc/dp_watermark.h 78595e6262d5ab0e6232392dc0852feaf83c7585 - src/common/displayport/inc/dp_auxbus.h c2f5f82ddf1d0b5c976264ceb14fe9b67bf12851 - src/common/displayport/inc/dp_messagecodings.h cdb1e7797c250b0a7c0449e2df5ce71e42b83432 - src/common/displayport/inc/dp_merger.h f6e1b0850f5ed0f23f263d4104523d9290bb8669 - src/common/displayport/inc/dp_vrr.h 07d22f84e6a386dad251761278a828dab64b6dd5 - src/common/displayport/inc/dp_bitstream.h 8d8a5f0160922b6630fa796789c5d59cce94d9e0 - src/common/displayport/inc/dp_configcaps.h 7b7d9a137027fbbedfc041465987fa4ed4198ce4 - src/common/displayport/inc/dp_edid.h 34e808f745eaaff13aeb4e6cde1a8ce35f7b9def - src/common/displayport/inc/dp_connector.h 36d3c602cbbf0a52d574f841ba1b75125ec3b24a - src/common/displayport/inc/dp_linkconfig.h 29ee5f4ef6670f06e96c07b36c11e3bad8bee6aa - src/common/displayport/inc/dp_address.h 02b65d96a7a345eaa87042faf6dd94052235009c - src/common/displayport/inc/dp_messageheader.h e02e5621eaea52a2266a86dcd587f4714680caf4 - src/common/displayport/inc/dp_linkedlist.h d0b72ca2db108478bba75393c7255356da0e8233 - src/common/displayport/inc/dp_regkeydatabase.h a3fc03562a3fa0968ab8d4a50424465174392f0e - src/common/displayport/inc/dp_connectorimpl.h eb9cdbb0a907926b1afd2a551ec19830f06ae205 - src/common/displayport/inc/dp_splitter.h 750ecc85242882a9e428d5a5cf1a64f418d59c5f - src/common/displayport/inc/dp_object.h 4a098c4d09dedc33b86748d5fe9a30d097675e9f - src/common/displayport/inc/dp_list.h e70068249ebb59040a3e3be1fc4248d714550e61 - src/common/displayport/inc/dp_evoadapter.h 2a81681efef7ffced62c6d64cfdbc455d85fdb0a - src/common/displayport/inc/dp_mainlink.h 11487c992494f502d1c48ff00982998504336800 - src/common/displayport/inc/dp_internal.h 01f1dd58ed5bb12503fa45be7a6657cde0a857e2 - src/common/displayport/inc/dp_guid.h e27519c72e533a69f7433638a1d292fb9df8772e - src/common/displayport/inc/dp_crc.h 379d3933c90eaf9c35a0bad2bd6af960a321465f - src/common/displayport/inc/dp_wardatabase.h 5bd3706ceea585df76a75dda7f9581b91ee8f998 - src/common/displayport/inc/dp_tracing.h 020194b85245bad5de4dfe372a7ccb0c247d6ede - src/common/displayport/inc/dptestutil/dp_testmessage.h edded9ca3d455444372fe6c497b2d61bd0cc3f96 - src/common/unix/common/utils/nv_memory_tracker.c 26f2a36442266c5d2664d509ecfd31094a83e152 - src/common/unix/common/utils/nv_vasprintf.c e903bbbecf4fb3085aaccca0628f0a0e4aba3e58 - src/common/unix/common/utils/nv_mode_timings_utils.c bda08c8398f68ffc2866ebc390dc63a09a16b0b9 - src/common/unix/common/utils/unix_rm_handle.c 07c675d22c4f0f4be6647b65b6487e2d6927c347 - src/common/unix/common/utils/interface/nv_memory_tracker.h 667b361db93e35d12d979c47e4d7a68be9aa93b6 - src/common/unix/common/utils/interface/nv_mode_timings_utils.h 8d9c4d69394b23d689a4aa6727eb3da1d383765a - src/common/unix/common/utils/interface/unix_rm_handle.h 9e008270f277e243f9167ab50401602378a2a6e8 - src/common/unix/common/utils/interface/nv_vasprintf.h 881cbcc7ed39ea9198279136205dbe40142be35e - src/common/unix/common/inc/nv_assert.h 2476f128437c0520204e13a4ddd2239ff3f40c21 - src/common/unix/common/inc/nv-float.h d5253e7e4abd3ad8d72375260aa80037adcd8973 - src/common/unix/common/inc/nv_dpy_id.h 1c947cfc8a133b00727104684764e5bb900c9d28 - src/common/unix/common/inc/nv_mode_timings.h 995d8447f8539bd736cc09d62983ae8ebc7e3436 - src/common/unix/common/inc/nv_common_utils.h befb2c0bf0a31b61be5469575ce3c73a9204f4e9 - src/common/sdk/nvidia/inc/nv_stdarg.h 78a4b6b19a38de41527ef8b290754deca5906817 - src/common/sdk/nvidia/inc/nvcd.h 5cec5038e1f4a395a08b765c8361a9560f3312b7 - src/common/sdk/nvidia/inc/nvdisptypes.h 751abf80513898b35a6449725e27724b1e23ac50 - src/common/sdk/nvidia/inc/nvmisc.h 1e7eec6561b04d2d21c3515987aaa116e9401c1f - src/common/sdk/nvidia/inc/nv-kernel-interface-api.h fa267c903e9c449e62dbb6945906400d43417eff - src/common/sdk/nvidia/inc/nvlimits.h 3b12d770f8592b94a8c7774c372e80ad08c5774c - src/common/sdk/nvidia/inc/nvi2c.h f5a682339a89d2b119b43e5b9263dd67346ed3bc - src/common/sdk/nvidia/inc/cpuopsys.h 4a97d807a225d792544578f8112c9a3f90cc38f6 - src/common/sdk/nvidia/inc/nvstatuscodes.h 5cf4b517c9bd8f14593c1a6450078a774a39dd08 - src/common/sdk/nvidia/inc/nv-hypervisor.h 56cca793dd7bcbc4a3681677a822fc9f7a11a091 - src/common/sdk/nvidia/inc/nvos.h 7de14a0c3cc8460a9c41e1ee32fda5409c5b9988 - src/common/sdk/nvidia/inc/mmu_fmt_types.h e7a5fa74517ecd7f617860f01c5523bc5acd6432 - src/common/sdk/nvidia/inc/rs_access.h b3de92f4edb1fcc856fd62b74359c9cd447519a8 - src/common/sdk/nvidia/inc/nverror.h c8b96af9d498f87cb9acde064648f9e84d789055 - src/common/sdk/nvidia/inc/nv_vgpu_types.h af0bc90b3ad4767de53b8ff91e246fdab0146e8b - src/common/sdk/nvidia/inc/nvsecurityinfo.h b249abc0a7d0c9889008e98cb2f8515a9d310b85 - src/common/sdk/nvidia/inc/nvgputypes.h edf1f7d1457b015aa92c12f74f9ffa1e2f86a821 - src/common/sdk/nvidia/inc/nvtypes.h b5dedeada189123f1965650827bf8a8193383a92 - src/common/sdk/nvidia/inc/nvimpshared.h 95bf694a98ba78d5a19e66463b8adda631e6ce4c - src/common/sdk/nvidia/inc/nvstatus.h 9bca638f5832d831880f090c583fac6fc8cf6ee6 - src/common/sdk/nvidia/inc/dpringbuffertypes.h 7c03663f5e12754572e6efcbe09f51ec2c5f6502 - src/common/sdk/nvidia/inc/g_finn_rm_api.h a506a41b8dcf657fb39a740ffc1dfd83835d6c89 - src/common/sdk/nvidia/inc/nvcfg_sdk.h 95b0de4e76d9cc1bf49ef953fc00aa47e238ccd2 - src/common/sdk/nvidia/inc/nvfixedtypes.h 0edffddbe7764b268f724abc4ac84924767d1bf2 - src/common/sdk/nvidia/inc/ctrl/ctrl0041.h 8607fdd8ecaa5140bac6643a3f715610ed391d67 - src/common/sdk/nvidia/inc/ctrl/ctrlxxxx.h 352825959d98fe9b47a474cfdd154d380c80d24e - src/common/sdk/nvidia/inc/ctrl/ctrl90cd.h 5b573deb4d68ccb67d9cccc11b28203c5db3d2f7 - src/common/sdk/nvidia/inc/ctrl/ctrl0002.h bfee287b190fd698735c5660592741ba5c25a8ea - src/common/sdk/nvidia/inc/ctrl/ctrl0020.h 1cd4acc266f26dba813ac8802dba4e7ab381f753 - src/common/sdk/nvidia/inc/ctrl/ctrl0080.h 175ad4d300fa40b960d07fee059b51c6b8639f01 - src/common/sdk/nvidia/inc/ctrl/ctrlb06f.h b35f86170f27005bc714b37edc96dffb97691bd4 - src/common/sdk/nvidia/inc/ctrl/ctrla081.h f64c19679dc9a20e62ef86d01878a006b505ed93 - src/common/sdk/nvidia/inc/ctrl/ctrl906f.h 72164895b0055a1942e1190a05d5090753af95a1 - src/common/sdk/nvidia/inc/ctrl/ctrl30f1.h 360ed7fefcd6f8f4370b3cf88d43a9f8eec1e86d - src/common/sdk/nvidia/inc/ctrl/ctrl00da.h 90843f8173a341deb7f1466cd69a17114c6b9e4f - src/common/sdk/nvidia/inc/ctrl/ctrl90f1.h c8b2e0e64bb3cf3c562dee5fa7913035f82d8247 - src/common/sdk/nvidia/inc/ctrl/ctrl402c.h 7433f9674e36f120671d6e1802f2cdbcaadc58c3 - src/common/sdk/nvidia/inc/ctrl/ctrl2080.h 4fc1dd23cbfdb4ce49f1722f6e282cd21f33b7f5 - src/common/sdk/nvidia/inc/ctrl/ctrla06f.h a75a0a693d5742c8aecd788dc204a69863cfaf39 - src/common/sdk/nvidia/inc/ctrl/ctrl00de.h 3fcf5dbb82508d88a040981a7ab21eac1466bb2b - src/common/sdk/nvidia/inc/ctrl/ctrl0073.h fcdf7b331c3f7744d296918e68d44dfb114b9461 - src/common/sdk/nvidia/inc/ctrl/ctrl00fe.h b4cecb527cdc3ba4e68ca0031ac2179756108cb0 - src/common/sdk/nvidia/inc/ctrl/ctrl003e.h ade4a731f59c7cd16b4a60d318a19147b9918bb9 - src/common/sdk/nvidia/inc/ctrl/ctrl0004.h 625af1df5c9453bd35a9e873ee5c77e73d5fd195 - src/common/sdk/nvidia/inc/ctrl/ctrl90ec.h 6627bf1716c0e06e870c083d264753d6a0abb439 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080ce.h a002a436f77b9544041a259405dddba90301df01 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080grmgr.h 07f82ae90cde3c6e2e6c5af135c40e01660c39a3 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080boardobjgrpclasses.h aa86ffd04a55436ecacbedb1626f6187bbddedf7 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080perf_cf.h 59340a74f26b92f689fe99f8303775c87a4bbd58 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080hshub.h 48691dd2c8d93fbd162e207cdb5d27ea30741d36 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080gsp.h 0cd5e883dfafb74ce2ec9bccca6e688a27e6cfa9 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080perf_cf_pwr_model.h 96f72ec608cd198be995f3acd9c04afe7c7e6dc8 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080volt.h 97bb79e74b25134fa02a60d310b3e81170df6fd6 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080clkavfs.h 496c7a1a0c283b25a637a996995d3987c9045346 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080internal.h d5cdbcd10e049e8daf48feb5347f070d4ef85f8b - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080spdm.h 347efee37fa9404ce1933f01a7aa8a43b229db44 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080thermal.h 27341c2b0ad4eb10044fdf9fc2377024b4c63297 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080bios.h e8d117ea0d596ed6415324bd136de337f1a36ff1 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080fan.h 359c6b06f2712a527d1ef08465179c14a8b4a751 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080acr.h ae428e2b33fd058eeaffbbd4fbcd42178345883c - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080nvlink.h 18ed4b62c824c252abdd89a6616e3cc325ffa7fa - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080dmabuf.h 1990d0c4fa84c6d078282d4d7d0624ccb0325ce7 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080unix.h 5ac6c9a299256935259eaf94323ae58995a97ad7 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080gpio.h d4ba227a522423503e5044c774dbcca692c48247 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080rc.h e4441458a7914414a2092f36a9f93389ed65154a - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080fuse.h ecd312fabb249a25655e151cee3615c5ab61ffa7 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080pmgr.h c1e506bd4bb6ad792c802961a9e03b371abb6919 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080flcn.h 5013ec94fa6311100818efb422b013ed77cffe82 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080gpu.h 86737d12192b2e7dc878bbeb8e57a41dcc1a655e - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080fb.h 920f69f6d8386a107160da834545f71172cc2f0f - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080boardobj.h bf976b3c428ccb9cb80d2f84f80b2c33d96e6ce1 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080perf.h 8b622186edb156e980d02bd59a71c01923d1aa23 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080tmr.h fed713e236b4fbc1e71dcf6747182ebea5836318 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080event.h b2eecbca32d87b939858bf0b22f93c06b49b3a04 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080i2c.h 3db5bcbcae4063f2356ec76924b4bcc1d0df1a05 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080ecc.h 55cee85b56cb6ed5d017bab55c40cc8799789c8b - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080nvd.h 66aa4e08f838e1f87e4babacb42d3d59cb6837ff - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080pmu.h 42dc8204c0f6da47c5f741344032fc02702cfac5 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080ucodefuzzer.h 59254e4bdc475b70cfd0b445ef496f27c20faab0 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080cipher.h 93a9fa93eb3d1099991e4682b6228124220ca293 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080fla.h cfa32c37f373eeef53aedc3f4dffff1634c122e8 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080gpumon.h 4f31fe752e050953a0f87d04063dc152bba261fe - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080clk.h 01a6a431e8aeffeec97755009b4e9575bdf0de7b - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080mc.h b8e8c5ccab01d7997d1fd5579a690cb3279a8ab3 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080base.h 22b8cc6c4677e664904659c726425a62aa24124e - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080fifo.h aa0f685b94bdae99a58aa1a45735b0593a2e6f5a - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080vfe.h 4c2af959d06536294d62b2366a6ba61ca744bd50 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080dma.h 5c7b955ef5e6f6ca9c0944e8a2b2c4a1ae760e04 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080spi.h 898fa08818b657c27b456d952e7a4e09d8d197ee - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080illum.h 4fa54b01cd70c3ca3b5cac93bade62dd09641b97 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080vgpumgrinternal.h 74f1abf45a2a0f60c82e4825b9abfa6c57cab648 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080power.h c30b5995d353e68623b32fea398f461351e3b8f1 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080lpwr.h 6c467ece3508071c2b3a296afffedd592726f8de - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080bus.h d411633fdeae66035e8c018ec8f6f25a9d5dd462 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080gr.h cfe695da65835f26c82399db0e44a56c7162c180 - src/common/sdk/nvidia/inc/ctrl/ctrl2080/ctrl2080pmumon.h 5f70c2eb6a144bc4d7ca8be63fa46391909e8201 - src/common/sdk/nvidia/inc/ctrl/ctrlc370/ctrlc370rg.h 2a00952f0f3988c5425fec957a19d926ae75ba28 - src/common/sdk/nvidia/inc/ctrl/ctrlc370/ctrlc370verif.h 6975ff971c7ed1ac1a429896a3be1d95353fa4bd - src/common/sdk/nvidia/inc/ctrl/ctrlc370/ctrlc370chnc.h 0710ae87ce40008bea9181310b755ed74c397bfe - src/common/sdk/nvidia/inc/ctrl/ctrlc370/ctrlc370event.h a8384da236fdd365d15d26daeb7db1c117ce1072 - src/common/sdk/nvidia/inc/ctrl/ctrlc370/ctrlc370base.h e8d883de767aa995a374d8da56b5c9da8787cb1d - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070system.h 3ab2fc007f2c76ddc89caf14c4db0ab530515d4a - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070verif.h 5f4b08b9ee7853eb33269ef7b415050eac2d702a - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070or.h 50f2ef0c01ab81077bd0e313d9ff168faae91670 - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070rg.h ce4e42c8e73047ae03f835f9d3655dda1eb44452 - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070base.h 53134475c1fd9c228a2c607051b34c28a5a80b03 - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070seq.h a138379dd76c468072f1862b8fc6ae79ee876b4e - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070common.h e3fb93f0ff3469ec76cecdc6f0bf1c296551a2b1 - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070impoverrides.h 0acaf597e0fc8f59a99b1772b7370395513492ed - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070event.h fa763827e4359b2deb6307ef742474f8f6f960dd - src/common/sdk/nvidia/inc/ctrl/ctrl5070/ctrl5070chnc.h 67a911b3177b75243e2fceef821ebcfd3668235e - src/common/sdk/nvidia/inc/ctrl/ctrl208f/ctrl208fgpu.h 9279520e7dec45516d5339d82d35eb60b88f7300 - src/common/sdk/nvidia/inc/ctrl/ctrl208f/ctrl208fbase.h ce19b7278c6720b3bee62bcaa763ebb322d91957 - src/common/sdk/nvidia/inc/ctrl/ctrla06f/ctrla06fgpfifo.h e919b586a0e44cfe96b819deeab2c21c6af34f55 - src/common/sdk/nvidia/inc/ctrl/ctrla06f/ctrla06finternal.h cebcfa209648731e86af526834717b19d5b24159 - src/common/sdk/nvidia/inc/ctrl/ctrla06f/ctrla06fevent.h 83d495dfe528167aa8ddbf45091051a89bd1a262 - src/common/sdk/nvidia/inc/ctrl/ctrla06f/ctrla06fbase.h 6bc78fd963e407de843598786bdbcd1653005328 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000diag.h a33a1c1173962183793d84276e46c61d27ca867e - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000gpuacct.h ebf415ac7d55643fa24493f27b69a843ea05f6c7 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000client.h dd49db523d761d6f14e3890549cd8186c25f1d62 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000event.h 4e7733c378eb6f7924e43ff111017ae0e433800d - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000vgpu.h 668e6d37c0a556a70ae003569fe237b1024d6e6b - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000nvd.h c341344b0879c5e9c7ba9ac0005eb28b347eaa63 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000system.h 1b594c39d1439c3d1ecc24c4325b2ea8c2724548 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000syncgpuboost.h 1cef17e1833c002d968a2255726a4f785e4e66e7 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000unix.h 899e3bc9a551ca0b181d1c8dd7ef8d779a66ecc4 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000gpu.h d08ef822e97ee56984618d52ed3ed55ee395eadb - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000gsync.h 5782a19aeaf9695c13940cf4532e41523a8460e3 - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000base.h 0146d2b3ecec8760e76dacd8ce6bb75c343c6cac - src/common/sdk/nvidia/inc/ctrl/ctrl0000/ctrl0000proc.h 92ff82d1045933baa79958a9f6efd451b0123e95 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080bsp.h 316494234df96c6af34cc0bd2b1c791dc42ac92b - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080unix.h 4f0ccb0667bd3e3070e40f3f83bede7849bc78e4 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080nvjpg.h 7edd8cdb8061ec137bc29d0dbbfbb5d169c0fd35 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080perf.h a3328cf6633f9b04258eff05ce30e66cc6930310 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080cipher.h 68bdc682ee42784c09409cd581bb991f7fc1bf41 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080msenc.h 12f1e560480dafde75646fb41aa349d9d729ca7d - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080host.h ec7b09fe14c31c175e0abfcfa85dee20d57d02b4 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080clk.h 12f1d3bb13c72fb1b52b62cf2a21f1b15619c06d - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080dma.h e238d87a94267f62141c413d0c44f03f27204b33 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080fifo.h 28b06c8f8152dce2b2e684a4ba84acd25a8b8c26 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080base.h ea6d95de011af0039b1adc209733e524bc583c92 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080fb.h e0c551dc47bc06f8dff5884affdeb05eb118609f - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080bif.h ccba5f12df1bce4b4235eed5a1c7a0cd2612c2ce - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080internal.h 8e85550f24771c87138a973cd8cd714e419a14e8 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080gpu.h 6fb840928970cf39919f2f415932bcc3e0764b25 - src/common/sdk/nvidia/inc/ctrl/ctrl0080/ctrl0080gr.h 33716a49ba4f7fcc0faa889d535e370a14edd582 - src/common/sdk/nvidia/inc/ctrl/ctrl83de/ctrl83dedebug.h c74ac448c3382d92e662804b56e73edd748e2678 - src/common/sdk/nvidia/inc/ctrl/ctrl83de/ctrl83debase.h 31534360d235be6dfdf4c1cf3854ce1e97be8fe2 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073dfp.h f9db227bd1cefe92e4f35b52cafcb15266630582 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073stereo.h 52f251090780737f14eb993150f3ae73be303921 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073dpu.h 456707a5de78815fc6a33f2da7e2a2a45ccc4884 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073internal.h d2992c1a9aac5b1b5cfefcca72e9a2401190158c - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073common.h 77eb4fab61225663a3f49b868c983d5d532ca184 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073svp.h f9f404124a718ace14803ebe84efe752fcef816b - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073specific.h 022feef64678b2f71ab70dc67d5d604054990957 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073psr.h 6ca26c7149455e43f32e8b83b74f4a34a24a2d29 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073base.h ff78c1bb58b1946f3e75e053be9f2b5de443e2f4 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073system.h abed22b35137e2d40399eb4ed01724aa789cb635 - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073event.h 505860d3cd6f7d5144f97195b9fb32dd5b8f74aa - src/common/sdk/nvidia/inc/ctrl/ctrl0073/ctrl0073dp.h 1066e2e0a0633b0dd1b9114f31079c30178a5ac8 - src/common/sdk/nvidia/inc/ctrl/ctrlc372/ctrlc372chnc.h 3f747a4fc98291329e0245a971248cf2c28a1b60 - src/common/sdk/nvidia/inc/ctrl/ctrlc372/ctrlc372base.h 41a588413e1b13f0f3eec6647ffc7023dfaf651f - src/common/sdk/nvidia/inc/alloc/alloc_channel.h 04ab1761d913030cb7485149ecd365f2f9c0f7da - src/common/sdk/nvidia/inc/class/cl0005_notification.h ddbffcce44afa7c07924fd64a608f7f3fe608ccc - src/common/sdk/nvidia/inc/class/cl0071.h e6818f1728a66a70080e87dac15a6f92dd875b4e - src/common/sdk/nvidia/inc/class/cl927d.h d90649c6a6c491bf086958426b56c697222e10bc - src/common/sdk/nvidia/inc/class/cl00fe.h e1bfd0c78f397e7c924c9521f87da8286bebe3f1 - src/common/sdk/nvidia/inc/class/cl84a0_deprecated.h dd4f75c438d19c27e52f25b36fc8ded1ce02133c - src/common/sdk/nvidia/inc/class/cl917cswspare.h 28867d69a6ceac83da53a11a5e1ef87d9476f0be - src/common/sdk/nvidia/inc/class/clc57d.h c61f8348c2978eef0a07191aaf92bd73e935f7bd - src/common/sdk/nvidia/inc/class/clc67e.h 2614a83d383b540f23ef721ec49af1dfde629098 - src/common/sdk/nvidia/inc/class/cl0080.h 05605d914edda157385e430ccdbeb3fcd8ad3c36 - src/common/sdk/nvidia/inc/class/cl9171.h f968cd35ce1d1d8e3bc2f669025e6b1042b35354 - src/common/sdk/nvidia/inc/class/cl00de.h 7c8e1f1055f9522cfb2935ea0aae612ef172c26e - src/common/sdk/nvidia/inc/class/clc370_notification.h 1efc9d4aa038f208cd19533f6188ac3a629bf31a - src/common/sdk/nvidia/inc/class/cl917a.h 435a34753d445eb9711c7132d70bd26df2b8bdab - src/common/sdk/nvidia/inc/class/cl917d.h 4fc2133935b8e560c9a1048bc0b1f1c2f0a4464c - src/common/sdk/nvidia/inc/class/cl00c1.h 326dbbeb275b4fc29f6a7e2e42b32736474fec04 - src/common/sdk/nvidia/inc/class/cl9571.h 31939808cd46382b1c63bc1e0bd4af953302773f - src/common/sdk/nvidia/inc/class/cl977d.h e0c9a155f829c158c02c21b49c083168f8b00cbe - src/common/sdk/nvidia/inc/class/clc37dswspare.h d301edef2d1dd42382670e5a6ceef0d8caf67d28 - src/common/sdk/nvidia/inc/class/cl90cd.h 7c7406d40a09372dcae2aaf3fcad225c3dd2cf3f - src/common/sdk/nvidia/inc/class/cl9010_callback.h 941a031920c0b3bb16473a6a3d4ba8c52c1259d7 - src/common/sdk/nvidia/inc/class/cl917e.h fb5ef3d6734a2ee6baba7981cdf6419d013cee85 - src/common/sdk/nvidia/inc/class/clc671.h 38265d86eb7c771d2d3fc5102d53e6a170a7f560 - src/common/sdk/nvidia/inc/class/cl0041.h bb79bbd1b0a37283802bc59f184abe0f9ced08a5 - src/common/sdk/nvidia/inc/class/cl0040.h a26ddc6c62faac1ecd5c5f43499aab32c70f32cb - src/common/sdk/nvidia/inc/class/clc67b.h b7a5b31a8c3606aa98ba823e37e21520b55ba95c - src/common/sdk/nvidia/inc/class/cl402c.h 9e1d2f90d77e23f1d2163a8f8d8d747058e21947 - src/common/sdk/nvidia/inc/class/cl9010.h 02ff42b6686954e4571b8a318575372239db623b - src/common/sdk/nvidia/inc/class/cl30f1_notification.h 6db83e33cb3432f34d4b55c3de222eaf793a90f0 - src/common/sdk/nvidia/inc/class/cl00b1.h fe7484d17bc643ad61faabee5419ddc81cf9bfd6 - src/common/sdk/nvidia/inc/class/cl9570.h 13f8e49349460ef0480b74a7043d0591cf3eb68f - src/common/sdk/nvidia/inc/class/clc57b.h 9f8a45cb986e3ad2bd4a8900469fe5f8b0c9463a - src/common/sdk/nvidia/inc/class/cl9870.h c40fd87fa6293d483b5bf510e2e331143ded9fa4 - src/common/sdk/nvidia/inc/class/cl9470.h bd9f406625e6c0cce816a5ddfb9078723e7f7fb5 - src/common/sdk/nvidia/inc/class/clb0b5sw.h 5416c871e8d50a4e76cbad446030dbedbe1644fd - src/common/sdk/nvidia/inc/class/cl00f2.h e63ed2e1ff3fe2a5b29cfc334d3da611db2aadf6 - src/common/sdk/nvidia/inc/class/clc37dcrcnotif.h cb610aaae807d182b4a2ee46b9b43ebfa4a49a08 - src/common/sdk/nvidia/inc/class/clc57e.h 513c505274565fa25c5a80f88a7d361ffbcb08c3 - src/common/sdk/nvidia/inc/class/cl0005.h dec74b9cf8062f1a0a8bbeca58b4f98722fd94b0 - src/common/sdk/nvidia/inc/class/cl0076.h 5df0ce4eb733554e963eb3c7938396f58f2dd4d5 - src/common/sdk/nvidia/inc/class/cl2081.h 8b75d2586151302d181f59d314b6b3f9f80b8986 - src/common/sdk/nvidia/inc/class/clc573.h ab27db8414f1400a3f4d9011e83ac49628b4fe91 - src/common/sdk/nvidia/inc/class/cl987d.h 02906b5ba8aab0736a38fd1f6d7b4f6026a5185b - src/common/sdk/nvidia/inc/class/clc57esw.h 5556b1c2e267d1fda7dee49abec983e5e4a93bff - src/common/sdk/nvidia/inc/class/cl2080_notification.h ff47d8a4b4bdb3b9cd04ddb7666005ac7fcf2231 - src/common/sdk/nvidia/inc/class/cl003e.h cef74c734fc7d2f32ff74095c59212d9e1d4cafc - src/common/sdk/nvidia/inc/class/cl84a0.h ef173136a93cdd2e02ec82d7db05dc223b93c0e1 - src/common/sdk/nvidia/inc/class/clc770.h 4a6444c347825e06bdd62401120553469f79c188 - src/common/sdk/nvidia/inc/class/cl917dcrcnotif.h 78259dc2a70da76ef222ac2dc460fe3caa32457a - src/common/sdk/nvidia/inc/class/clc37e.h 053e3c0de24348d3f7e7fe9cbd1743f46be7a978 - src/common/sdk/nvidia/inc/class/cl0004.h 9b2d08d7a37beea802642f807d40413c7f9a8212 - src/common/sdk/nvidia/inc/class/clc37d.h 89d4eeb421fc2be3b9717e333e9ff67bfffa24e8 - src/common/sdk/nvidia/inc/class/cl2080.h 2e3d5c71793820d90973d547d8afdf41ff989f89 - src/common/sdk/nvidia/inc/class/clc67a.h 2d76476dba432ffc1292d2d5dd2a84ff3a359568 - src/common/sdk/nvidia/inc/class/cl0092.h 60d0c7923699599a5a4732decfbcb89e1d77b69e - src/common/sdk/nvidia/inc/class/cl9770.h f5760f5054538f4ecf04d94fb1582a80a930bc29 - src/common/sdk/nvidia/inc/class/clc673.h 99a34eee22f584d5dfb49c3018a8cb9a7b1035ed - src/common/sdk/nvidia/inc/class/cl5070_notification.h 0285aed652c6aedd392092cdf2c7b28fde13a263 - src/common/sdk/nvidia/inc/class/cl00fc.h 95ca0b08eed54d1c6dd76fdf9cf4715007df1b20 - src/common/sdk/nvidia/inc/class/cl0020.h 992b395855033b4a1fa7536d0de6ab2d071a5f82 - src/common/sdk/nvidia/inc/class/clc77d.h 36c6162356ac39346c8900b1e0074e4b614d4b5a - src/common/sdk/nvidia/inc/class/clc370.h 204feb997ba42deab327d570e5f12235d5160f00 - src/common/sdk/nvidia/inc/class/clc57a.h b685769b5f3fed613227498866d06cc3c1caca28 - src/common/sdk/nvidia/inc/class/cl2082.h 83427e3172c64c3b9ef393205ccc3b961ec65190 - src/common/sdk/nvidia/inc/class/cl5070.h e72a7871d872b2eb823cc67c0a7d4cafb3d0ca18 - src/common/sdk/nvidia/inc/class/cl90ec.h 127f78d2bb92ef3f74effd00c2c67cf7db5382fe - src/common/sdk/nvidia/inc/class/clc67d.h 158c98c8721d558ab64a025e6fdd04ce7a16ba9e - src/common/sdk/nvidia/inc/class/cl947d.h bae36cac0a8d83003ded2305409192995d264d04 - src/common/sdk/nvidia/inc/class/cl0001.h da8d312d2fdc6012e354df4fa71ed62ae4aac369 - src/common/sdk/nvidia/inc/class/cl927c.h c2600834921f8a6aad6a0404076fa76f9bc1c04d - src/common/sdk/nvidia/inc/class/clc37b.h eac86d7180236683b86f980f89ec7ebfe6c85791 - src/common/sdk/nvidia/inc/class/cl957d.h 026f66c4cc7baad36f1af740ae885dae58498e07 - src/common/sdk/nvidia/inc/class/clc371.h 2f87e87bcf9f38017ad84417d332a6aa7022c88f - src/common/sdk/nvidia/inc/class/cl9471.h 0d8975eec1e3222694e98eb69ddb2c01accf1ba6 - src/common/sdk/nvidia/inc/class/cl0000_notification.h b29ba657f62f8d8d28a8bdd2976ef3ac8aa6075f - src/common/sdk/nvidia/inc/class/cl0073.h b71d1f698a3e3c4ac9db1f5824db983cf136981a - src/common/sdk/nvidia/inc/class/cl9170.h 15d1f928a9b3f36065e377e29367577ae92ab065 - src/common/sdk/nvidia/inc/class/cl0080_notification.h 11b19cb8d722146044ad5a12ae96c13ed5b122b6 - src/common/sdk/nvidia/inc/class/cl917b.h a23967cf3b15eefe0cc37fef5d03dfc716770d85 - src/common/sdk/nvidia/inc/class/clc372sw.h f3f33f70ec85c983acec8862ccaabf5b186de2bb - src/common/sdk/nvidia/inc/class/cl9270.h 20894d974d1f8f993c290463f1c97c71fd2e40b1 - src/common/sdk/nvidia/inc/class/cl30f1.h 9db39be032023bff165cd9d36bee2466617015a5 - src/common/sdk/nvidia/inc/class/cl0002.h 593384ce8938ceeec46c782d6869eda3c7b8c274 - src/common/sdk/nvidia/inc/class/cl900e.h 31ac68401e642baf44effb681d42374f42cf86b1 - src/common/sdk/nvidia/inc/class/cl00c3.h a3e011723b5863277a453bfcfb59ce967cee0673 - src/common/sdk/nvidia/inc/class/clc670.h 78efa8d42f828c89cd2a62b8c3931ebd0b0a6476 - src/common/sdk/nvidia/inc/class/clc771.h 9797f4758d534181eeaa6bc88d576de43ba56045 - src/common/sdk/nvidia/inc/class/clc574.h 060722ac6a529a379375bb399785cbf2380db4fd - src/common/sdk/nvidia/inc/class/clc373.h 022e8405220e482f83629dd482efee81cc49f665 - src/common/sdk/nvidia/inc/class/clc77f.h a7c7899429766c092ee3ecf5f672b75bef55216c - src/common/sdk/nvidia/inc/class/cl9271.h 95d99f0805c8451f0f221483b3618e4dbd1e1dd8 - src/common/sdk/nvidia/inc/class/cl90f1.h 74c75472658eea77d031bf3979dd7fe695b4293f - src/common/sdk/nvidia/inc/class/cl0092_callback.h a75d43f7b84d4cb39f8a2be35c12b2d2735f0ad9 - src/common/sdk/nvidia/inc/class/cl0000.h 16f9950a48c4e670b939a89724b547c5be9938bf - src/common/sdk/nvidia/inc/class/clc570.h c2d8bb02052e80cd0d11695e734f5e05ab7faeb5 - src/common/sdk/nvidia/inc/class/cl907dswspare.h a9503a5558b08071f35b11df9a917310947c378b - src/common/sdk/nvidia/inc/class/cl00da.h b1133e9abe15cf7b22c04d9627afa2027e781b81 - src/common/sdk/nvidia/inc/class/cl917c.h 866977d299eac812b41eb702a517e27bdc56e875 - src/common/sdk/nvidia/inc/class/clc37a.h 556d925de1e686243db36090cc35927f6d53c8bc - src/common/inc/nvUnixVersion.h b4c5d759f035b540648117b1bff6b1701476a398 - src/common/inc/nvCpuUuid.h 8c41b32c479f0de04df38798c56fd180514736fc - src/common/inc/nvBldVer.h d877f4b99ae7d18cc5c78b85e89c0a7e3f3e8418 - src/common/inc/nvPNPVendorIds.h ebccc5c2af2863509e957fe98b01d9a14d8b0367 - src/common/inc/nv_list.h e1fbb040ea9d3c773ed07deb9ef5d63c8c8cab7a - src/common/inc/nvSha1.h 62e510fa46465f69e9c55fabf1c8124bee3091c4 - src/common/inc/nvHdmiFrlCommon.h 4282574b39d1bcaf394b63aca8769bb52462b89b - src/common/inc/nvBinSegment.h 56f837b06862884abb82686948cafc024f210126 - src/common/inc/nvlog_defs.h e670ffdd499c13e5025aceae5541426ab2ab0925 - src/common/inc/gps.h 87bb66c50d1301edb50140e9896e1f67aaaa7175 - src/common/inc/nvVer.h d9c0905f374db0b9cc164ce42eab457d1ba28c53 - src/common/inc/nvop.h 6fa5359ffe91b624548c226b6139f241771a9289 - src/common/inc/jt.h b58ed1b4372a5c84d5f3755b7090b196179a2729 - src/common/inc/nv_speculation_barrier.h 8f0d91e1a8f0d3474fb91dc3e6234e55d2c79fcc - src/common/inc/rmosxfac.h 4df0a4ae78271bb5b295288798d5be7866242adc - src/common/inc/nvctassert.h 963aebc9ec7bcb9c445eee419f72289b21680cdd - src/common/inc/hdmi_spec.h a346380cebac17412b4efc0aef2fad27c33b8fb5 - src/common/inc/nvlog_inc2.h 5257e84f2048b01258c78cec70987f158f6b0c44 - src/common/inc/nvlog_inc.h 714db3678cd564170ec05022de6c37686da9df23 - src/common/inc/pex.h 90998aac8685a403fdec9ff875f7436373d76f71 - src/common/inc/displayport/dpcd14.h ee0105d1113ce6330939c7e8d597d899daae662e - src/common/inc/displayport/dpcd.h 1fc95a17ddb619570063f6707d6a395684bfa884 - src/common/inc/displayport/dpcd20.h 669268ea1660e9e5b876f90da003599ba01356bb - src/common/inc/displayport/displayport.h bbcecae47807b4578baa460da4147328140ecfcd - src/common/inc/swref/published/nv_ref.h 1efbc285d851a4430776a945d8c250b6a7019ab5 - src/common/inc/swref/published/nv_arch.h 38edc89fd4148b5b013b9e07081ba1e9b34516ac - src/common/inc/swref/published/turing/tu102/kind_macros.h 86a59440492fd6f869aef3509f0e64a492b4550d - src/common/inc/swref/published/turing/tu102/dev_mmu.h 64c123c90018c5ee122b02b02cbccfcd5ec32cab - src/common/inc/swref/published/t23x/t234/dev_fuse.h 3cddaacf90bbbefedf500e6af7eaefb0f007813c - src/common/inc/swref/published/disp/v03_00/dev_disp.h 1ea0c3d6ea0c79c01accc7b25d15b421ab49a55d - src/common/inc/swref/published/disp/v04_02/dev_disp.h 54c516f23671ec703a4e000f700c16dce640367a - src/common/modeset/timing/nvt_dmt.c cc04c12ebe4e2f7e31d0619ddd16db0c46b9db9e - src/common/modeset/timing/nvtiming.h 1997adbf2f6f5be7eb6c7a88e6660391a85d891b - src/common/modeset/timing/nvt_gtf.c cb1923187030de8ad82780663eb7151b68c3b735 - src/common/modeset/timing/displayid20.h 80063c05e3961073d23f76822bc9b55be533a6ee - src/common/modeset/timing/nvt_edid.c 58b68f1272b069bb7819cbe86fd9e19d8acd0571 - src/common/modeset/timing/edid.h 446e1044fcc8f7711111fca6a49d2776dba6e24c - src/common/modeset/timing/nvt_edidext_displayid.c aad5d6f2b238b9582a63ba1e467da13d86ee4ded - src/common/modeset/timing/dpsdp.h 49df9034c1634d0a9588e5588efa832a71750a37 - src/common/modeset/timing/nvt_cvt.c f75b1d98895bdccda0db2d8dd8feba53b88180c5 - src/common/modeset/timing/displayid.h 2868a1ecc76e5dd57535929890b922028522f4b5 - src/common/modeset/timing/nvt_edidext_861.c 5b1ce39d595dfb88141f698e73b0a64d26e9b31d - src/common/modeset/timing/nvt_dsc_pps.c 04693ced0777456f6b7005f19a4b7c39a6d20ee6 - src/common/modeset/timing/nvtiming_pvt.h 28d7b753825d5f4a9402aff14488c125453e95c5 - src/common/modeset/timing/nvt_tv.c 849309f12f14d685acf548f9eed35fadea10c4e7 - src/common/modeset/timing/nvt_edidext_displayid20.c 890d8c2898a3277b0fed360301c2dc2688724f47 - src/common/modeset/timing/nvt_util.c 783bd7a92ca178ca396b15e8027561c8b61c09a3 - src/common/modeset/timing/nvt_displayid20.c 974f52eb92bda6186510c71a2b6ae25cb0514141 - src/common/modeset/timing/nvt_dsc_pps.h 67db549636b67a32d646fb7fc6c8db2f13689ecc - src/common/modeset/hdmipacket/nvhdmipkt_9271.c f2b434ed8bdd7624143654b7b3953d8c92e5a8e2 - src/common/modeset/hdmipacket/nvhdmipkt_common.h e6d500269128cbd93790fe68fbcad5ba45c2ba7d - src/common/modeset/hdmipacket/nvhdmipkt_C371.c 60ee78d72d4d6b03932b7111508784538f35381a - src/common/modeset/hdmipacket/nvhdmipkt.c 443c0a4b17a0019e4de3032c93c5cac258529f01 - src/common/modeset/hdmipacket/nvhdmipkt_internal.h bb634bc2517a2653be2534602ab0f4712e0b1363 - src/common/modeset/hdmipacket/nvhdmipkt_9171.c 9fbe6313ee438f301ac75f5ca2228e27b785c4f4 - src/common/modeset/hdmipacket/nvhdmipkt_0073.c 54a1b5e5aaf0848a72befc896ed12f1de433ad4f - src/common/modeset/hdmipacket/nvhdmipkt_9471.c 5e12a290fc91202e4ba9e823b6d8457594ed72d3 - src/common/modeset/hdmipacket/nvhdmi_frlInterface.h 381e1b8aeaa8bd586c51db1f9b37d3634285c16a - src/common/modeset/hdmipacket/nvhdmipkt_class.h 9be7b7be94a35d1d9a04f269ff560dbbb7860a2a - src/common/modeset/hdmipacket/nvhdmipkt_9571.c 1babb2c7f11b95fd69bcbc9dcffeefea29d61118 - src/common/modeset/hdmipacket/nvhdmipkt_C671.c a1f52f0f78eec1d98b30b0f08bc1c5e88ae3d396 - src/common/modeset/hdmipacket/nvhdmipkt.h 4de33a60116ce3fa3f440db105561eddc21ce375 - src/common/shared/nvstatus/nvstatus.c a71d2c98bc2dc5445436cd96ac5c7e6a57efcf84 - src/nvidia/Makefile c5f16fdf43ca3d2845d120c219d1da11257072b0 - src/nvidia/nv-kernel.ld 3f7b20e27e6576ee1f2f0557d269697a0b8af7ec - src/nvidia/interface/nv-firmware-registry.h bff92c9767308a13df1d0858d5f9c82af155679a - src/nvidia/interface/nvacpitypes.h d02ee5bb3f19dffd8b5c30dc852cea243bcdf399 - src/nvidia/interface/acpidsmguids.h 75d3a4e35230b114a2a233be8235f19220d953a4 - src/nvidia/interface/nvrm_registry.h 60c7cafce7bd5240e8409e3c5b71214262347efc - src/nvidia/interface/acpigenfuncs.h 7dec210405c35d200be24bd1c0c81fcc6c3f93bf - src/nvidia/interface/deprecated/rmapi_deprecated.h f7b69924dbdf53be6cd184583145726aa65d3acd - src/nvidia/interface/deprecated/rmapi_deprecated_utils.c d81ef382635d0c4de47dfa3d709e0702f371ceb7 - src/nvidia/interface/rmapi/src/g_finn_rm_api.c 253baf641e4e29ede6a49129c2dd1415b7e5d9bd - src/nvidia/kernel/inc/nvpcf.h 6f9edcff7ad34c4e85ec7c0b8d79c175009d438c - src/nvidia/kernel/inc/objrpc.h 1feab39692ea8796ac7675f4780dfd51e6e16326 - src/nvidia/kernel/inc/objtmr.h 0cff83f4fdcc8d025cd68e0a12faaeead09fa03b - src/nvidia/kernel/inc/tmr.h b5f3932b9f6e7223e8c755155b60be98fd0a21df - src/nvidia/kernel/inc/vgpu/rpc_global_enums.h 961ed81de50e67eadf163a3a8008ce1fde1d880c - src/nvidia/kernel/inc/vgpu/rpc_hal_stubs.h 31deee778df2651d3d21b4d9c8ab180b8dc1ff14 - src/nvidia/kernel/inc/vgpu/rpc_vgpu.h 6006a612fcd546de794676da19fc431ddd0410e5 - src/nvidia/kernel/inc/vgpu/rpc.h 3477a139633890d3fdd2e5e02044e1a293566e3d - src/nvidia/kernel/inc/vgpu/rpc_headers.h 9b8e6b29a48ff022dda092cc8139dbe5ac6dedd8 - src/nvidia/generated/g_rs_client_nvoc.c d0a43a5d4941392b3c6c1b5a0d156edc26559ded - src/nvidia/generated/g_disp_inst_mem_nvoc.c f1e98f21f75eaba821fe16f2410921a4fd7c54ee - src/nvidia/generated/g_mem_mgr_nvoc.h b0089bee11caa0d8994b39eaecfb42ca3507de37 - src/nvidia/generated/g_syncpoint_mem_nvoc.h c2eae693c1b8d8502db368048f3b1c45d0576dc5 - src/nvidia/generated/g_chips2halspec_nvoc.h 0b2233e5cb68257231dd94310559bc09635c8279 - src/nvidia/generated/g_generic_engine_nvoc.c e41a55d75416e6d9978d2cf788553acdb9336afd - src/nvidia/generated/g_resource_nvoc.c 14336cd31573538728e0bf17941681b9d91d2b12 - src/nvidia/generated/g_gpu_access_nvoc.c b18ed7a5d71571b57266995f0d30317814e8bd6e - src/nvidia/generated/g_gpu_access_nvoc.h 76b1f545e3712a2f8e7c31b101acd9dd682c52f8 - src/nvidia/generated/g_traceable_nvoc.c 42fac2ccb00006825e7d42a6b23264870365ace6 - src/nvidia/generated/g_gpu_user_shared_data_nvoc.h b3b3ee6b514249e553187dc14a98f74bdd9fa6c6 - src/nvidia/generated/g_virt_mem_mgr_nvoc.h fcb89aff81d5e2b0a4a39069356ee4644bf53b2b - src/nvidia/generated/g_os_nvoc.c eefa27872e4acde78a18211b8ab51bc5436b6cfe - src/nvidia/generated/g_nv_debug_dump_nvoc.h 493a547850d9e7cdf74350de0e42aef2f66869a9 - src/nvidia/generated/g_client_resource_nvoc.h 3b08d4bb1612bb193cd2f26229b119cc43284879 - src/nvidia/generated/g_rs_server_nvoc.h 73a37ad59b9b13b61eb944748b6c2ba3cad7b630 - src/nvidia/generated/g_traceable_nvoc.h 19d73b04597bca6d3a7dd82d327e6cbf4a591a65 - src/nvidia/generated/g_eng_state_nvoc.c 0eb34617fea0cc6843d317ba7cea287483e39703 - src/nvidia/generated/rmconfig.h 17c69e14076324c230bbe68b55141089c1f4d10e - src/nvidia/generated/g_os_desc_mem_nvoc.h 1268ee54592c8ae1078b72bfaff882549efbcd3c - src/nvidia/generated/g_disp_capabilities_nvoc.c bdb198b18c700dc396f73191a8e696d106a1f716 - src/nvidia/generated/g_resource_nvoc.h b0f47afbc6aefce339db95801f48823989abad8a - src/nvidia/generated/g_mem_desc_nvoc.h 779103a57f68832641a7616ea8c5608780cfc155 - src/nvidia/generated/g_disp_objs_nvoc.h 2a3476812057692ef35f9658d24c275a1576f498 - src/nvidia/generated/g_sdk-structures.h 125b688444f16d9cb3902a9f79959c05c12397e3 - src/nvidia/generated/g_disp_sf_user_nvoc.c dbf11a9f931cfac248c3e6006bedeadb3d062670 - src/nvidia/generated/g_gpu_group_nvoc.c ecb4db5b676f0541c851ba9454577812e1a07023 - src/nvidia/generated/g_object_nvoc.c 9b4cf69383d0a7b7492b2fa28983cfe4d88c3263 - src/nvidia/generated/g_vaspace_nvoc.h d3b89f97bb0f4c5c0ca44e74040aab24c70ae06f - src/nvidia/generated/g_generic_engine_nvoc.h c1652e6cc404f23660ee440b61c6d0b9149ff593 - src/nvidia/generated/g_gpu_resource_nvoc.c 85580813dbcf78bf4aeecf5e55054447396dcfe3 - src/nvidia/generated/g_gpu_db_nvoc.c a97bf85ce6681aae086e0415aecaebf0208bfebb - src/nvidia/generated/g_tmr_nvoc.h 31270057a91fcd2dc7dbf1abed9e3f67d8db1787 - src/nvidia/generated/g_rmconfig_private.h e181d568b36f4d6e717d6d26c7bbe4b4ed968f4f - src/nvidia/generated/g_gpu_mgmt_api_nvoc.c 3b0e038829647cfe0d8807579db33416a420d1d2 - src/nvidia/generated/g_chips2halspec.h 4302502637f5c4146cb963801258444f2d8173e1 - src/nvidia/generated/g_allclasses.h 61cb019a28b25479d65022226623be2d20f32429 - src/nvidia/generated/g_nv_name_released.h 7f89931ecb53fb0b88da1be5489fe50e3d7897c3 - src/nvidia/generated/g_resserv_nvoc.h ac3965eea078f1998c3a3041f14212578682e599 - src/nvidia/generated/g_vaspace_nvoc.c a44899c21c77899b3b8deb7b2613b16841bbf397 - src/nvidia/generated/g_gpu_mgr_nvoc.c 631ac1d7bfa00f66e699937b8cabc0cbbc26d151 - src/nvidia/generated/g_rs_server_nvoc.c 67df2bc381609f290f173ea73f3e8125ac073888 - src/nvidia/generated/g_gpu_mgmt_api_nvoc.h 0e15fddc0426c42f3d22e5cb5609b5193adb7145 - src/nvidia/generated/g_standard_mem_nvoc.h 0a6b27d74e5e4ba872d77bfd369ddb5772abd8f8 - src/nvidia/generated/g_event_buffer_nvoc.h 9934a21ca6169499e471a2fc000c3eaee348391e - src/nvidia/generated/g_resource_fwd_decls_nvoc.h aac0c7df733e179f2a5906ab66b302a5bee82cbe - src/nvidia/generated/g_gpu_db_nvoc.h 47ced25e3252d402b9a5c30115705d16651ab460 - src/nvidia/generated/g_object_nvoc.h 81f915ae199df67c1884bfc18f3d23f20941af6a - src/nvidia/generated/g_dce_client_nvoc.c c8d6ddc934e0c4ae3fd2d2dc81d0d1a91c8b8d52 - src/nvidia/generated/g_disp_inst_mem_nvoc.h b30dc7b4114007f7649e18a7be2d829a3752447a - src/nvidia/generated/g_mem_nvoc.c 33932ed2752329a63bcafd88f00e69203c3621c0 - src/nvidia/generated/g_gpu_mgr_nvoc.h 2156c006acf83494e55de3d5604e9234f73b2867 - src/nvidia/generated/g_eng_desc_nvoc.h 6742231d4f59cc03ed822b80fb3995d1821de488 - src/nvidia/generated/g_standard_mem_nvoc.c a42b32adb0533fafb2de6b127c7e1939029cdeb5 - src/nvidia/generated/g_system_nvoc.c a044b01f708a5690f1796579904539791e24d5a3 - src/nvidia/generated/g_hda_codec_api_nvoc.h ddc0ac4e1d8b8aef15e147f1f85f8df37c196763 - src/nvidia/generated/g_hal_register.h fc7f913eab7ef26b877606e0593928784c3121ec - src/nvidia/generated/g_device_nvoc.c 9c03069f964e4d628b68a4ab0cff3b44aee82bdd - src/nvidia/generated/g_rpc-structures.h 8db5b2345278ce409562ca35754447d353dd54d7 - src/nvidia/generated/g_rs_resource_nvoc.h ad695d35b837b970b8f50a280d400ffed5067c0f - src/nvidia/generated/g_os_desc_mem_nvoc.c 14450b18d002d4e1786d4630ef4f1994c07ef188 - src/nvidia/generated/g_odb.h 93f9738c0e8aa715592306ddf023adf6b548dcc4 - src/nvidia/generated/g_nvh_state.h dad5def7d6c24268ac1e1a75038cbf33900745ff - src/nvidia/generated/g_binary_api_nvoc.h 06094e14a41e58c8a687bc8b64197a73c0c2b61a - src/nvidia/generated/g_system_nvoc.h 92c99fd64caa9f78664ed1fd54313ee82e2cf9c7 - src/nvidia/generated/g_disp_channel_nvoc.h e70cc806acae6fc1c3f4ffc283ded8351f3482c4 - src/nvidia/generated/g_hda_codec_api_nvoc.c 2239839c8a780a87e786439a49ab63e25d25001a - src/nvidia/generated/g_rmconfig_util.h e3078050c80bf14c9f91f12b43eab48af94c9ec5 - src/nvidia/generated/g_disp_objs_nvoc.c f9bdef39159a8475626a0edcbc3a53505a0ff80a - src/nvidia/generated/g_os_hal.h 57431742e2f1bbefc9142db49a84f4e8264e4673 - src/nvidia/generated/g_mem_list_nvoc.h 12cb2f4228fe81762587413c7f346f3d271d9b6b - src/nvidia/generated/g_eng_state_nvoc.h bfb7c703aa0e55ed5df9310a233861e43ef5c828 - src/nvidia/generated/g_prereq_tracker_nvoc.h 734ea4782083e4a7b940722577dc75177446eed1 - src/nvidia/generated/g_io_vaspace_nvoc.c 8b5821085e5aabc00408e7a90e78b2471de6797e - src/nvidia/generated/g_os_nvoc.h 5c65c680b77a501fd98460c4ce8fecd7ed95be14 - src/nvidia/generated/g_mem_mgr_nvoc.c cf2a81f40855ceb13b0dc18fb1ee790ba939bfb2 - src/nvidia/generated/g_event_buffer_nvoc.c d47bc1508583e02dc8234efce85fb7803dbd3d97 - src/nvidia/generated/g_hypervisor_nvoc.h 35889e5f6bdc996fa95c76d05e7b8902328d450b - src/nvidia/generated/g_rs_client_nvoc.h 61d09dd789fc4159344cec4c02ff9db13cd246eb - src/nvidia/generated/g_hal_mgr_nvoc.h af86a67a1c33acc193efa6dba8bc46ebe5dbb5eb - src/nvidia/generated/g_gpu_class_list.c aac848bd48955659eb5e07fcac70e6fe3c3a137a - src/nvidia/generated/g_hal_nvoc.c 1ca8ad4d9216aef1df145358c48e7ca533927e25 - src/nvidia/generated/g_objtmr_nvoc.c b35821f54f7ec965edd25a60e58d7639cd19df19 - src/nvidia/generated/g_hal_archimpl.h 97ce053e6b047ecd0803a7571d061516de9d95ff - src/nvidia/generated/g_hal_mgr_nvoc.c 972e9ba00890776dc3a4f51300cbcd73c1691c1d - src/nvidia/generated/g_rpc-message-header.h 906af83650985c58b63fe3e1f24b75b5ac62d90d - src/nvidia/generated/g_gpu_nvoc.c 431796f7485743a0848883a204676424b4a3b65f - src/nvidia/generated/g_hal.h 44bcd3503d90703a33a7bb9c75b41111d092c5f8 - src/nvidia/generated/g_client_resource_nvoc.c 142a5e1b07a3bbe2952b27f4a65a133f5a100dc3 - src/nvidia/generated/g_prereq_tracker_nvoc.c 3c7d16d75ef53c09d7076c55976e71fd17a3f483 - src/nvidia/generated/g_subdevice_nvoc.h 7c698deeb69b4e92af3c7c4e6fc6274b75dab05c - src/nvidia/generated/g_disp_channel_nvoc.c 9b0d4695e84ec959790dd553944cb44685c5c251 - src/nvidia/generated/g_event_nvoc.h 803eb8b520597468e3dc99ecd29ffc1027dfe4be - src/nvidia/generated/g_context_dma_nvoc.h 09597f23d6a5440258656be81e7e6709390128f8 - src/nvidia/generated/g_hal_private.h b459db8ccf299f7bda0fa9fa18ef1e3aeb2996eb - src/nvidia/generated/g_gpu_user_shared_data_nvoc.c 170a42c047d0085873a48db0d83d59feb8dc327f - src/nvidia/generated/g_binary_api_nvoc.c 47f006ce959471f8ecd2a7b05d83d854610a521b - src/nvidia/generated/g_system_mem_nvoc.c b9f25e208f5ea6f566dbd9cbcaaa30cd0786c31b - src/nvidia/generated/g_client_nvoc.h 31ee3939e0830f960aeb854827af0aace0dddb93 - src/nvidia/generated/g_kern_disp_nvoc.h eb95c379eec668bfd697bcd4977d4f18da0b56bb - src/nvidia/generated/g_device_nvoc.h 1d66bab50a7d39faa2b0fec469a4512d2c7610d5 - src/nvidia/generated/g_rmconfig_util.c a1bfb789c1e23bac2b7a31255b7d738e40a290f2 - src/nvidia/generated/g_mem_nvoc.h b5d4219786bd77483ce70a770caac52db51566cc - src/nvidia/generated/g_ioaccess_nvoc.c 97bab26b95f21f4618fd023284b20dd4d5a76ad4 - src/nvidia/generated/g_disp_capabilities_nvoc.h b378d336af4d5cb4b1fb13b85042fad1fe02f4cc - src/nvidia/generated/g_journal_nvoc.h 16c7821c01a4e728d66a25ca6eb824ce85ff908e - src/nvidia/generated/g_rs_resource_nvoc.c 6771b718fe182d524864f55fa23f145012205d5b - src/nvidia/generated/g_objtmr_nvoc.h 87c14e1c1a8f37f139f6a99efaf7752d6db48db5 - src/nvidia/generated/g_kern_disp_nvoc.c 4f3ff51033e4ef9491e8b345ffea36dfb5122055 - src/nvidia/generated/g_chips2halspec_nvoc.c 8a76494ebc5809ed30c31a9afa2a46bf2463e6e5 - src/nvidia/generated/g_dce_client_nvoc.h e4ccb216aafed837a37fca90284b0a0413b3080d - src/nvidia/generated/g_kernel_head_nvoc.c 262192e794cba0bb120cbfe75ee037e868e34ef3 - src/nvidia/generated/g_subdevice_nvoc.c 71185f1534d3c53954c271566b610045aef3ed98 - src/nvidia/generated/g_system_mem_nvoc.h 549314acf103e21a4cab113114f719626202a19f - src/nvidia/generated/g_tmr_nvoc.c c010d93fd293ec399a0cd05662a177e7251c7b1e - src/nvidia/generated/g_event_nvoc.c 693cd3e7b93e9377634800ff2b3669939ba10603 - src/nvidia/generated/g_kernel_head_nvoc.h 0097015ef25011bee849966ef5248d206ab0f816 - src/nvidia/generated/g_gpu_resource_nvoc.h dc922421b0f41b7b8f0219caa623c099fc3f083d - src/nvidia/generated/g_ioaccess_nvoc.h 5a46be3060122eca672dc3bf11bdb6e68700b5e4 - src/nvidia/generated/g_gpu_halspec_nvoc.h 10645f82dd031d0aa6f4a3dfc039ef776f2fdee9 - src/nvidia/generated/g_hal_nvoc.h 574adefb17ee3e2a7d85262f8ce4d8b4bc4367b4 - src/nvidia/generated/g_gpu_halspec_nvoc.c 653b72892f7c3ce7fd3e28690863ef89826b5314 - src/nvidia/generated/g_context_dma_nvoc.c 3b1586e0aebb66d31190be64b1109232ee3467bf - src/nvidia/generated/g_ref_count_nvoc.h 155b6249c4fd472218cef640fa0a665cec10bfa4 - src/nvidia/generated/g_disp_sf_user_nvoc.h 2cac1d138a8bcf99e70068f50698f6cdd3dc57dd - src/nvidia/generated/g_syncpoint_mem_nvoc.c 6aea089965620df057ab6b900496590ca26772b2 - src/nvidia/generated/g_virt_mem_mgr_nvoc.c 8e8c58d6e99de01acf926026506ab91499109dd4 - src/nvidia/generated/g_gpu_nvoc.h 8f1b0c4a6b75280b5155aef8490c95237bbf6f97 - src/nvidia/generated/g_gpu_group_nvoc.h d960a819d29d7e968eaab0e7a29897426b7ba646 - src/nvidia/generated/g_io_vaspace_nvoc.h 47bed9b41213c837c4ca08aaaefe079b84dfd52f - src/nvidia/generated/g_client_nvoc.c 36b3993cc05598590bc6356bab5ea7c0a2efd2f0 - src/nvidia/src/kernel/gpu_mgr/gpu_mgr.c 719d890f8160efe57e4c3267db65885ebb66cd03 - src/nvidia/src/kernel/gpu_mgr/gpu_db.c 37d1e3dd86e6409b8e461f90386e013194c9e4d1 - src/nvidia/src/kernel/gpu_mgr/gpu_mgmt_api.c d5d8ff429d3bda7103bafcb2dca94678efc8ddd8 - src/nvidia/src/kernel/gpu_mgr/gpu_group.c 4e1be780ac696a61f056933e5550040a2d42c6bd - src/nvidia/src/kernel/gpu/gpu_device_mapping.c 381cbcd5c362e5c5563806bfff2fb60eec80eda2 - src/nvidia/src/kernel/gpu/gpu.c cb9af9dcd3931eb62bfdb4872c4e3001ff9def26 - src/nvidia/src/kernel/gpu/gpu_rmapi.c bfcdb98c6541f95c3a37aaa25e9ca51ec2a0b9c1 - src/nvidia/src/kernel/gpu/eng_state.c 6fa4ba2da905692cd39ec09054f2bd6621aa2a7a - src/nvidia/src/kernel/gpu/gpu_resource_desc.c ceb3639a86578b9d823a00a9a6553f278acb558f - src/nvidia/src/kernel/gpu/gpu_resource.c bca16e8ff1697e953a54a3a3de4273f5584ac0df - src/nvidia/src/kernel/gpu/device_ctrl.c 493e90398cb78a3f24d2f271bbedebd8c682d7c1 - src/nvidia/src/kernel/gpu/gpu_gspclient.c 1653c7b99cfc86db6692d9d8d6de19f1b24b9071 - src/nvidia/src/kernel/gpu/gpu_uuid.c a4225e0074c1aee00d082f69231d1d8e7d812347 - src/nvidia/src/kernel/gpu/gpu_access.c 207b32d1423f3666feeedb85d38fa7a924c1f7a9 - src/nvidia/src/kernel/gpu/device_share.c 29458992dabff6c2550e0202b11dc47cd7f66cd5 - src/nvidia/src/kernel/gpu/gpu_engine_type.c 89543f7085fbc2ca01b5a8baae33b5de921c79e9 - src/nvidia/src/kernel/gpu/gpu_t234d_kernel.c 3229e9f5d2779147d337e9c6a7b6f518079f1709 - src/nvidia/src/kernel/gpu/gpu_timeout.c c2228fbf8366e197aec9bb75ad2c01b267aedeb7 - src/nvidia/src/kernel/gpu/gpu_user_shared_data.c cf85f6ecacf40fa649de2c443595e2313fa364d6 - src/nvidia/src/kernel/gpu/device.c cffbdcaacd4fd5be809fc81bd76a384920781391 - src/nvidia/src/kernel/gpu/timer/timer.c 17e9f2af953c3cf96d0eee9cfea3aad6e540c3cf - src/nvidia/src/kernel/gpu/timer/timer_ostimer.c 5a053caaa8eb655d9e0f7ab42ec1b3f0b72fb787 - src/nvidia/src/kernel/gpu/dce_client/dce_client_rpc.c 7f9874d9af6b937dac888a3ebb55a82c2a5de71b - src/nvidia/src/kernel/gpu/dce_client/dce_client.c 1f4d15f959df38f4f6ea48c7b10fc859c6e04b12 - src/nvidia/src/kernel/gpu/audio/hda_codec_api.c d852ad5a6af96e173832833379ae9d38baaed47f - src/nvidia/src/kernel/gpu/subdevice/subdevice_ctrl_timer_kernel.c 086e9a51757c3989dfe0bf89ca6c0b9c7734104a - src/nvidia/src/kernel/gpu/subdevice/generic_engine.c c9ec73f6e2f2e87371b97ec47a65c3874dd4949a - src/nvidia/src/kernel/gpu/subdevice/subdevice_ctrl_gpu_kernel.c 3d0b8b3dabe8aab7884f1ddec7ef4f9715de31ad - src/nvidia/src/kernel/gpu/subdevice/subdevice_ctrl_event_kernel.c ba49fc89b1a453aca3a79f51d3250c7c0a667327 - src/nvidia/src/kernel/gpu/subdevice/subdevice.c 8ce824bfdb06f08567a29ee5e175106c32611182 - src/nvidia/src/kernel/gpu/disp/disp_channel.c 6437dd659a38c62cd81fb59f229bd94e59f37e71 - src/nvidia/src/kernel/gpu/disp/disp_sf_user.c c3d94d9a49e1c0dffd8987d9b007a9cef91be561 - src/nvidia/src/kernel/gpu/disp/disp_object_kern_ctrl_minimal.c 4b783bc279ea35c4b7e101a668d136f1a12d9030 - src/nvidia/src/kernel/gpu/disp/kern_disp.c 681499b2c86582cd110ede079d757c5797c4b458 - src/nvidia/src/kernel/gpu/disp/disp_common_kern_ctrl_minimal.c 1533c870f3e6521f180eb967f7144a62a727d125 - src/nvidia/src/kernel/gpu/disp/disp_objs.c ceb516c8064e1df2d18897f98f5c8ea58e907973 - src/nvidia/src/kernel/gpu/disp/disp_capabilities.c 84fdcdf90d9a656a572774fb8330f7a1fa9f59e2 - src/nvidia/src/kernel/gpu/disp/inst_mem/disp_inst_mem.c 629566bf98be863b12e6dc6aab53d8f5ea13988c - src/nvidia/src/kernel/gpu/disp/inst_mem/arch/v03/disp_inst_mem_0300.c 0156d5407cf877b8f5c79823d3c83ead54b6385c - src/nvidia/src/kernel/gpu/disp/head/kernel_head.c 8a418dce9fbeb99d5d6e175ed8c88811866f3450 - src/nvidia/src/kernel/gpu/disp/arch/v04/kern_disp_0402.c e7f143390807f3f4d4bf6586068378a9f5a75d57 - src/nvidia/src/kernel/gpu/disp/arch/v03/kern_disp_0300.c 611098328a114b66c6dcea4a8ea710887db006c4 - src/nvidia/src/kernel/gpu/arch/t23x/kern_gpu_t234d.c 3c463773f2f970b1764edb231d349164fe4341fc - src/nvidia/src/kernel/gpu/mem_mgr/mem_desc.c c6e78a54a1b8d4ca6fe4b01d83e3199ea41606d7 - src/nvidia/src/kernel/gpu/mem_mgr/context_dma.c f30ae0e8e1e32d0adb7e52b8995c277637b6bc2a - src/nvidia/src/kernel/gpu/mem_mgr/mem_utils.c 2bb921b462c4b50d1f42b39b4728374c7433c8cb - src/nvidia/src/kernel/gpu/mem_mgr/arch/turing/mem_mgr_tu102_base.c c8c4af5a28740f1e66ff4e6e9c47fc6c981ce46b - src/nvidia/src/kernel/os/os_timer.c 0e0c1b862bdba245297ffd4f725001fa2439cddf - src/nvidia/src/kernel/os/os_sanity.c 1dc0be7577b4f7914743379943bcf0d5e236eb0b - src/nvidia/src/kernel/os/os_stubs.c 1fad27934185df50c1d91b5536d0df437618382f - src/nvidia/src/kernel/os/os_init.c df7ac5873dc42eafc335a1ddba095fbc8cd1d708 - src/nvidia/src/kernel/core/locks_common.c 61691e21cdabc8919d7b41142c97f510db9c0cc6 - src/nvidia/src/kernel/core/locks_minimal.c 8adbda67510ec9fab31edd681c51ddfb7b190d7d - src/nvidia/src/kernel/core/thread_state.c db40522057f29afe6624e33468879e5e9813f07c - src/nvidia/src/kernel/core/system.c afbf166f49a964873a13e19b787cae33813f9de5 - src/nvidia/src/kernel/core/hal_mgr.c 8eac3ea49f9a53063f7106211e5236372d87bdaf - src/nvidia/src/kernel/core/hal/info_block.c afa03f17393b28b9fc791bf09c4d35833447808d - src/nvidia/src/kernel/core/hal/hal.c c38181e1361a59e3252ae446a0e8761363db35e7 - src/nvidia/src/kernel/core/hal/hals_all.c b3a29311cc22e2dae686f8ed2df6bc828aa826cf - src/nvidia/src/kernel/diagnostics/profiler.c fc39cb6ac6e9d73bd1ab98890e6b253217d6cc90 - src/nvidia/src/kernel/diagnostics/nvlog_printf.c 8192d2364dc63171b51f6ced5b1726125f1a8ff6 - src/nvidia/src/kernel/diagnostics/nvlog.c 2aa207714971c97d9486c1ed48a3123e40b6c4ff - src/nvidia/src/kernel/rmapi/rmapi_cache.c 79a130d1e1e10881ea1e5f5d8dfcb84ceb53b0f2 - src/nvidia/src/kernel/rmapi/client_resource.c 0bded8ce6e3e81de589c4e6fbb611085c705dfcd - src/nvidia/src/kernel/rmapi/event_notification.c 7fdf8e379fd2a5eeae0981bf7328163379279c29 - src/nvidia/src/kernel/rmapi/rmapi_stubs.c fb2a191dc60c1232c198b1ff9a302883302ca526 - src/nvidia/src/kernel/rmapi/resource_list_required_includes.h bac6ef63d11e87f9a4af3318d5be6860f861a0b9 - src/nvidia/src/kernel/rmapi/rpc_common.c 25ac4188ba55b098321700828a9386a8a6e9f80b - src/nvidia/src/kernel/rmapi/event_buffer.c a418377318e121a2b2f83f3961da74f09a2123d0 - src/nvidia/src/kernel/rmapi/event.c 5166298f09865066535a3e04c111354ceaefbcbc - src/nvidia/src/kernel/rmapi/control.c ac6a5b3adf15eac4a7bd9ae24981f6f5fc727097 - src/nvidia/src/kernel/rmapi/deprecated_context.h a2ad052692006f70e97fd3d186f19c7ddfe80c4c - src/nvidia/src/kernel/rmapi/deprecated_context.c 19d3213dc7471e7a7d4ff379494f724869638d28 - src/nvidia/src/kernel/rmapi/mapping_cpu.c 8cc578a1e5f534e911ba4b49b58352ef9ea57772 - src/nvidia/src/kernel/rmapi/client.c cb6835f318c0d871d72185e0ac410d03d788654a - src/nvidia/src/kernel/rmapi/binary_api.c c59a08852553b5843beec8138caa8e2141d3d759 - src/nvidia/src/kernel/rmapi/resource_desc_flags.h d964061679e6f3da0e6e6c3b8e0eb93eb31fd3dc - src/nvidia/src/kernel/rmapi/resource.c 96f763eef08f1954d3f07639053db2cde2a01e39 - src/nvidia/src/kernel/rmapi/rmapi.c b4dc306ae4d4f8850571e2fbbed0114d63f1ba93 - src/nvidia/src/kernel/rmapi/entry_points.c 3b53d6b8ef183702327b4bc3a96aa06f67475ddc - src/nvidia/src/kernel/rmapi/param_copy.c 7a4e3a3369efd50c9d80eaa73c48852edd6e6966 - src/nvidia/src/kernel/rmapi/rs_utils.c f04faaeeeda2d799207fd7e0877a2bb6d5363c13 - src/nvidia/src/kernel/rmapi/mapping.c b001f31a373973b7a4568c411e261aa8f7487441 - src/nvidia/src/kernel/rmapi/alloc_free.c d6b3b8ac45ede7530028848749820d2cbe0f5d55 - src/nvidia/src/kernel/rmapi/resource_desc.h ea7b6b816ca16af62c0b2040b8a76c6c10a16053 - src/nvidia/src/kernel/rmapi/resource_list.h b28d140f1bfe0aac770127e8391400d44d5582e3 - src/nvidia/src/kernel/rmapi/rmapi_finn.c 682977753c878ccee6279e539cf11bee2b548752 - src/nvidia/src/kernel/rmapi/resource_desc.c 9b1453ed00d80034a0d2e3e918d31dbe939177b0 - src/nvidia/src/kernel/rmapi/rmapi_utils.c bb67ea7ef87ff0148473ebf1165e3afd59d63b20 - src/nvidia/src/kernel/rmapi/sharing.c c4eeb6d566366ab2b9532f109632d4e14539332c - src/nvidia/src/kernel/rmapi/entry_points.h a14b8d9a6e029d8a5c571283b520645a562b5c2c - src/nvidia/src/kernel/mem_mgr/vaspace.c 5b9048e62581a3fbb0227d1a46c4ee8d8397bf5b - src/nvidia/src/kernel/mem_mgr/mem_mgr_internal.h 623dad3ec0172ed7b3818caece0db5687d587ff3 - src/nvidia/src/kernel/mem_mgr/os_desc_mem.c 38b2ed45dc7d7d7172f6d0fd2be31b43e49e41d5 - src/nvidia/src/kernel/mem_mgr/virt_mem_mgr.c ed8316b9cbfe13336af1f8e4cd0b492a21af44b9 - src/nvidia/src/kernel/mem_mgr/syncpoint_mem.c e75d8a0eb4c22e11ececd24a43ad034bb76f12ce - src/nvidia/src/kernel/mem_mgr/standard_mem.c 630200d06b6588d7fa8c5b1ea16146e8281163d7 - src/nvidia/src/kernel/mem_mgr/io_vaspace.c 223b7541c7904067914a01e4aa3e589fd1690cb6 - src/nvidia/src/kernel/mem_mgr/system_mem.c 3080c8404e554eba5eac3f6482ed6094d25ccdef - src/nvidia/src/kernel/mem_mgr/mem.c 24928c8b4e8b238f1921a1699f3af59bcff994ed - src/nvidia/src/lib/base_utils.c a6134d6f5f3e3b0b4c274eb3b2d0a146644c842b - src/nvidia/src/lib/zlib/inflate.c c8f4cf70923179b7c2aaa6bd6b3eedc195655abe - src/nvidia/src/libraries/containers/vector.c 8991136ccb86f511f60254955ac3d86072b071f2 - src/nvidia/src/libraries/containers/map.c 864bd314450490b687a652335a44fb407835152c - src/nvidia/src/libraries/containers/ringbuf.c 6553a1c368e9d9709fb89b5e43524757f786c58b - src/nvidia/src/libraries/containers/queue.c 5940d69147d1376b03cd96fa69796360b279ae97 - src/nvidia/src/libraries/containers/list.c 23c328fc27ad0317efe6ccd2da71cfd9db9da236 - src/nvidia/src/libraries/containers/multimap.c ea3254ebd278d9efb7dd348e52370d780c23cd94 - src/nvidia/src/libraries/containers/eheap/eheap_old.c 9c80df385a47834da4f92dc11053ca40a37a7fe7 - src/nvidia/src/libraries/containers/btree/btree.c cccb1fedee02a240692688090e00ac1e289dec9e - src/nvidia/src/libraries/tls/tls.c 0e7a9b9c697f260438ca5fda8527b0f4edc2de13 - src/nvidia/src/libraries/prereq_tracker/prereq_tracker.c 619f9f6df576ad20d32c30fd9a69733dc5c19da8 - src/nvidia/src/libraries/eventbuffer/eventbufferproducer.c ee7ea17829dfbbf9e6cd8d6c6fb2ada086b5d36e - src/nvidia/src/libraries/ioaccess/ioaccess.c 702c73446bba35f88249cfe609ac0ca39dbd80ff - src/nvidia/src/libraries/nvport/crypto/crypto_random_xorshift.c f0c486c1ad0f7d9516b13a02d52b4d857d8865b1 - src/nvidia/src/libraries/nvport/util/util_compiler_switch.c a045a19d750d48387640ab659bb30f724c34b8c8 - src/nvidia/src/libraries/nvport/util/util_unix_kernel_os.c d047abe66dd8a459c15224cc056fc6f2176b0c6a - src/nvidia/src/libraries/nvport/util/util_gcc_clang.c b387005657f81538fab5962d4aabbc5dc681aa1b - src/nvidia/src/libraries/nvport/core/core.c 9b69fbf3efea6ba58f9ba7cb0189c9264c994657 - src/nvidia/src/libraries/nvport/sync/sync_common.h eb8b5fcab51c47f58a37958ddb38ff90991bcbbe - src/nvidia/src/libraries/nvport/sync/sync_unix_kernel_os.c b2ae1406c94779f575d3e2233a7ab248ac10e74f - src/nvidia/src/libraries/nvport/sync/inc/sync_unix_kernel_os_def.h 099c17e5931d5d881d8248ec68041fa0bbc2a9bc - src/nvidia/src/libraries/nvport/thread/thread_unix_kernel_os.c a305654bafc883ad28a134a04e83bbd409e0fc06 - src/nvidia/src/libraries/nvport/cpu/cpu_common.h 9ca28a5af5663dec54b4cd35f48a8a3d8e52e25f - src/nvidia/src/libraries/nvport/cpu/cpu_common.c 8f41e7127a65102f0035c03536c701b7ecdaa909 - src/nvidia/src/libraries/nvport/string/string_generic.c caff00b37e7f58fde886abcc2737c08526fa089e - src/nvidia/src/libraries/nvport/memory/memory_generic.h c5a16e5bb7d304ffe5e83d7b27226cbecdbc7ce1 - src/nvidia/src/libraries/nvport/memory/memory_unix_kernel_os.c 3e3ab114d56dfcecc2886d8f9cdb8f365c5093c7 - src/nvidia/src/libraries/nvport/memory/memory_tracking.c 522da5465e5596d48cf6393c329811f3c708be19 - src/nvidia/src/libraries/resserv/src/rs_resource.c 1f2e9d09e658474b36d0b0ecd9380d0d2bcc86b2 - src/nvidia/src/libraries/resserv/src/rs_domain.c 0c9581aa68a77cb9977a7fbcfd2077ccb618206e - src/nvidia/src/libraries/resserv/src/rs_access_rights.c f55556cd2392f55f2609ef69fca1caf2dd348e3f - src/nvidia/src/libraries/resserv/src/rs_server.c 310a8d3442285113f4ba672ba7fcc7f2aa295c6a - src/nvidia/src/libraries/resserv/src/rs_client.c dac54d97b38ad722198ec918668f175dc5122e4e - src/nvidia/src/libraries/resserv/src/rs_access_map.c cf48c6335eb7ff27cd7cae0faad77dd98669ad95 - src/nvidia/src/libraries/utils/nvassert.c d3e5f13be70c8e458401ec9bdad007dfadedcc11 - src/nvidia/src/libraries/nvbitvector/nvbitvector.c 4cfe1ebd2ad6968ed513025aed61ecf2127aa683 - src/nvidia/src/libraries/nvoc/src/runtime.c b417d06ed1845f5ed69181d8eb9de6b6a87fa973 - src/nvidia/arch/nvalloc/common/inc/nv-firmware.h d1089d8ee0ffcdbf73a42d7c4edb90769aa79d8c - src/nvidia/arch/nvalloc/common/inc/nvrangetypes.h 499e72dad20bcc283ee307471f8539b315211da4 - src/nvidia/arch/nvalloc/unix/include/nv-unix-nvos-params-wrappers.h 1e89b4a52a5cdc6cac511ff148c7448d53cf5d5c - src/nvidia/arch/nvalloc/unix/include/os_custom.h 507d35d1d4c5ba94ef975f75e16c63244d6cd650 - src/nvidia/arch/nvalloc/unix/include/nv-ioctl.h 2d644a3f78bcda50e813b25156e9df07ec6da7b8 - src/nvidia/arch/nvalloc/unix/include/nv.h 3c61881e9730a8a1686e422358cdfff59616b670 - src/nvidia/arch/nvalloc/unix/include/nv_escape.h e69045379ed58dc0110d16d17eb39a6f600f0d1d - src/nvidia/arch/nvalloc/unix/include/nv-ioctl-lockless-diag.h 3a26838c4edd3525daa68ac6fc7b06842dc6fc07 - src/nvidia/arch/nvalloc/unix/include/nv-gpu-info.h 1a98a2aaf386cd3d03b4b5513d6a511c60f71c2c - src/nvidia/arch/nvalloc/unix/include/nv-reg.h 5f2a30347378f2ed028c9fb7c8abea9b6032141c - src/nvidia/arch/nvalloc/unix/include/osapi.h 4750735d6f3b334499c81d499a06a654a052713d - src/nvidia/arch/nvalloc/unix/include/nv-caps.h ae7d5cb2c57beeea12724e09d957e233a71c12a1 - src/nvidia/arch/nvalloc/unix/include/nv-priv.h 1d8b347e4b92c340a0e9eac77e0f63b9fb4ae977 - src/nvidia/arch/nvalloc/unix/include/nv-ioctl-numbers.h 9c7b09c55aabbd670c860bdaf8ec9e8ff254b5e9 - src/nvidia/arch/nvalloc/unix/include/nv-kernel-rmapi-ops.h 7188b83b28051b40cda60f05cacfa12b94ade4dc - src/nvidia/arch/nvalloc/unix/include/osfuncs.h de6913c5e5092a417530ac9f818497824eab7946 - src/nvidia/arch/nvalloc/unix/include/os-interface.h ddfedb3b81feb09ea9daadf1a7f63f6309ee6e3b - src/nvidia/arch/nvalloc/unix/include/rmobjexportimport.h a28937330829b4f27a9da5e2c3776ceb293b6085 - src/nvidia/arch/nvalloc/unix/src/os-hypervisor-stubs.c 6ca29f3d6b38fb5d05ff222cd1b79ade811a74b2 - src/nvidia/arch/nvalloc/unix/src/osunix.c 8f725a01c2a29658580936a87bdd33308030a332 - src/nvidia/arch/nvalloc/unix/src/os.c 866073d8caaa58055268aa5b3548eec6e1168d04 - src/nvidia/arch/nvalloc/unix/src/exports-stubs.c 63edc719390a814eb70290e709634d133ad198cc - src/nvidia/arch/nvalloc/unix/src/osmemdesc.c 690927567b5344c8030e2c52d91f824bb94e956c - src/nvidia/arch/nvalloc/unix/src/registry.c eccfc4f261fd8531254eb2961120073aac9847db - src/nvidia/arch/nvalloc/unix/src/rmobjexportimport.c 4971626589ae66cc273ad11b80f0ab875fb39c05 - src/nvidia/arch/nvalloc/unix/src/osapi.c 68d80083483bf4976d6d83153a3880e5949e0824 - src/nvidia/arch/nvalloc/unix/src/osinit.c 69d2719c759456a22ccc4de470e5d15cf0c3d26c - src/nvidia/arch/nvalloc/unix/src/escape.c b5b409625fde1b640e4e93276e35248f0fccfa4c - src/nvidia/arch/nvalloc/unix/src/gcc_helper.c 11c6d988bccbdf49ac241d77e6363c7843a0191f - src/nvidia/arch/nvalloc/unix/src/power-management-tegra.c 8ef620afdf720259cead00d20fae73d31e59c2f7 - src/nvidia/inc/kernel/virtualization/hypervisor/hypervisor.h 5b151d0d97b83c9fb76b76c476947f9e15e774ad - src/nvidia/inc/kernel/gpu_mgr/gpu_mgr.h ea32018e3464bb1ac792e39227badf482fa2dc67 - src/nvidia/inc/kernel/gpu_mgr/gpu_group.h 2c48d7335bdb0b7ea88b78216c0aeab2e11e00c1 - src/nvidia/inc/kernel/gpu_mgr/gpu_mgmt_api.h e188d9f2d042ffe029b96d8fbb16c79a0fc0fb01 - src/nvidia/inc/kernel/gpu_mgr/gpu_db.h ac5842e58bf82bb8f0b738695f9b459709f03b92 - src/nvidia/inc/kernel/gpu/gpu_shared_data_map.h f2947fefcaf0611cd80c2c88ce3fdea70953c1ed - src/nvidia/inc/kernel/gpu/gpu_child_class_defs.h a9c2b16261b46eb0f86fc611b8b3b5118e2b4e59 - src/nvidia/inc/kernel/gpu/gpu_acpi_data.h 76b24227c65570898c19e16bf35b2cad143f3d05 - src/nvidia/inc/kernel/gpu/gpu.h ce5439e2066933d7d1045b7813ef0195b55e78fc - src/nvidia/inc/kernel/gpu/gpu_engine_type.h 7010ff346c27b6453c091f5577672b8b1821808d - src/nvidia/inc/kernel/gpu/gpu_access.h ce3302c1890e2f7990434f7335cb619b12dee854 - src/nvidia/inc/kernel/gpu/gpu_resource_desc.h 28d0d82b58ef13662e8896d3bbc42d340836294e - src/nvidia/inc/kernel/gpu/gpu_user_shared_data.h 10ba0b9d4c67c8027b391073dab8dc4388f32fd7 - src/nvidia/inc/kernel/gpu/nvbitmask.h bf894a769c46d5d173e3875cd9667bb3fe82feb9 - src/nvidia/inc/kernel/gpu/gpu_timeout.h c33ab6494c9423c327707fce2bcb771328984a3c - src/nvidia/inc/kernel/gpu/gpu_halspec.h 6b27c9edf93f29a31787d9acaaefb2cefc31e7d4 - src/nvidia/inc/kernel/gpu/gpu_device_mapping.h f17b704f2489ffedcc057d4a6da77c42ece42923 - src/nvidia/inc/kernel/gpu/gpu_resource.h 1938fd2511213c8003864d879cf1c41ae1169a5f - src/nvidia/inc/kernel/gpu/gpu_uuid.h 0d29e997f13d314ea320898ffb40b7a3a58898e2 - src/nvidia/inc/kernel/gpu/gpu_child_list.h 0e8353854e837f0ef0fbf0d5ff5d7a25aa1eef7c - src/nvidia/inc/kernel/gpu/eng_state.h 57a4a0d006588395c0b8b6d447acd7b4a9eeeb30 - src/nvidia/inc/kernel/gpu/kern_gpu_power.h 426c6ab6cecc3b1ba540b01309d1603301a86db1 - src/nvidia/inc/kernel/gpu/eng_desc.h ce4e0f7177f46f4fc507a68b635e5395a3f7dde6 - src/nvidia/inc/kernel/gpu/dce_client/dce_client.h 97d0a067e89251672f191788abe81cf26dcb335f - src/nvidia/inc/kernel/gpu/device/device.h 1e3bebe46b7f2f542eedace554a4156b3afb51f1 - src/nvidia/inc/kernel/gpu/audio/hda_codec_api.h 24d01769b39a6dd62574a95fad64443b05872151 - src/nvidia/inc/kernel/gpu/subdevice/subdevice.h efc50bb2ff6ccf1b7715fd413ca680034920758e - src/nvidia/inc/kernel/gpu/subdevice/generic_engine.h 61711ed293ee6974a6ed9a8a3732ae5fedcdc666 - src/nvidia/inc/kernel/gpu/disp/kern_disp_max.h 576216219d27aa887beeccefc22bcead4d1234d7 - src/nvidia/inc/kernel/gpu/disp/kern_disp.h 51a209575d3e3fe8feb7269ece7df0846e18ca2a - src/nvidia/inc/kernel/gpu/disp/kern_disp_type.h 74bc902cd00b17da3a1dfa7fd3ebc058de439b76 - src/nvidia/inc/kernel/gpu/disp/disp_channel.h be7da8d1106ee14ff808d86abffb86794299b2df - src/nvidia/inc/kernel/gpu/disp/disp_objs.h b39826404d84e0850aa3385691d8dde6e30d70d4 - src/nvidia/inc/kernel/gpu/disp/disp_sf_user.h 277a2719f8c063037c6a9ed55ade2b1cb17f48ae - src/nvidia/inc/kernel/gpu/disp/disp_capabilities.h 5179f01acf7e9e251552dc17c0dcd84f7d341d82 - src/nvidia/inc/kernel/gpu/disp/inst_mem/disp_inst_mem.h f758ea5f9cbd23a678290ef0b8d98d470e3499e0 - src/nvidia/inc/kernel/gpu/disp/vblank_callback/vblank.h 9a33a37c6cea9bad513aa14c942c689f28f7c0d8 - src/nvidia/inc/kernel/gpu/disp/head/kernel_head.h 7b7cf3b6459711065d1b849bf5acaea10b6400ca - src/nvidia/inc/kernel/gpu/intr/intr_common.h 889ba18a43cc2b5c5e970a90ddcb770ce873b785 - src/nvidia/inc/kernel/gpu/mem_mgr/mem_desc.h c2957c7f40cc454ba12fd954397fcea5d95ccae5 - src/nvidia/inc/kernel/gpu/mem_mgr/rm_page_size.h e4c67260b5cb693d695ad3d8aa96aaed45688322 - src/nvidia/inc/kernel/gpu/mem_mgr/virt_mem_allocator_common.h 6756126ddd616d6393037bebf371fceacaf3a9f1 - src/nvidia/inc/kernel/gpu/mem_mgr/context_dma.h 983bf02af93d39384c8b3ef0306193b63d8e82d9 - src/nvidia/inc/kernel/gpu/mem_mgr/mem_utils.h 20416f7239833dcaa743bbf988702610e9251289 - src/nvidia/inc/kernel/gpu/mem_mgr/mem_mgr.h 9cef17543abaa167299c57e8f043cb4b975cf640 - src/nvidia/inc/kernel/gpu/mem_mgr/heap_base.h 70c31f5c6997542d0a4693b4ad7a6539cc3ec421 - src/nvidia/inc/kernel/gpu/gsp/message_queue.h 408c0340350b813c3cba17fd36171075e156df72 - src/nvidia/inc/kernel/os/os.h f60f647bcf307f7639bccb99cb0244c7314115a1 - src/nvidia/inc/kernel/os/os_stub.h c8496199cd808ed4c79d8e149961e721ad96714e - src/nvidia/inc/kernel/os/capability.h cda75171ca7d8bf920aab6d56ef9aadec16fd15d - src/nvidia/inc/kernel/os/nv_memory_type.h 5e9928552086947b10092792db4a8c4c57a84adf - src/nvidia/inc/kernel/platform/acpi_common.h 3e11362627f9ad55e7d657da7929562230220591 - src/nvidia/inc/kernel/platform/sli/sli.h b5859c7862fb3eeb266f7213845885789801194a - src/nvidia/inc/kernel/core/system.h 42596ff1ef62df0b439e8a1e73c71b495dcf311a - src/nvidia/inc/kernel/core/printf.h 37f267155ddfc3db38f110dbb0397f0463d055ff - src/nvidia/inc/kernel/core/strict.h bdc4ab675c6f6c4bd77c3aaf08aa5c865b186802 - src/nvidia/inc/kernel/core/hal.h 93f40859dc710fd965a643da1d176790cc8886d5 - src/nvidia/inc/kernel/core/locks.h b00302aec7e4f4e3b89a2f699f8b1f18fc17b1ba - src/nvidia/inc/kernel/core/hal_mgr.h bffae4da6a1f9b7dc7c879587fd674b49b46dac1 - src/nvidia/inc/kernel/core/core.h 457c02092adfc1587d6e3cd866e28c567acbc43a - src/nvidia/inc/kernel/core/info_block.h ce992cb08e286a88c491ee8e64019ad5f8493d1b - src/nvidia/inc/kernel/core/thread_state.h 2b41b4346b7d07ca8d505574ea0f9aad6910dd69 - src/nvidia/inc/kernel/core/prelude.h 3a28bf1692efb34d2161907c3781401951cc2d4f - src/nvidia/inc/kernel/diagnostics/journal_structs.h 7e75b5d99376fba058b31996d49449f8fe62d3f0 - src/nvidia/inc/kernel/diagnostics/profiler.h 7615ac3a83d0ad23b2160ff8ad90bec9eb1f3c6c - src/nvidia/inc/kernel/diagnostics/journal.h b259f23312abe56d34a8f0da36ef549ef60ba5b0 - src/nvidia/inc/kernel/diagnostics/nv_debug_dump.h fd780f85cb1cd0fd3914fa31d1bd4933437b791d - src/nvidia/inc/kernel/diagnostics/tracer.h c6efd51b8b8447829a0867cd7fb7a5a5a2fb1e3d - src/nvidia/inc/kernel/diagnostics/traceable.h 2b23f2dbd8f3f63a17a1b63ebb40a2fd7fd8801a - src/nvidia/inc/kernel/rmapi/alloc_size.h b4bae9ea958b4d014908459e08c93319784c47dd - src/nvidia/inc/kernel/rmapi/event.h 99a27d87c7f1487f8df5781d284c2e9a83525892 - src/nvidia/inc/kernel/rmapi/binary_api.h 2baec15f4c68a9c59dd107a0db288e39914e6737 - src/nvidia/inc/kernel/rmapi/client.h aab23ad58777406fa75b55778adc747f17c1afdb - src/nvidia/inc/kernel/rmapi/rs_utils.h 7646fc9f1d17b29747b457655d65f7cae80ccc33 - src/nvidia/inc/kernel/rmapi/control.h 4453fe6463e3155063f2bdbf36f44697606a80a5 - src/nvidia/inc/kernel/rmapi/client_resource.h 497492340cea19a93b62da69ca2000b811c8f5d6 - src/nvidia/inc/kernel/rmapi/event_buffer.h ac9288d75555180c1d5dd6dd7e0e11fb57a967f2 - src/nvidia/inc/kernel/rmapi/exports.h 7e1200e609082316ed4bc2d0d925e15396b695a5 - src/nvidia/inc/kernel/rmapi/mapping_list.h 6f0f62525d2b966a24adaaabf19e79e6efc4e572 - src/nvidia/inc/kernel/rmapi/rmapi_utils.h 2724476b61b1790f1b7c293cc86e8a268125e11c - src/nvidia/inc/kernel/rmapi/param_copy.h 1399c6dc08b96577bb778e66730e7f4bcf8e7256 - src/nvidia/inc/kernel/rmapi/rmapi.h 61e3704cd51161c9804cb168d5ce4553b7311973 - src/nvidia/inc/kernel/rmapi/resource.h a92dbf2870fe0df245ea8967f2f6a68f5075ecaf - src/nvidia/inc/kernel/rmapi/resource_fwd_decls.h a5f49a031db4171228a27482d091283e84632ace - src/nvidia/inc/kernel/mem_mgr/system_mem.h 0ce5d6370c086d2944b2e8d31ff72a510d98dc8f - src/nvidia/inc/kernel/mem_mgr/virt_mem_mgr.h d15991bc770c5ab41fe746995294c5213efa056b - src/nvidia/inc/kernel/mem_mgr/io_vaspace.h 02d6a37ef1bb057604cb98a905fa02429f200c96 - src/nvidia/inc/kernel/mem_mgr/mem.h 5ae08b2077506cbc41e40e1b3672e615ce9d910f - src/nvidia/inc/kernel/mem_mgr/vaspace.h 4c386104eaead66c66df11258c3f1182b46e96ee - src/nvidia/inc/kernel/mem_mgr/syncpoint_mem.h 2d4afabd63699feec3aea5e89601db009fc51a08 - src/nvidia/inc/kernel/mem_mgr/standard_mem.h 1a08e83fd6f0a072d6887c60c529e29211bcd007 - src/nvidia/inc/kernel/mem_mgr/os_desc_mem.h 5fd1da24ae8263c43dc5dada4702564b6f0ca3d9 - src/nvidia/inc/os/dce_rm_client_ipc.h ec26741397ebd68078e8b5e34da3b3c889681b70 - src/nvidia/inc/lib/base_utils.h fff3ebc8527b34f8c463daad4d20ee5e33321344 - src/nvidia/inc/lib/ref_count.h f8d9eb5f6a6883de962b63b4b7de35c01b20182f - src/nvidia/inc/lib/protobuf/prb.h 601edb7333b87349d791d430f1cac84fb6fbb919 - src/nvidia/inc/lib/zlib/inflate.h 083667047714a008219fa41b3a7deb9803bbe48a - src/nvidia/inc/libraries/poolalloc.h 8dd7f2d9956278ed036bbc288bff4dde86a9b509 - src/nvidia/inc/libraries/eventbufferproducer.h 67ecfa8adcb2b5bb5eb8e425bc5889390fd77ca8 - src/nvidia/inc/libraries/containers/list.h fc211c8276ebcee194080140b5f3c30fba3dfe49 - src/nvidia/inc/libraries/containers/queue.h 4c8c52993d4a99f7552cd10e8c1fc8aea0330a4a - src/nvidia/inc/libraries/containers/vector.h 5cabf8b70c3bb188022db16f6ff96bcae7d7fe21 - src/nvidia/inc/libraries/containers/multimap.h 9f76ab27650b137566bf49202857c3195674d44a - src/nvidia/inc/libraries/containers/map.h 1dacc1c1efc757c12e4c64eac171474a798b86fd - src/nvidia/inc/libraries/containers/eheap_old.h 63a8244e13f9217461f624ab46281716ef42b20f - src/nvidia/inc/libraries/containers/ringbuf.h 5f116730f8b7a46e9875850e9b6ffb2a908ad6c2 - src/nvidia/inc/libraries/containers/btree.h a23790cded20fe2347c19083f2b7430aeb26ab27 - src/nvidia/inc/libraries/containers/type_safety.h 2eb9b0121765c0a3e1085f41a3d47c89e7d5dcb0 - src/nvidia/inc/libraries/nvlog/nvlog.h f97ea1dce9d593ecc599df510c98054db2b2d1a2 - src/nvidia/inc/libraries/nvlog/nvlog_printf.h d2c035e67e295b8f33f0fc52d9c30e43c5d7c2ba - src/nvidia/inc/libraries/nvlog/internal/nvlog_printf_internal.h 7f623508b3f3631ce89dad6d8762f593b1ac0d71 - src/nvidia/inc/libraries/tls/tls.h 56b8bae7756ed36d0831f76f95033f74eaab01db - src/nvidia/inc/libraries/prereq_tracker/prereq_tracker.h a5e6f98ac5fb53fd26ee429c65b73fa1a4715631 - src/nvidia/inc/libraries/ioaccess/ioaccess.h 7d8efe42c402cbbdd1710ef1f7498bf3e883a743 - src/nvidia/inc/libraries/nvport/string.h 6065fa9a525d80f9b61acb19e476066823df0700 - src/nvidia/inc/libraries/nvport/sync.h a1d93b6ec8ff01a3c2651e772a826ee11a7781d7 - src/nvidia/inc/libraries/nvport/util.h 4e25b80a74aad3f6403d7c34cd55f0ed58824888 - src/nvidia/inc/libraries/nvport/cpu.h 0fe8c0bd2791b105baf7cad7a90797ed9f743115 - src/nvidia/inc/libraries/nvport/memory.h 147d47ef4bd860394d1d8ae82c68d97887e2898b - src/nvidia/inc/libraries/nvport/core.h 87a130551593551380ac3e408f8044cc0423c01a - src/nvidia/inc/libraries/nvport/nvport.h f31ed19d0588861b8c2b1489dd4e70d430110db5 - src/nvidia/inc/libraries/nvport/crypto.h fb5a011275328b7c1edc55abc62e604462b37673 - src/nvidia/inc/libraries/nvport/atomic.h 199df020beb31a865f19ceec20f8f758e757c39a - src/nvidia/inc/libraries/nvport/debug.h 6d698ca4fc5e48c525f214a57e1de0cc4aa9e36b - src/nvidia/inc/libraries/nvport/thread.h 2487ffc1eb1e50b27ba07e0581da543d80bdaa72 - src/nvidia/inc/libraries/nvport/safe.h f267235fd8690e1b1d7485d3a815841607683671 - src/nvidia/inc/libraries/nvport/inline/safe_generic.h 254e86ee0c1d5c0ad652bc1f3182b46f6d5c0f3b - src/nvidia/inc/libraries/nvport/inline/memory_tracking.h ba267abed142db81efe7807b53c26ab4345da286 - src/nvidia/inc/libraries/nvport/inline/atomic_gcc.h 9596b274389ea56acff6ca81db8201f41f2dd39d - src/nvidia/inc/libraries/nvport/inline/atomic_clang.h 23afbd04f4e4b3301edcfdec003c8e936d898e38 - src/nvidia/inc/libraries/nvport/inline/debug_unix_kernel_os.h a8c9b83169aceb5f97d9f7a411db449496dc18f6 - src/nvidia/inc/libraries/nvport/inline/util_generic.h 1d6a239ed6c8dab1397f056a81ff456141ec7f9c - src/nvidia/inc/libraries/nvport/inline/util_valist.h bbece45965ffbc85fbd383a8a7c30890c6074b21 - src/nvidia/inc/libraries/nvport/inline/util_gcc_clang.h 645734ed505a4d977490e54b26cdf49657e20506 - src/nvidia/inc/libraries/nvport/inline/sync_tracking.h 2dec1c73507f66736674d203cc4a00813ccb11bc - src/nvidia/inc/libraries/resserv/rs_domain.h cd033fe116a41285a979e629a2ee7b11ec99369f - src/nvidia/inc/libraries/resserv/rs_access_rights.h 1d04abec9438189995cb2a675f4e35a79599aae4 - src/nvidia/inc/libraries/resserv/rs_client.h 98fa7e07b6b41d1ba4ace1de93b7d7ddfd1d7c20 - src/nvidia/inc/libraries/resserv/rs_resource.h df174d6b4f718ef699ca6f38c16aaeffa111ad3c - src/nvidia/inc/libraries/resserv/rs_access_map.h 290f84ec0b699931373eea3cd84437faf578e4a3 - src/nvidia/inc/libraries/resserv/resserv.h 3e431d72308a8b5fc423901a09079904a644b96e - src/nvidia/inc/libraries/resserv/rs_server.h c314121149d3b28e58a62e2ccf81bf6904d1e4bc - src/nvidia/inc/libraries/utils/nvmacro.h 1aabd992631089ec24621835e046ddf2e2fd4232 - src/nvidia/inc/libraries/utils/nvbitvector.h 77db350059fa3326500af4269f09e1f02c1ab07b - src/nvidia/inc/libraries/utils/nvassert.h d229861edca62007af83b86aa7fc1c77e957aa6f - src/nvidia/inc/libraries/utils/nvprintf.h d0458cdc61eb650d57429f9ae58e60a62ab93025 - src/nvidia/inc/libraries/utils/nvrange.h 9aa5870d052a45c2489a6ea1a4f2e30fbc52d6be - src/nvidia/inc/libraries/utils/nv_enum.h e35ff9733ea7fbffe0641399ccb0fd92a492e30d - src/nvidia/inc/libraries/nvoc/runtime.h 85b30b26f790b55f5370bbe9bb07349c62353841 - src/nvidia/inc/libraries/nvoc/object.h 664ff0e10e893923b70425fa49c9c48ed0735573 - src/nvidia/inc/libraries/nvoc/rtti.h 1b28bd0ee2e560ca2854a73a3ee5fb1cf713d013 - src/nvidia/inc/libraries/nvoc/utility.h 3919368b5b4cdd72d7da49801232048b5e786845 - src/nvidia/inc/libraries/nvoc/prelude.h 0b1508742a1c5a04b6c3a4be1b48b506f4180848 - kernel-open/dkms.conf 0a6f3c96043c01acbbb789874a7579728b89fcfd - kernel-open/Kbuild 4f4410c3c8db46e5a98d7a35f7d909a49de6cb43 - kernel-open/Makefile 17b99572fb2564a0817477e8b3da810ab6f6e477 - kernel-open/conftest.sh 646e6b03521587cc1a02617afd697183e5d1a83a - kernel-open/nvidia-modeset/nv-kthread-q.c 2ea1436104463c5e3d177e8574c3b4298976d37e - kernel-open/nvidia-modeset/nvkms-ioctl.h 7dbe6f8405e47c1380c6151c7c7d12b0b02ef7f4 - kernel-open/nvidia-modeset/nvidia-modeset.Kbuild 252660f72b80add6f6071dd0b86288dda8dbb168 - kernel-open/nvidia-modeset/nvkms.h 6e4ae13d024a1df676736752df805b6f91511009 - kernel-open/nvidia-modeset/nvidia-modeset-os-interface.h 487d949cacad8a734bab459c962a157fe56d373f - kernel-open/nvidia-modeset/nvidia-modeset-linux.c b02c378ac0521c380fc2403f0520949f785b1db6 - kernel-open/common/inc/nv-dmabuf.h befb2c0bf0a31b61be5469575ce3c73a9204f4e9 - kernel-open/common/inc/nv_stdarg.h 57937fb42f6fb312f7c3cf63aa399e43bad13c8c - kernel-open/common/inc/nv-proto.h 751abf80513898b35a6449725e27724b1e23ac50 - kernel-open/common/inc/nvmisc.h 5fd1da24ae8263c43dc5dada4702564b6f0ca3d9 - kernel-open/common/inc/dce_rm_client_ipc.h b417d06ed1845f5ed69181d8eb9de6b6a87fa973 - kernel-open/common/inc/nv-firmware.h 1e7eec6561b04d2d21c3515987aaa116e9401c1f - kernel-open/common/inc/nv-kernel-interface-api.h b4c5d759f035b540648117b1bff6b1701476a398 - kernel-open/common/inc/nvCpuUuid.h 507d35d1d4c5ba94ef975f75e16c63244d6cd650 - kernel-open/common/inc/nv-ioctl.h fc319569799d54944cd09b0e170e29d67b33072d - kernel-open/common/inc/nv.h fa267c903e9c449e62dbb6945906400d43417eff - kernel-open/common/inc/nvlimits.h 891192c9aabdb45fb4a798cc24cd89d205972d3f - kernel-open/common/inc/nv_uvm_types.h a0c57e8ffbe1ae12de70e56b740737dae5394a18 - kernel-open/common/inc/nv-linux.h 689d6be9302d488000e57a329373feeb14e93798 - kernel-open/common/inc/nv-procfs-utils.h 3b12d770f8592b94a8c7774c372e80ad08c5774c - kernel-open/common/inc/nvi2c.h 0e70d16576584082ee4c7f3ff9944f3bd107b1c1 - kernel-open/common/inc/cpuopsys.h b7f5d125ca0cbd4631012894b635a58cfc9f8e06 - kernel-open/common/inc/nv-pgprot.h b15c5fe5d969414640a2cb374b707c230e7597e4 - kernel-open/common/inc/nv-hash.h e1144f5bd643d24f67b7577c16c687294cb50d39 - kernel-open/common/inc/rm-gpu-ops.h 4a97d807a225d792544578f8112c9a3f90cc38f6 - kernel-open/common/inc/nvstatuscodes.h d51449fa2fd19748007f2e98f0233c92b45f9572 - kernel-open/common/inc/nvkms-api-types.h 880e45b68b19fdb91ac94991f0e6d7fc3b406b1f - kernel-open/common/inc/nv-pci-types.h bf4fdaa93deed0b110d5ca954a1f9678ffaabc6e - kernel-open/common/inc/nv-platform.h 3a26838c4edd3525daa68ac6fc7b06842dc6fc07 - kernel-open/common/inc/nv-gpu-info.h 3f7b20e27e6576ee1f2f0557d269697a0b8af7ec - kernel-open/common/inc/nv-firmware-registry.h 5cf4b517c9bd8f14593c1a6450078a774a39dd08 - kernel-open/common/inc/nv-hypervisor.h ceac0fe7333f3a67b8fb63de42ab567dd905949f - kernel-open/common/inc/nv-ioctl-numa.h 8eae29f78efd73bf16437e439294d21ae71db9f3 - kernel-open/common/inc/nv-mm.h 36c20e9c111e66601b025802f840e7b87d09cdde - kernel-open/common/inc/nvkms-kapi.h b986bc6591ba17a74ad81ec4c93347564c6d5165 - kernel-open/common/inc/nvkms-format.h 19a5da412ce1557b721b8550a4a80196f6162ba6 - kernel-open/common/inc/os_dsi_panel_props.h 1d17329caf26cdf931122b3c3b7edf4932f43c38 - kernel-open/common/inc/nv-msi.h e4a4f57abb8769d204468b2f5000c81f5ea7c92f - kernel-open/common/inc/nv-procfs.h 4a8b7f3cc65fa530670f510796bef51cf8c4bb6b - kernel-open/common/inc/nv-register-module.h 4750735d6f3b334499c81d499a06a654a052713d - kernel-open/common/inc/nv-caps.h b249abc0a7d0c9889008e98cb2f8515a9d310b85 - kernel-open/common/inc/nvgputypes.h 1d8b347e4b92c340a0e9eac77e0f63b9fb4ae977 - kernel-open/common/inc/nv-ioctl-numbers.h 03257213e55fff1c07c75c6dcf69afa920372822 - kernel-open/common/inc/nvtypes.h d25291d32caef187daf3589ce4976e4fa6bec70d - kernel-open/common/inc/nv-time.h 1c49c1642d44ec347f82ff0aa06d0fca6213bad2 - kernel-open/common/inc/nvimpshared.h e20882a9b14f2bf887e7465d3f238e5ac17bc2f5 - kernel-open/common/inc/nv_speculation_barrier.h 95bf694a98ba78d5a19e66463b8adda631e6ce4c - kernel-open/common/inc/nvstatus.h c75bfc368c6ce3fc2c1a0c5062834e90d822b365 - kernel-open/common/inc/nv-memdbg.h b642fb649ce2ba17f37c8aa73f61b38f99a74986 - kernel-open/common/inc/nv-retpoline.h 143051f69a53db0e7c5d2f846a9c14d666e264b4 - kernel-open/common/inc/nv-kref.h 60ef64c0f15526ae2d786e5cec07f28570f0663b - kernel-open/common/inc/conftest.h 4856fe869a5f3141e5d7f7d1b0a6affad94cbc31 - kernel-open/common/inc/nv-pci.h 3603c631c6cf784ec862e4e45f05939d98679002 - kernel-open/common/inc/nv-kthread-q.h d7ab0ee225361daacd280ff98848851933a10a98 - kernel-open/common/inc/nv-list-helpers.h 906329ae5773732896e6fe94948f7674d0b04c17 - kernel-open/common/inc/os_gpio.h c45b2faf17ca2a205c56daa11e3cb9d864be2238 - kernel-open/common/inc/nv-modeset-interface.h 7b2e2e6ff278acddc6980b330f68e374f38e0a6c - kernel-open/common/inc/nv-timer.h f428218ee6f5d0289602495a1cfb287db4fb0823 - kernel-open/common/inc/nv_uvm_interface.h de6913c5e5092a417530ac9f818497824eab7946 - kernel-open/common/inc/os-interface.h e42d91cd7e6c17796fa89a172146950261f45d42 - kernel-open/common/inc/nv-lock.h cda75171ca7d8bf920aab6d56ef9aadec16fd15d - kernel-open/common/inc/os/nv_memory_type.h 86443277db67b64c70260e5668bb4140bc90165c - kernel-open/nvidia/nv-clk.c ef8fd76c55625aeaa71c9b789c4cf519ef6116b2 - kernel-open/nvidia/libspdm_hkdf.c 4c64885083621f5f313a7dee72e14eee8abed2a0 - kernel-open/nvidia/nvidia-sources.Kbuild f701fb148bda4eb03332ab45194a4824e499cab7 - kernel-open/nvidia/nv-platform.c e5cd40b060a69cf71220c910e9428d7f261892f7 - kernel-open/nvidia/internal_crypt_lib.h 646e6b03521587cc1a02617afd697183e5d1a83a - kernel-open/nvidia/nv-kthread-q.c 4e5a330fa40dab218821976ac1b530c649d48994 - kernel-open/nvidia/libspdm_ecc.c 0a3ad5cdacfe156b02f53c0087bdc0ec9509cd6a - kernel-open/nvidia/nv-ipc-soc.c 6e669fe32e4b69dcdbc9739dc8a45fb800547d53 - kernel-open/nvidia/nv-p2p.c ab04c42e0e8e7f48f1a7074885278bbb6006d65f - kernel-open/nvidia/nv-bpmp.c 95ae148b016e4111122c2d9f8f004b53e78998f3 - kernel-open/nvidia/nv-memdbg.c fbae5663e3c278d8206d07ec6446ca4c2781795f - kernel-open/nvidia/nv-ibmnpu.h ec3055aa73c6c65b601ea040989f0b638a847e86 - kernel-open/nvidia/os-interface.c dd819a875c584bc469082fcf519779ea00b1d952 - kernel-open/nvidia/libspdm_aead_aes_gcm.c 980556d84bc56e819955b9338a43a9d970dba11d - kernel-open/nvidia/nv_gpu_ops.h 4eee7319202366822e17d29ecec9f662c075e7ac - kernel-open/nvidia/nv-rsync.c 2f6e4c6ee6f809097c8b07a7b698e8614bf25e57 - kernel-open/nvidia/nv-caps.c d11ab03a617b29efcf00f85e24ebce60f91cf82c - kernel-open/nvidia/nv-backlight.c 57a06cab892f111b0fb1ebe182c0c688560e750e - kernel-open/nvidia/nvspdm_cryptlib_extensions.h 189eebce734b698f0fd0b60290eca7922b865888 - kernel-open/nvidia/nv-imp.c 8bedc7374d7a43250e49fb09139c511b489d45e3 - kernel-open/nvidia/nv-pci-table.h 68d781e929d103e6fa55fa92b5d4f933fbfb6526 - kernel-open/nvidia/nv-report-err.h 94c406f36836c3396b0ca08b4ff71496666b9c43 - kernel-open/nvidia/os-usermap.c dc39c4ee87f4dc5f5ccc179a98e07ddb82bb8bce - kernel-open/nvidia/nv-modeset-interface.c 06e7ec77cd21c43f900984553a4960064753e444 - kernel-open/nvidia/nv-platform-pm.c cf98395acb4430a7c105218f7a4b5f7e810b39cf - kernel-open/nvidia/os-registry.c 7b1bd10726481626dd51f4eebb693794561c20f6 - kernel-open/nvidia/nv-host1x.c 1a98a2aaf386cd3d03b4b5513d6a511c60f71c2c - kernel-open/nvidia/nv-reg.h 42b9924aa348e9b23dffba9b613108d58f3a671e - kernel-open/nvidia/nv.c 37654472e65659be229b5e35c6f25c0724929511 - kernel-open/nvidia/nv-frontend.c d9221522e02e18b037b8929fbc075dc3c1e58654 - kernel-open/nvidia/nv-pci-table.c 94344ec0af21bd9c7c7ab912f7bd3a8668a3e0aa - kernel-open/nvidia/os-pci.c b8d361216db85fe897cbced2a9600507b7708c61 - kernel-open/nvidia/libspdm_hkdf_sha.c 70a9117dce7471a07178d9456b146a033d6b544b - kernel-open/nvidia/nv-dma.c 946fb049ca50c9bb39897eca4b8443278043eea2 - kernel-open/nvidia/nv-vm.c 6710f4603a9d3e14bcaefdf415b1cfff9ec9b7ec - kernel-open/nvidia/libspdm_aead.c e0aff92ee8ddec261d8f0d81c41f837503c4b571 - kernel-open/nvidia/nv-dsi-parse-panel-props.c cf90d9ea3abced81d182ab3c4161e1b5d3ad280d - kernel-open/nvidia/nv-rsync.h 6d4fbea733fdcd92fc6a8a5884e8bb359f9e8abd - kernel-open/nvidia/rmp2pdefines.h dd9e367cba9e0672c998ec6d570be38084a365ab - kernel-open/nvidia/libspdm_rand.c 2fab5ae911554508e6e7a3b25824e8b2c27e85c2 - kernel-open/nvidia/nv-ibmnpu.c ce537a7d786bd11a4429bf7c59836d5373a66f61 - kernel-open/nvidia/nv-i2c.c b71bf4426322ab59e78e2a1500509a5f4b2b71ab - kernel-open/nvidia/nv-pat.h 64f1c96761f6d9e7e02ab049dd0c810196568036 - kernel-open/nvidia/nv-pat.c 9104dc5f36a825aaf1208b54b167965625d4a433 - kernel-open/nvidia/nv_uvm_interface.c 9b701fe42a0e87d62c58b15c553086a608e89f7b - kernel-open/nvidia/nv-frontend.h 02b1936dd9a9e30141245209d79b8304b7f12eb9 - kernel-open/nvidia/nv-cray.c 11778961efc78ef488be5387fa3de0c1b761c0d9 - kernel-open/nvidia/libspdm_sha.c 5ac10d9b20ccd37e1e24d4a81b8ac8f83db981e4 - kernel-open/nvidia/nv-vtophys.c 9883eb32e5d4377c3dce1c7cb54d0e05c05e128b - kernel-open/nvidia/nv-mmap.c 01d4701e8302e345275f1ec60b9718e645b5663c - kernel-open/nvidia/libspdm_x509.c e8daae4e6106429378673988293aaa1fcd80f0eb - kernel-open/nvidia/nv-pci.c 69f203ad21e643f7b7c85e7e86bd4b674a3536de - kernel-open/nvidia/nv-acpi.c 8c9fd9590d7e3ad333ae03d5f22b72ffbdbe6e70 - kernel-open/nvidia/nv-dmabuf.c c7f1aaa6a5f3a3cdf1e5f80adf40b3c9f185fb94 - kernel-open/nvidia/nv-report-err.c c1ebcfec42f7898dd9d909eacd439d288b80523f - kernel-open/nvidia/os-mlock.c d68af9144d3d487308e73d0a52f4474f8047d6ca - kernel-open/nvidia/nv-gpio.c 7ac10bc4b3b1c5a261388c3f5f9ce0e9b35d7b44 - kernel-open/nvidia/nv-usermap.c e0a37b715684ae0f434327e4ce1b5832caf7ea4e - kernel-open/nvidia/nv-nano-timer.c 3b27e4eaa97bd6fa71f1a075b50af69b1ec16454 - kernel-open/nvidia/libspdm_ec.c fc22bea3040ae178492cb9c7a62f1d0012b1c113 - kernel-open/nvidia/nv-procfs.c a46f27be57870c7669f3e43fffb7e1fdaff5a3d6 - kernel-open/nvidia/nvidia.Kbuild 6060392eec4e707ac61ebca3995b6a966eba7fc1 - kernel-open/nvidia/nv-p2p.h 642c3a7d10b263ab9a63073f83ad843566927b58 - kernel-open/nvidia/libspdm_hmac_sha.c 8f87a475c202458948025d1521968677fc11dd50 - kernel-open/nvidia/nv-msi.c e2da77ff1bc25c0b1de69af7c09e0bde26c34e30 - kernel-open/nvidia/libspdm_shash.c 9a6e164ec60c2feb1eb8782e3028afbffe420927 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_mac.h 95b97f5a3ddcf73ed5d7fa0be9e27aec776d7c13 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_rsa.h 7ff12b437215b77c920a845943e4101dcde289c4 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_hkdf.h 34de62da6f880ba8022299c77eddbb11d7fc68d2 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_hash.h fa178a7209f56008e67b553a2c5ad1b2dd383aac - kernel-open/nvidia/hal/library/cryptlib/cryptlib_rng.h cf94004b7b5729982806f7d6ef7cc6db53e3de56 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_aead.h c276be3eb63bb451edfe9ed13859c251530743e6 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_ecd.h 5b79fbc90502b1ba8d1f9966fc7b9a6fd7ef07b4 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_cert.h 0dcb1fd3982e6307b07c917cb453cddbcd1d2f43 - kernel-open/nvidia/hal/library/cryptlib/cryptlib_dh.h 92ab7c0bf545029c4c1d9a0ab68b53eedc655f9c - kernel-open/nvidia/hal/library/cryptlib/cryptlib_ec.h d007df1d642e836595331598ca0313084922f3ee - kernel-open/nvidia/hal/library/cryptlib/cryptlib_sm2.h 7398ff33b24fa58315cc40776bc3451e090aa437 - kernel-open/nvidia/internal/libspdm_lib_config.h 19b5d633f4560d545f622ada0dd352d5aa02c651 - kernel-open/nvidia/library/cryptlib.h d5ddc354e191d6178625b0df8e8b34e8c3e4c474 - kernel-open/nvidia/library/spdm_lib_config.h 99642b76e9a84b5a1d2e2f4a8c7fb7bcd77a44fd - kernel-open/nvidia-drm/nvidia-drm.h 66b33e4ac9abe09835635f6776c1222deefad741 - kernel-open/nvidia-drm/nvidia-drm-fb.h 23586447526d9ffedd7878b6cf5ba00139fadb5e - kernel-open/nvidia-drm/nvidia-drm-gem-user-memory.h 6d65ea9f067e09831a8196022bfe00a145bec270 - kernel-open/nvidia-drm/nvidia-drm-gem-dma-buf.h 646e6b03521587cc1a02617afd697183e5d1a83a - kernel-open/nvidia-drm/nv-kthread-q.c c1af941dd5144b05995dcf5721652a4f126e175f - kernel-open/nvidia-drm/nvidia-drm-priv.h c52acdbc07f16aa78570d9e6a7f62e493264fde1 - kernel-open/nvidia-drm/nvidia-drm-helper.c 337d6b7013c2527d7efdb7ef87f335024ed140a8 - kernel-open/nvidia-drm/nvidia-drm-drv.c 511ea7cd9e7778c6adc028ae13377c1a8856b72a - kernel-open/nvidia-drm/nvidia-drm-format.c e362c64aa67b47becdbf5c8ba2a245e135adeedf - kernel-open/nvidia-drm/nvidia-drm-gem-dma-buf.c 492a1b0b02dcd2d60f05ac670daeeddcaa4b0da5 - kernel-open/nvidia-drm/nvidia-dma-resv-helper.h 55e26337c0d52b5ec4f6ab403e9306417d2893f8 - kernel-open/nvidia-drm/nvidia-drm-gem-user-memory.c 672afea77ca2c2575f278d9e182ba1188e35e971 - kernel-open/nvidia-drm/nvidia-drm-encoder.c 40b5613d1fbbe6b74bff67a5d07974ad321f75f0 - kernel-open/nvidia-drm/nvidia-drm-utils.h 2c0518192eac1a1877eef0dbf7b668e8450d0821 - kernel-open/nvidia-drm/nvidia-drm-helper.h 273d0cafeb0f21bf9b7d189f2dc6278e1a3c9672 - kernel-open/nvidia-drm/nvidia-drm-os-interface.h eb98761cdc99141ad937966e5533c57189db376a - kernel-open/nvidia-drm/nvidia-drm-fence.h 8bedc7374d7a43250e49fb09139c511b489d45e3 - kernel-open/nvidia-drm/nv-pci-table.h 8da06bd922850e840c94ed380e3b92c63aecbf70 - kernel-open/nvidia-drm/nvidia-drm-fb.c 044071d60c8cc8ea66c6caaf1b70fe01c4081ad3 - kernel-open/nvidia-drm/nvidia-drm-conftest.h 8b2063f0cc2e328f4f986c2ce556cfb626c89810 - kernel-open/nvidia-drm/nvidia-drm-utils.c 487db563f4e5153ffc976fc2aa26636ebb4cd534 - kernel-open/nvidia-drm/nvidia-drm-crtc.h deb00fa4d1de972d93d8e72355d81ba87044c86f - kernel-open/nvidia-drm/nvidia-drm-fence.c dc0fe38909e2f38e919495b7b4f21652a035a3ee - kernel-open/nvidia-drm/nvidia-drm.c 203295380efca7e422746805437b05ce22505424 - kernel-open/nvidia-drm/nvidia-drm-gem.c 1f0cdee2468f842c06bb84aceef60e0723023084 - kernel-open/nvidia-drm/nvidia-drm-linux.c 97b6c56b1407de976898e0a8b5a8f38a5211f8bb - kernel-open/nvidia-drm/nvidia-drm-format.h d9221522e02e18b037b8929fbc075dc3c1e58654 - kernel-open/nvidia-drm/nv-pci-table.c ec550cba2bebff2c5054b6e12fc43d81e37ade48 - kernel-open/nvidia-drm/nvidia-dma-fence-helper.h 8a8b431f45bd0fe477759c1527d792cb9a1fa3f5 - kernel-open/nvidia-drm/nvidia-drm-gem.h 79bcf373ff7d728740716acde5e2d44e924efefa - kernel-open/nvidia-drm/nvidia-drm-gem-nvkms-memory.c 734f8ad9fbbe2e07b7d8c38455f66be9f75de127 - kernel-open/nvidia-drm/nvidia-drm-crtc.c 6528efa1f8061678b8543c5c0be8761cab860858 - kernel-open/nvidia-drm/nvidia-drm-modeset.h b91df730fba3c2f9401321557bb1bc2e64bbf980 - kernel-open/nvidia-drm/nvidia-drm-connector.h eca70b3b8146903ec678a60eebb0462e6ccf4569 - kernel-open/nvidia-drm/nvidia-drm-encoder.h efeac7919ce5bbdab479fe5489e9ea84d2cee0a2 - kernel-open/nvidia-drm/nvidia-drm.Kbuild 4b68b6cb0f98116376be36733f5ae60eec85d78d - kernel-open/nvidia-drm/nvidia-drm-ioctl.h 61c61f91d1a29d6f7794a67eac337152b58aaac0 - kernel-open/nvidia-drm/nvidia-drm-connector.c fe9132110f104ff7ebba922ce6dd66a2d08a998d - kernel-open/nvidia-drm/nvidia-drm-modeset.c 2eba218d75f3802d7bab34d0dd6320f872b2d604 - kernel-open/nvidia-drm/nvidia-drm-gem-nvkms-memory.h 9a882b31b2acc9e1ad3909c0061eee536e648aae - kernel-open/nvidia-drm/nvidia-drm-drv.h Change-Id: I4c402d345459fbad7b568857262f5190b68f4ead
4028 lines
129 KiB
C
4028 lines
129 KiB
C
/*
|
|
* SPDX-FileCopyrightText: Copyright (c) 2014-2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
* to deal in the Software without restriction, including without limitation
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
* DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
#if !defined(NVKMS_API_H)
|
|
#define NVKMS_API_H
|
|
|
|
/*
|
|
* NVKMS API
|
|
*
|
|
*
|
|
* All file operations described in this header file go through a
|
|
* single device file that has system-wide scope. The individual
|
|
* ioctl request data structures specify the objects to which the
|
|
* request is targeted.
|
|
*
|
|
*
|
|
* OBJECTS
|
|
*
|
|
* The NVKMS API is organized into several objects:
|
|
*
|
|
* - A device, which corresponds to an RM device. This can either be
|
|
* a single GPU, or multiple GPUs linked into SLI. Each GPU is
|
|
* called a "subdevice". The subdevices used by an NVKMS device are
|
|
* reported in NvKmsAllocDeviceReply::subDeviceMask.
|
|
*
|
|
* A device is specified by a deviceHandle, returned by
|
|
* NVKMS_IOCTL_ALLOC_DEVICE.
|
|
*
|
|
* - A disp, which represents an individually programmable display
|
|
* engine of a GPU. In SLI Mosaic, there is one disp per physical
|
|
* GPU. In all other configurations there is one disp for the
|
|
* entire device. A disp is specified by a (deviceHandle,
|
|
* dispHandle) duple. A dispHandle is only unique within a single
|
|
* device: multiple devices may have disps with the same dispHandle
|
|
* value.
|
|
*
|
|
* A disp represents one subdevice; disp index N corresponds to subdevice
|
|
* index N.
|
|
*
|
|
* - A connector, which represents an electrical connection to the
|
|
* GPU. E.g., a physical DVI-I connector has two NVKMS connector
|
|
* objects (a VGA NVKMS connector and a TMDS NVKMS connector).
|
|
* However, a physical DisplayPort connector has one NVKMS connector
|
|
* object, even if there is a tree of DisplayPort1.2 Multistream
|
|
* monitors connected to it.
|
|
*
|
|
* Connectors are associated with a specific disp. A connector is
|
|
* specified by a (deviceHandle, dispHandle, connectorHandle)
|
|
* triplet. A connectorHandle is only unique within a single disp:
|
|
* multiple disps may have connectors with the same connectorHandle
|
|
* value.
|
|
*
|
|
* - A dpy, which represents a connection of a display device to the
|
|
* system. Multiple dpys can map to the same connector in the case
|
|
* of DisplayPort1.2 MultiStream. A dpy is specified by a
|
|
* (deviceHandle, dispHandle, dpyId) triplet. A dpyId is only
|
|
* unique within a single disp: multiple disps may have dpys with
|
|
* the same dpyId value.
|
|
*
|
|
* - A surface, which represents memory to be scanned out. Surfaces
|
|
* should be allocated by resman, and then registered and
|
|
* unregistered with NVKMS. The NvKmsSurfaceHandle value of 0 is
|
|
* reserved to mean no surface.
|
|
*
|
|
* NVKMS clients should treat the device, disp, connector, and surface
|
|
* handles as opaque values. They are specific to the file descriptor
|
|
* through which a client allocated and queried them. Dpys should
|
|
* also be treated as opaque, though they can be passed between
|
|
* clients.
|
|
*
|
|
* NVKMS clients initialize NVKMS by allocating an NVKMS device. The
|
|
* device can either be a single GPU, or an SLI group. It is expected
|
|
* that the client has already attached/linked the GPUs through
|
|
* resman and created a resman device.
|
|
*
|
|
* NVKMS device allocation returns a device handle, the disp handles,
|
|
* and capabilities of the device.
|
|
*
|
|
*
|
|
* MODE VALIDATION
|
|
*
|
|
* When a client requests to set a mode via NVKMS_IOCTL_SET_MODE,
|
|
* NVKMS will validate the mode at that point in time, honoring the
|
|
* NvKmsModeValidationParams specified as part of the request.
|
|
*
|
|
* Clients can use NVKMS_IOCTL_VALIDATE_MODE to test if a mode is valid.
|
|
*
|
|
* Clients can use NVKMS_IOCTL_VALIDATE_MODE_INDEX to get the list of
|
|
* modes that NVKMS currently considers valid for the dpy (modes from
|
|
* the EDID, etc).
|
|
*
|
|
* IMPLEMENTATION NOTE: the same mode validation common code will be
|
|
* used in each of NVKMS_IOCTL_SET_MODE, NVKMS_IOCTL_VALIDATE_MODE,
|
|
* and NVKMS_IOCTL_VALIDATE_MODE_INDEX, but NVKMS won't generally maintain
|
|
* a "mode pool" with an exhaustive list of the allowable modes for a
|
|
* dpy.
|
|
*
|
|
*
|
|
* DYNAMIC DPY HANDLING
|
|
*
|
|
* Dynamic dpys (namely, DisplayPort multistream dpys) share the NVDpyId
|
|
* namespace with non-dynamic dpys on the same disp. However, dynamic dpys will
|
|
* not be listed in NvKmsQueryDispReply::validDpys. Instead, dynamic dpys are
|
|
* added and removed from the system dynamically.
|
|
*
|
|
* When a dynamic dpy is first connected, NVKMS will allocate a new NVDpyId for
|
|
* it and generate an NVKMS_EVENT_TYPE_DYNAMIC_DPY_CONNECTED event. When the
|
|
* dynamic dpy is disconnected, NVKMS will generate an
|
|
* NVKMS_EVENT_TYPE_DYNAMIC_DPY_DISCONNECTED event. Whether the corresponding
|
|
* NVDpyId is immediately freed and made available for subsequent dynamic dpys
|
|
* depends on client behavior.
|
|
*
|
|
* Clients may require that a dynamic NVDpyId persist even after the dynamic dpy
|
|
* is disconnected. Clients who require this can use
|
|
* NVKMS_IOCTL_DECLARE_DYNAMIC_DPY_INTEREST. NVKMS will retain the NVDpyId
|
|
* until the dynamic dpy is disconnected and there are no clients who have
|
|
* declared "interest" on the particular dynamic dpy. While the NVDpyId
|
|
* persists, it will be used for any monitor that is connected at the same
|
|
* dynamic dpy address (i.e., port address, in the case of DP MST).
|
|
*
|
|
*
|
|
* FILE DESCRIPTOR HANDLING
|
|
*
|
|
* With the exception of NVDpyIds, all handles should be assumed to be
|
|
* specific to the current file descriptor on which the ioctls are
|
|
* performed.
|
|
*
|
|
* Multiple devices can be allocated on the same file descriptor.
|
|
* E.g., to drive the display of multiple GPUs.
|
|
*
|
|
* If a file descriptor is closed prematurely, either explicitly by
|
|
* the client or implicitly by the operating system because the client
|
|
* process was terminated, NVKMS will perform an
|
|
* NVKMS_IOCTL_FREE_DEVICE for any devices currently allocated by the
|
|
* client on the closed file descriptor.
|
|
*
|
|
* NVKMS file descriptors are normally used as the first argument of
|
|
* ioctl(2). However, NVKMS file descriptors are also used for
|
|
* granting surfaces (see NVKMS_IOCTL_GRANT_SURFACE) or permissions
|
|
* (see NVKMS_IOCTL_GRANT_PERMISSIONS). Any given NVKMS file
|
|
* descriptor can only be used for one of these uses.
|
|
*
|
|
* QUESTIONS:
|
|
*
|
|
* - Is there any reason for errors to be returned through a status field
|
|
* in the Param structures, rather than the ioctl(2) return value?
|
|
*
|
|
* - Is it too asymmetric that NVKMS_IOCTL_SET_MODE can set a
|
|
* mode across heads/disps, but other requests (e.g.,
|
|
* NVKMS_IOCTL_SET_CURSOR_IMAGE) operate on a single head?
|
|
*
|
|
*
|
|
* IOCTL PARAMETER ORGANIZATION
|
|
*
|
|
* For table-driven processing of ioctls, it is useful for all ioctl
|
|
* parameters to follow the same convention:
|
|
*
|
|
* struct NvKmsFooRequest {
|
|
* (...)
|
|
* };
|
|
*
|
|
* struct NvKmsFooReply {
|
|
* (...)
|
|
* };
|
|
*
|
|
* struct NvKmsFooParams {
|
|
* struct NvKmsFooRequest request; //! in
|
|
* struct NvKmsFooReply reply; //! out
|
|
* };
|
|
*
|
|
* I.e., all ioctl parameter structures NvKmsFooParams should have
|
|
* "request" and "reply" fields, with types "struct NvKmsFooRequest"
|
|
* and "struct NvKmsFooReply". C doesn't technically support empty
|
|
* structures, so the convention is to place a "padding" NvU32 in
|
|
* request or reply structures that would otherwise be empty.
|
|
*/
|
|
|
|
#include "nvtypes.h"
|
|
#include "nvlimits.h"
|
|
#include "nv_dpy_id.h"
|
|
#include "nv_mode_timings.h"
|
|
#include "nvkms-api-types.h"
|
|
#include "nvgputypes.h" /* NvGpuSemaphore */
|
|
#include "nvkms-format.h"
|
|
|
|
/*
|
|
* The NVKMS ioctl commands. See the ioctl parameter declarations
|
|
* later in this header file for an explanation of each ioctl command.
|
|
*/
|
|
enum NvKmsIoctlCommand {
|
|
NVKMS_IOCTL_ALLOC_DEVICE,
|
|
NVKMS_IOCTL_FREE_DEVICE,
|
|
NVKMS_IOCTL_QUERY_DISP,
|
|
NVKMS_IOCTL_QUERY_CONNECTOR_STATIC_DATA,
|
|
NVKMS_IOCTL_QUERY_CONNECTOR_DYNAMIC_DATA,
|
|
NVKMS_IOCTL_QUERY_DPY_STATIC_DATA,
|
|
NVKMS_IOCTL_QUERY_DPY_DYNAMIC_DATA,
|
|
NVKMS_IOCTL_VALIDATE_MODE_INDEX,
|
|
NVKMS_IOCTL_VALIDATE_MODE,
|
|
NVKMS_IOCTL_SET_MODE,
|
|
NVKMS_IOCTL_SET_CURSOR_IMAGE,
|
|
NVKMS_IOCTL_MOVE_CURSOR,
|
|
NVKMS_IOCTL_SET_LUT,
|
|
NVKMS_IOCTL_IDLE_BASE_CHANNEL,
|
|
NVKMS_IOCTL_FLIP,
|
|
NVKMS_IOCTL_DECLARE_DYNAMIC_DPY_INTEREST,
|
|
NVKMS_IOCTL_REGISTER_SURFACE,
|
|
NVKMS_IOCTL_UNREGISTER_SURFACE,
|
|
NVKMS_IOCTL_GRANT_SURFACE,
|
|
NVKMS_IOCTL_ACQUIRE_SURFACE,
|
|
NVKMS_IOCTL_RELEASE_SURFACE,
|
|
NVKMS_IOCTL_SET_DPY_ATTRIBUTE,
|
|
NVKMS_IOCTL_GET_DPY_ATTRIBUTE,
|
|
NVKMS_IOCTL_GET_DPY_ATTRIBUTE_VALID_VALUES,
|
|
NVKMS_IOCTL_SET_DISP_ATTRIBUTE,
|
|
NVKMS_IOCTL_GET_DISP_ATTRIBUTE,
|
|
NVKMS_IOCTL_GET_DISP_ATTRIBUTE_VALID_VALUES,
|
|
NVKMS_IOCTL_QUERY_FRAMELOCK,
|
|
NVKMS_IOCTL_SET_FRAMELOCK_ATTRIBUTE,
|
|
NVKMS_IOCTL_GET_FRAMELOCK_ATTRIBUTE,
|
|
NVKMS_IOCTL_GET_FRAMELOCK_ATTRIBUTE_VALID_VALUES,
|
|
NVKMS_IOCTL_GET_NEXT_EVENT,
|
|
NVKMS_IOCTL_DECLARE_EVENT_INTEREST,
|
|
NVKMS_IOCTL_CLEAR_UNICAST_EVENT,
|
|
NVKMS_IOCTL_GET_3DVISION_DONGLE_PARAM_BYTES,
|
|
NVKMS_IOCTL_SET_3DVISION_AEGIS_PARAMS,
|
|
NVKMS_IOCTL_SET_LAYER_POSITION,
|
|
NVKMS_IOCTL_GRAB_OWNERSHIP,
|
|
NVKMS_IOCTL_RELEASE_OWNERSHIP,
|
|
NVKMS_IOCTL_GRANT_PERMISSIONS,
|
|
NVKMS_IOCTL_ACQUIRE_PERMISSIONS,
|
|
NVKMS_IOCTL_REVOKE_PERMISSIONS,
|
|
NVKMS_IOCTL_QUERY_DPY_CRC32,
|
|
NVKMS_IOCTL_REGISTER_DEFERRED_REQUEST_FIFO,
|
|
NVKMS_IOCTL_UNREGISTER_DEFERRED_REQUEST_FIFO,
|
|
NVKMS_IOCTL_ALLOC_SWAP_GROUP,
|
|
NVKMS_IOCTL_FREE_SWAP_GROUP,
|
|
NVKMS_IOCTL_JOIN_SWAP_GROUP,
|
|
NVKMS_IOCTL_LEAVE_SWAP_GROUP,
|
|
NVKMS_IOCTL_SET_SWAP_GROUP_CLIP_LIST,
|
|
NVKMS_IOCTL_GRANT_SWAP_GROUP,
|
|
NVKMS_IOCTL_ACQUIRE_SWAP_GROUP,
|
|
NVKMS_IOCTL_RELEASE_SWAP_GROUP,
|
|
NVKMS_IOCTL_SWITCH_MUX,
|
|
NVKMS_IOCTL_GET_MUX_STATE,
|
|
NVKMS_IOCTL_EXPORT_VRR_SEMAPHORE_SURFACE,
|
|
NVKMS_IOCTL_ENABLE_VBLANK_SYNC_OBJECT,
|
|
NVKMS_IOCTL_DISABLE_VBLANK_SYNC_OBJECT,
|
|
NVKMS_IOCTL_NOTIFY_VBLANK,
|
|
};
|
|
|
|
|
|
#define NVKMS_NVIDIA_DRIVER_VERSION_STRING_LENGTH 32
|
|
#define NVKMS_MAX_CONNECTORS_PER_DISP 16
|
|
#define NVKMS_MAX_GPUS_PER_FRAMELOCK 4
|
|
#define NVKMS_MAX_DEVICE_REGISTRY_KEYS 16
|
|
#define NVKMS_MAX_DEVICE_REGISTRY_KEYNAME_LEN 32
|
|
#define NVKMS_MAX_VBLANK_SYNC_OBJECTS_PER_HEAD 6
|
|
|
|
|
|
/*
|
|
* There can be at most one SwapGroup per-head, per-disp (and,
|
|
* in the extreme, there is one disp per-GPU).
|
|
*/
|
|
#define NVKMS_MAX_SWAPGROUPS (NVKMS_MAX_HEADS_PER_DISP * NV_MAX_DEVICES)
|
|
|
|
#define NVKMS_MAX_VALID_SYNC_RANGES 8
|
|
|
|
#define NVKMS_DPY_NAME_SIZE 128
|
|
#define NVKMS_GUID_SIZE 16
|
|
#define NVKMS_3DVISION_DONGLE_PARAM_BYTES 20
|
|
#define NVKMS_GPU_STRING_SIZE 80
|
|
|
|
#define NVKMS_LOG2_LUT_ARRAY_SIZE 10
|
|
#define NVKMS_LUT_ARRAY_SIZE (1 << NVKMS_LOG2_LUT_ARRAY_SIZE)
|
|
#define NVKMS_VRR_SEMAPHORE_SURFACE_SIZE 1024
|
|
|
|
/*
|
|
* The GUID string has the form:
|
|
* XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
|
|
* Two Xs per byte, plus four dashes and a NUL byte.
|
|
*/
|
|
#define NVKMS_GUID_STRING_SIZE ((NVKMS_GUID_SIZE * 2) + 5)
|
|
|
|
#define NVKMS_MODE_VALIDATION_MAX_INFO_STRING_LENGTH 2048
|
|
#define NVKMS_EDID_INFO_STRING_LENGTH (32 * 1024)
|
|
|
|
/*!
|
|
* A base EDID is 128 bytes, with 128 bytes per extension block. 2048
|
|
* should be large enough for any EDID we see.
|
|
*/
|
|
#define NVKMS_EDID_BUFFER_SIZE 2048
|
|
|
|
/*!
|
|
* Description of modetimings.
|
|
*
|
|
* YUV420 modes require special care since some GPUs do not support YUV420
|
|
* scanout in hardware. When timings::yuv420Mode is NV_YUV420_SW, NVKMS will
|
|
* set a mode with horizontal values that are half of what are described in
|
|
* NvKmsMode, and not enable any color space conversion. When clients allocate
|
|
* a surface and populate it with content, the region of interest within the
|
|
* surface should be half the width of the NvKmsMode, and the surface content
|
|
* should be RGB->YUV color space converted, and decimated from 4:4:4 to 4:2:0.
|
|
*
|
|
* The NvKmsMode and viewPortOut, specified by the NVKMS client,
|
|
* should be in "full" horizontal space, but the surface and
|
|
* viewPortIn should be in "half" horizontal space.
|
|
*/
|
|
struct NvKmsMode {
|
|
NvModeTimings timings;
|
|
char name[32];
|
|
};
|
|
|
|
/*!
|
|
* Mode validation override bit flags, for use in
|
|
* NvKmsModeValidationParams::overrides.
|
|
*/
|
|
enum NvKmsModeValidationOverrides {
|
|
NVKMS_MODE_VALIDATION_NO_MAX_PCLK_CHECK = (1 << 0),
|
|
NVKMS_MODE_VALIDATION_NO_EDID_MAX_PCLK_CHECK = (1 << 1),
|
|
NVKMS_MODE_VALIDATION_NO_HORIZ_SYNC_CHECK = (1 << 2),
|
|
NVKMS_MODE_VALIDATION_NO_VERT_REFRESH_CHECK = (1 << 3),
|
|
NVKMS_MODE_VALIDATION_NO_EDID_DFP_MAX_SIZE_CHECK = (1 << 4),
|
|
NVKMS_MODE_VALIDATION_NO_EXTENDED_GPU_CAPABILITIES_CHECK = (1 << 5),
|
|
NVKMS_MODE_VALIDATION_OBEY_EDID_CONTRADICTIONS = (1 << 6),
|
|
NVKMS_MODE_VALIDATION_NO_TOTAL_SIZE_CHECK = (1 << 7),
|
|
NVKMS_MODE_VALIDATION_NO_DUAL_LINK_DVI_CHECK = (1 << 8),
|
|
NVKMS_MODE_VALIDATION_NO_DISPLAYPORT_BANDWIDTH_CHECK = (1 << 9),
|
|
NVKMS_MODE_VALIDATION_ALLOW_NON_3DVISION_MODES = (1 << 10),
|
|
NVKMS_MODE_VALIDATION_ALLOW_NON_EDID_MODES = (1 << 11),
|
|
NVKMS_MODE_VALIDATION_ALLOW_NON_HDMI3D_MODES = (1 << 12),
|
|
NVKMS_MODE_VALIDATION_NO_MAX_SIZE_CHECK = (1 << 13),
|
|
NVKMS_MODE_VALIDATION_NO_HDMI2_CHECK = (1 << 14),
|
|
NVKMS_MODE_VALIDATION_NO_RRX1K_CHECK = (1 << 15),
|
|
NVKMS_MODE_VALIDATION_REQUIRE_BOOT_CLOCKS = (1 << 16),
|
|
NVKMS_MODE_VALIDATION_ALLOW_DP_INTERLACED = (1 << 17),
|
|
NVKMS_MODE_VALIDATION_NO_INTERLACED_MODES = (1 << 18),
|
|
NVKMS_MODE_VALIDATION_MAX_ONE_HARDWARE_HEAD = (1 << 19),
|
|
};
|
|
|
|
/*!
|
|
* Frequency information used during mode validation (for HorizSync
|
|
* and VertRefresh) can come from several possible sources. NVKMS
|
|
* selects the frequency information by prioritizing the input sources
|
|
* and then reports the selected source.
|
|
*
|
|
* Without client input, NVKMS will use frequency ranges from the
|
|
* EDID, if available. If there is no EDID, NVKMS will fall back to
|
|
* builtin conservative defaults.
|
|
*
|
|
* The client can specify frequency ranges that are used instead of
|
|
* anything in the EDID (_CLIENT_BEFORE_EDID), or frequency ranges
|
|
* that are used only if no EDID-reported ranges are available
|
|
* (_CLIENT_AFTER_EDID).
|
|
*/
|
|
enum NvKmsModeValidationFrequencyRangesSource {
|
|
NVKMS_MODE_VALIDATION_FREQUENCY_RANGE_SOURCE_NONE = 0,
|
|
NVKMS_MODE_VALIDATION_FREQUENCY_RANGE_SOURCE_CLIENT_BEFORE_EDID = 1,
|
|
NVKMS_MODE_VALIDATION_FREQUENCY_RANGE_SOURCE_EDID = 2,
|
|
NVKMS_MODE_VALIDATION_FREQUENCY_RANGE_SOURCE_CLIENT_AFTER_EDID = 3,
|
|
NVKMS_MODE_VALIDATION_FREQUENCY_RANGE_SOURCE_CONSERVATIVE_DEFAULTS = 4,
|
|
};
|
|
|
|
|
|
/*!
|
|
* Mode validation parameters.
|
|
*/
|
|
struct NvKmsModeValidationFrequencyRanges {
|
|
enum NvKmsModeValidationFrequencyRangesSource source;
|
|
NvU32 numRanges;
|
|
struct {
|
|
NvU32 high;
|
|
NvU32 low;
|
|
} range[NVKMS_MAX_VALID_SYNC_RANGES];
|
|
};
|
|
|
|
struct NvKmsModeValidationValidSyncs {
|
|
|
|
/*! If TRUE, ignore frequency information from the EDID. */
|
|
NvBool ignoreEdidSource;
|
|
|
|
/*! values are in Hz */
|
|
struct NvKmsModeValidationFrequencyRanges horizSyncHz;
|
|
|
|
/*! values are in 1/1000 Hz */
|
|
struct NvKmsModeValidationFrequencyRanges vertRefreshHz1k;
|
|
};
|
|
|
|
enum NvKmsStereoMode {
|
|
NVKMS_STEREO_DISABLED = 0,
|
|
NVKMS_STEREO_NVIDIA_3D_VISION,
|
|
NVKMS_STEREO_NVIDIA_3D_VISION_PRO,
|
|
NVKMS_STEREO_HDMI_3D,
|
|
NVKMS_STEREO_OTHER,
|
|
};
|
|
|
|
struct NvKmsModeValidationParams {
|
|
NvBool verboseModeValidation;
|
|
NvBool moreVerboseModeValidation;
|
|
|
|
/*!
|
|
* Normally, if a mode supports both YUV 4:2:0 and RGB 4:4:4,
|
|
* NVKMS will prefer RGB 4:4:4 if both the monitor and the GPU
|
|
* support it. Use preferYUV420 to override that preference.
|
|
*/
|
|
NvBool preferYUV420;
|
|
|
|
enum NvKmsStereoMode stereoMode;
|
|
NvU32 overrides;
|
|
|
|
struct NvKmsModeValidationValidSyncs validSyncs;
|
|
|
|
/*!
|
|
* Normally, NVKMS will determine on its own whether to use Display
|
|
* Stream Compression (DSC). Use forceDsc to force NVKMS to use DSC,
|
|
* when the GPU supports it.
|
|
*/
|
|
NvBool forceDsc;
|
|
|
|
/*!
|
|
* When enabled, Display Stream Compression (DSC) has an
|
|
* associated bits/pixel rate, which NVKMS normally computes.
|
|
* Use dscOverrideBitsPerPixelX16 to override the DSC bits/pixel rate.
|
|
* This is in units of 1/16 of a bit per pixel.
|
|
*
|
|
* This target bits/pixel rate should be >= 8.0 and <= 32.0, i.e. the valid
|
|
* bits/pixel values are members of the sequence 8.0, 8.0625, 8.125, ...,
|
|
* 31.9375, 32.0. You can convert bits/pixel value to
|
|
* the dscOverrideBitsPerPixelX16 as follow:
|
|
*
|
|
* +------------------+--------------------------------------------+
|
|
* | bits_per_pixel | dscBitsPerPixelX16 = bits_per_pixel * 16 |
|
|
* +------------------+--------------------------------------------+
|
|
* | 8.0 | 128 |
|
|
* | 8.0625 | 129 |
|
|
* | . | . |
|
|
* | . | . |
|
|
* | . | . |
|
|
* | 31.9375 | 511 |
|
|
* | 32.0 | 512 |
|
|
* +------------------+--------------------------------------------+
|
|
*
|
|
* If the specified dscOverrideBitsPerPixelX16 is out of range,
|
|
* then mode validation may fail.
|
|
*
|
|
* When dscOverrideBitsPerPixelX16 is 0, NVKMS compute the rate itself.
|
|
*/
|
|
NvU32 dscOverrideBitsPerPixelX16;
|
|
};
|
|
|
|
/*!
|
|
* The list of pixelShift modes.
|
|
*/
|
|
enum NvKmsPixelShiftMode {
|
|
NVKMS_PIXEL_SHIFT_NONE = 0,
|
|
NVKMS_PIXEL_SHIFT_4K_TOP_LEFT,
|
|
NVKMS_PIXEL_SHIFT_4K_BOTTOM_RIGHT,
|
|
NVKMS_PIXEL_SHIFT_8K,
|
|
};
|
|
|
|
/*!
|
|
* The available resampling methods used when viewport scaling is requested.
|
|
*/
|
|
enum NvKmsResamplingMethod {
|
|
NVKMS_RESAMPLING_METHOD_BILINEAR = 0,
|
|
NVKMS_RESAMPLING_METHOD_BICUBIC_TRIANGULAR,
|
|
NVKMS_RESAMPLING_METHOD_BICUBIC_BELL_SHAPED,
|
|
NVKMS_RESAMPLING_METHOD_BICUBIC_BSPLINE,
|
|
NVKMS_RESAMPLING_METHOD_BICUBIC_ADAPTIVE_TRIANGULAR,
|
|
NVKMS_RESAMPLING_METHOD_BICUBIC_ADAPTIVE_BELL_SHAPED,
|
|
NVKMS_RESAMPLING_METHOD_BICUBIC_ADAPTIVE_BSPLINE,
|
|
NVKMS_RESAMPLING_METHOD_NEAREST,
|
|
NVKMS_RESAMPLING_METHOD_DEFAULT = NVKMS_RESAMPLING_METHOD_BILINEAR,
|
|
};
|
|
|
|
enum NvKmsWarpMeshDataType {
|
|
NVKMS_WARP_MESH_DATA_TYPE_TRIANGLES_XYUVRQ,
|
|
NVKMS_WARP_MESH_DATA_TYPE_TRIANGLE_STRIP_XYUVRQ,
|
|
};
|
|
|
|
/*!
|
|
* Description of a cursor image on a single head; this is used by any
|
|
* NVKMS request that needs to specify the cursor image.
|
|
*/
|
|
struct NvKmsSetCursorImageCommonParams {
|
|
/*! The surface to display in the cursor. */
|
|
NvKmsSurfaceHandle surfaceHandle[NVKMS_MAX_EYES];
|
|
/*!
|
|
* The cursor composition parameters gets read and applied only if the
|
|
* specified cursor surface is not null.
|
|
*/
|
|
struct NvKmsCompositionParams cursorCompParams;
|
|
};
|
|
|
|
|
|
/*!
|
|
* Description of the cursor position on a single head; this is used
|
|
* by any NVKMS request that needs to specify the cursor position.
|
|
*
|
|
* x,y are relative to the current viewPortIn configured on the head.
|
|
*/
|
|
struct NvKmsMoveCursorCommonParams {
|
|
NvS16 x; /*! in */
|
|
NvS16 y; /*! in */
|
|
};
|
|
|
|
/*!
|
|
* Per-component arrays of NvU16s describing the LUT; used for both the input
|
|
* LUT and output LUT.
|
|
*/
|
|
struct NvKmsLutRamps {
|
|
NvU16 red[NVKMS_LUT_ARRAY_SIZE]; /*! in */
|
|
NvU16 green[NVKMS_LUT_ARRAY_SIZE]; /*! in */
|
|
NvU16 blue[NVKMS_LUT_ARRAY_SIZE]; /*! in */
|
|
};
|
|
|
|
/*!
|
|
* Description of the main layer LUT on a single head; this is used by any NVKMS
|
|
* request that needs to specify the LUT.
|
|
*/
|
|
struct NvKmsSetInputLutParams {
|
|
NvBool specified;
|
|
NvU32 depth; /*! used bits per pixel (8, 15, 16, 24, 30) */
|
|
|
|
/*!
|
|
* The first and last elements (inclusive) in the color arrays to
|
|
* use. Valid values are in the range [0,N], where N is a
|
|
* function of depth:
|
|
*
|
|
* Depth N
|
|
* 8 256
|
|
* 15 32
|
|
* 16 64
|
|
* 24 256
|
|
* 30 1024
|
|
*
|
|
* 'start' is the first element in the color arrays to use.
|
|
*/
|
|
NvU32 start;
|
|
|
|
/*!
|
|
* 'end' is the last element (inclusive) in the color arrays to
|
|
* use. If end == 0, this command will disable the HW LUT for
|
|
* this head.
|
|
*
|
|
* The other fields in this structure, besides 'specified', are ignored if
|
|
* end == 0.
|
|
*/
|
|
NvU32 end;
|
|
|
|
/*!
|
|
* Pointer to struct NvKmsLutRamps describing the LUT.
|
|
* Elements [start,end] will be used.
|
|
*
|
|
* Each entry in the input LUT has valid values in the range [0, 65535].
|
|
* However, on pre-Turing GPUs only 11 bits are significant; NVKMS will
|
|
* convert values in this range into the appropriate internal format.
|
|
*
|
|
* Use nvKmsPointerToNvU64() to assign pRamps.
|
|
*/
|
|
NvU64 pRamps NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
|
|
/*!
|
|
* Description of the output LUT on a single head; this is used by any NVKMS
|
|
* request that needs to specify the LUT.
|
|
*
|
|
* Unlike the input LUT:
|
|
* - specifying the output LUT updates all values at once.
|
|
*
|
|
* Each entry in the output LUT has valid values in the range [0, 65535].
|
|
* However, only 11 bits are significant; NVKMS will convert values in this
|
|
* range into the appropriate internal format.
|
|
*/
|
|
struct NvKmsSetOutputLutParams {
|
|
NvBool specified;
|
|
NvBool enabled;
|
|
|
|
/*!
|
|
* Pointer to struct NvKmsLutRamps containing the actual LUT data, if
|
|
* required.
|
|
* Use nvKmsPointerToNvU64() to assign pRamps.
|
|
*/
|
|
NvU64 pRamps NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
/*!
|
|
* Description of the LUT on a single head; this is used by any NVKMS
|
|
* request that needs to specify the LUT.
|
|
*/
|
|
struct NvKmsSetLutCommonParams {
|
|
struct NvKmsSetInputLutParams input;
|
|
struct NvKmsSetOutputLutParams output;
|
|
|
|
NvBool synchronous; /*! block until the LUT update is complete */
|
|
};
|
|
|
|
struct NvKmsNIsoSurface {
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
enum NvKmsNIsoFormat format;
|
|
NvU16 offsetInWords;
|
|
};
|
|
|
|
struct NvKmsCompletionNotifierDescription {
|
|
struct NvKmsNIsoSurface surface;
|
|
NvBool awaken;
|
|
};
|
|
|
|
struct NvKmsSemaphore {
|
|
struct NvKmsNIsoSurface surface;
|
|
NvU32 value;
|
|
};
|
|
|
|
enum NvKmsSyncptType {
|
|
NVKMS_SYNCPT_TYPE_NONE,
|
|
NVKMS_SYNCPT_TYPE_RAW,
|
|
NVKMS_SYNCPT_TYPE_FD,
|
|
};
|
|
|
|
struct NvKmsSyncpt {
|
|
enum NvKmsSyncptType type;
|
|
union {
|
|
int fd;
|
|
struct {
|
|
NvU32 id;
|
|
NvU32 value;
|
|
} raw;
|
|
} u;
|
|
};
|
|
|
|
struct NvKmsChannelSyncObjects {
|
|
/*
|
|
* If useSyncpt is set to FALSE, clients can provide an acquisition and/or
|
|
* release semaphore via the 'syncObjects.semaphores' struct.
|
|
*
|
|
* If NvKmsAllocDeviceReply::supportsIndependentAcqRelSemaphore is
|
|
* FALSE, then 'syncObjects.semaphores.acquire.surface' must be the same
|
|
* as 'syncObjects.semaphores.release.surface'. In other words, the same
|
|
* exact semaphore surface must be used for both acquire and release.
|
|
*
|
|
* If NvKmsAllocDeviceReply::supportsIndependentAcqRelSemaphore is
|
|
* TRUE, then the client is allowed to provide different semaphore
|
|
* surfaces for acquire and release.
|
|
*
|
|
* If useSyncpt is set to TRUE, clients can provide a pre-syncpt that they
|
|
* want the display engine to wait on before scanning out from the given
|
|
* buffer, and can specify that they want NVKMS to return a post-syncpt
|
|
* that they can wait on, via the 'syncObjects.syncpts' struct.
|
|
*
|
|
* The post-syncpt that NVKMS returns will be signaled once the
|
|
* buffer that was activated by this flip is displaced. As a typical
|
|
* example:
|
|
* - Client flips buffer A, and requests a post-syncpt PS.
|
|
* - Buffer A becomes active at the next frame boundary, and display
|
|
* starts scanning out buffer A.
|
|
* - Client flips buffer B.
|
|
* - Once the UPDATE for the buffer B flip is processed and display
|
|
* has finished sending the last pixel of buffer A to precomp for
|
|
* the current frame, post-syncpt PS will get signaled.
|
|
*
|
|
* Clients can use this option iff
|
|
* NvKmsAllocDeviceReply::supportsSyncpts is TRUE.
|
|
*/
|
|
NvBool useSyncpt;
|
|
|
|
union {
|
|
struct {
|
|
struct NvKmsSemaphore acquire;
|
|
struct NvKmsSemaphore release;
|
|
} semaphores;
|
|
|
|
struct {
|
|
struct NvKmsSyncpt pre;
|
|
enum NvKmsSyncptType requestedPostType;
|
|
} syncpts;
|
|
} u;
|
|
};
|
|
|
|
/*!
|
|
* Description of how to flip on a single head.
|
|
*
|
|
* viewPortIn::point describes the position of the viewPortIn that
|
|
* should be scaled to the viewPortOut of the head. The
|
|
* viewPortSizeIn is specified by NvKmsSetModeOneHeadRequest. Note
|
|
* that viewPortIn::point is in desktop coordinate space, and
|
|
* therefore applies across all layers.
|
|
*
|
|
* For YUV420 modes, the surfaces and position should be in "half"
|
|
* horizontal space. See the explanation in NvKmsMode.
|
|
*
|
|
* If 'specified' is FALSE for any of the layers, then the current
|
|
* hardware value is used.
|
|
*/
|
|
struct NvKmsFlipCommonParams {
|
|
|
|
struct {
|
|
NvBool specified;
|
|
struct NvKmsPoint point;
|
|
} viewPortIn;
|
|
|
|
struct {
|
|
struct NvKmsSetCursorImageCommonParams image;
|
|
NvBool imageSpecified;
|
|
|
|
struct NvKmsMoveCursorCommonParams position;
|
|
NvBool positionSpecified;
|
|
} cursor;
|
|
|
|
/*
|
|
* Set the output transfer function.
|
|
*
|
|
* If output transfer function is HDR and staticMetadata is disabled
|
|
* for all the layers, flip request will be rejected.
|
|
*
|
|
* If output transfer function is HDR and staticMetadata is enabled
|
|
* for any of the layers, HDR output will be enabled. In this case,
|
|
* output lut values specified during modeset will be ignored and
|
|
* output lut will be set with the specified HDR transfer function.
|
|
*
|
|
* If output transfer function is SDR and staticMetadata is enabled,
|
|
* HDR content for that layer will be tonemapped to the SDR output
|
|
* range.
|
|
*/
|
|
struct {
|
|
enum NvKmsOutputTf val;
|
|
NvBool specified;
|
|
} tf;
|
|
|
|
struct {
|
|
struct {
|
|
NvKmsSurfaceHandle handle[NVKMS_MAX_EYES];
|
|
struct NvKmsRRParams rrParams;
|
|
NvBool specified;
|
|
} surface;
|
|
|
|
/*
|
|
* sizeIn/sizeOut can be used when
|
|
* NvKmsAllocDeviceReply::layerCaps[layer].supportsWindowMode is TRUE.
|
|
*/
|
|
struct {
|
|
struct NvKmsSize val;
|
|
NvBool specified;
|
|
} sizeIn;
|
|
|
|
struct {
|
|
struct NvKmsSize val;
|
|
NvBool specified;
|
|
} sizeOut;
|
|
|
|
/*
|
|
* Set the position of the layer, relative to the upper left
|
|
* corner of the surface. This controls the same state as
|
|
* NVKMS_IOCTL_SET_LAYER_POSITION.
|
|
*
|
|
* This field can be used when
|
|
* NvKmsAllocDeviceReply::layerCaps[layer].supportsWindowMode is TRUE.
|
|
*/
|
|
struct {
|
|
struct NvKmsSignedPoint val;
|
|
NvBool specified;
|
|
} outputPosition;
|
|
|
|
struct {
|
|
struct NvKmsCompletionNotifierDescription val;
|
|
NvBool specified;
|
|
} completionNotifier;
|
|
|
|
struct {
|
|
struct NvKmsChannelSyncObjects val;
|
|
|
|
/* If 'specified' is FALSE, then the current hardware value is used. */
|
|
NvBool specified;
|
|
} syncObjects;
|
|
|
|
/*
|
|
* If 'maxDownscaleFactors::specified' is true, nvkms will set the
|
|
* max H/V downscale usage bounds to the values specified in
|
|
* 'maxDownscaleFactors::horizontal' and 'maxDownscaleFactors::vertical'.
|
|
*
|
|
* If the 'maxDownscaleFactors::specified' values are within the bounds
|
|
* of 'NvKmsSetModeOneHeadReply::guaranteedUsage', then clients can expect
|
|
* the flip to succeed. If the 'maxDownscaleFactors::specified' values are
|
|
* beyond the bounds of 'NvKmsSetModeOneHeadReply::guaranteedUsage' but
|
|
* within 'NvKmsSetModeOneHeadReply::possibleUsage', then the request may
|
|
* legitimately fail due to insufficient display bandwidth and clients
|
|
* need to be prepared to handle that flip request failure.
|
|
*
|
|
* If 'maxDownscaleFactors::specified' is false, nvkms will calculate max
|
|
* H/V downscale factor by quantizing the range. E.g., max H/V downscale
|
|
* factor supported by HW is 4x for 5-tap and 2x for 2-tap mode. If
|
|
* 5-tap mode is required, the target usage bound that nvkms will
|
|
* attempt to program will either allow up to 2x downscaling, or up to
|
|
* 4x downscaling. If 2-tap mode is required, the target usage bound
|
|
* that NVKMS will attempt to program will allow up to 2x downscaling.
|
|
* Example: to downscale from 4096x2160 -> 2731x864 in 5-tap mode,
|
|
* NVKMS would specify up to 2x for the H downscale bound (required is
|
|
* 1.5x), and up to 4x for the V downscale bound (required is 2.5x).
|
|
*/
|
|
struct {
|
|
/*
|
|
* Maximum vertical downscale factor (scaled by 1024)
|
|
*
|
|
* For example, if the downscale factor is 1.5, then maxVDownscaleFactor
|
|
* would be 1.5 x 1024 = 1536.
|
|
*/
|
|
NvU16 vertical;
|
|
|
|
/*
|
|
* Maximum horizontal downscale factor (scaled by 1024)
|
|
*
|
|
* See the example above for vertical.
|
|
*/
|
|
NvU16 horizontal;
|
|
|
|
NvBool specified;
|
|
} maxDownscaleFactors;
|
|
|
|
NvBool tearing;
|
|
|
|
/*
|
|
* When true, we will flip to this buffer whenever the current eye is
|
|
* finished scanning out. Otherwise, this flip will only execute after
|
|
* both eyes have finished scanout.
|
|
*
|
|
* Note that if this is FALSE and a vsynced stereo flip is requested,
|
|
* the buffers in this flip will be displayed for minPresentInterval*2
|
|
* vblanks, one for each eye.
|
|
*
|
|
* This flag cannot be used for the overlay layer.
|
|
*/
|
|
NvBool perEyeStereoFlip;
|
|
|
|
/* When non-zero, block the flip until PTIMER >= timeStamp. */
|
|
NvU64 timeStamp NV_ALIGN_BYTES(8);
|
|
NvU8 minPresentInterval;
|
|
|
|
/* This field cannot be used for the main layer right now. */
|
|
struct {
|
|
struct NvKmsCompositionParams val;
|
|
NvBool specified;
|
|
} compositionParams;
|
|
|
|
/*
|
|
* Color-space conversion matrix applied to the layer before
|
|
* compositing.
|
|
*
|
|
* If csc::specified is TRUE and csc::useMain is TRUE, then the CSC
|
|
* matrix specified in the main layer is used instead of the one here.
|
|
* If csc::specified is FALSE, then the CSC matrix used from the previous
|
|
* flip is used. csc::useMain must be set to FALSE for the main layer.
|
|
*/
|
|
struct {
|
|
NvBool specified;
|
|
NvBool useMain;
|
|
struct NvKmsCscMatrix matrix;
|
|
} csc;
|
|
|
|
/*
|
|
* When true, all pending flips and synchronization operations get
|
|
* ignored, and channel flips to given buffer. Notifier and semaphore
|
|
* should not be specified if this flag is true. This flag does
|
|
* nothing if set true for NVKMS_IOCTL_SET_MODE ioctl.
|
|
*
|
|
* This flag allows client to remove stalled flips and unblock
|
|
* the channel.
|
|
*
|
|
* This flag cannot be used for the overlay layer.
|
|
*/
|
|
NvBool skipPendingFlips;
|
|
|
|
/*
|
|
* This field can be used when
|
|
* NvKmsAllocDeviceReply::layerCaps[layer].supportsHDR = TRUE.
|
|
*
|
|
* If staticMetadata is enabled for multiple layers, flip request
|
|
* will be rejected.
|
|
*/
|
|
struct {
|
|
NvBool specified;
|
|
/*!
|
|
* If TRUE, enable HDR static metadata. If FALSE, disable it.
|
|
*
|
|
* Note that “specified” serves to mark the field as being changed
|
|
* in this flip request, rather than as specified for this frame.
|
|
* So to disable HDR static metadata, set hdr.specified = TRUE and
|
|
* hdr.staticMetadata.enabled = FALSE.
|
|
*/
|
|
NvBool enabled;
|
|
struct NvKmsHDRStaticMetadata staticMetadata;
|
|
} hdr;
|
|
|
|
/* Specifies whether the input color range is FULL or LIMITED. */
|
|
struct {
|
|
enum NvKmsInputColorRange val;
|
|
NvBool specified;
|
|
} colorRange;
|
|
|
|
/* This field has no effect right now. */
|
|
struct {
|
|
enum NvKmsInputColorSpace val;
|
|
NvBool specified;
|
|
} colorSpace;
|
|
} layer[NVKMS_MAX_LAYERS_PER_HEAD];
|
|
};
|
|
|
|
struct NvKmsFlipCommonReplyOneHead {
|
|
struct {
|
|
struct NvKmsSyncpt postSyncpt;
|
|
} layer[NVKMS_MAX_LAYERS_PER_HEAD];
|
|
};
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_ALLOC_DEVICE: Allocate an NVKMS device object.
|
|
*
|
|
* This has the scope of a resman SLI device.
|
|
*
|
|
* Multiple clients can allocate devices (DRM-KMS, multiple X
|
|
* servers). Clients should configure SLI before initializing NVKMS.
|
|
* NVKMS will query resman for the current SLI topology.
|
|
*
|
|
* The SLI configuration (both the linked SLI device, and the sliMosaic
|
|
* boolean below) will be latched when the specified GPU transitions
|
|
* from zero NVKMS devices allocated to one NVKMS device allocated.
|
|
*
|
|
* The returned information will remain static until the NVKMS device
|
|
* object is freed.
|
|
*/
|
|
|
|
struct NvKmsAllocDeviceRequest {
|
|
/*!
|
|
* Clients should populate versionString with the value of
|
|
* NV_VERSION_STRING from nvUnixVersion.h. This is used for a
|
|
* version handshake.
|
|
*/
|
|
char versionString[NVKMS_NVIDIA_DRIVER_VERSION_STRING_LENGTH];
|
|
|
|
/*!
|
|
* The (primary) GPU for this device; this is used as the value
|
|
* for NV0080_ALLOC_PARAMETERS::deviceId.
|
|
*/
|
|
NvU32 deviceId;
|
|
|
|
/*!
|
|
* Whether SLI Mosaic is requested: i.e., multiple disps, one
|
|
* per physical GPU, for the SLI device.
|
|
*/
|
|
NvBool sliMosaic;
|
|
|
|
/*!
|
|
* When tryInferSliMosaicFromExistingDevice=TRUE, then the above
|
|
* 'sliMosaic' field is ignored and the ALLOC_DEVICE request will
|
|
* inherit the current sliMosaic state of the existing device
|
|
* identified by deviceId. If there is not an existing device for
|
|
* deviceId, then the ALLOC_DEVICE request will proceed normally, honoring
|
|
* the requested sliMosaic state.
|
|
*/
|
|
NvBool tryInferSliMosaicFromExistingDevice;
|
|
|
|
/*!
|
|
* NVKMS will use the 3D engine for headSurface. If clients want to avoid
|
|
* the use of the 3D engine, set no3d = TRUE. Note this will cause modesets
|
|
* that require headSurface to fail.
|
|
*
|
|
* This flag is only honored when there is not already an existing device
|
|
* for the deviceId.
|
|
*/
|
|
NvBool no3d;
|
|
|
|
/*!
|
|
* When enableConsoleHotplugHandling is TRUE, NVKMS will start handling
|
|
* hotplug events at the console when no modeset owner is present.
|
|
*
|
|
* If FALSE, console hotplug handling behavior is not changed.
|
|
*
|
|
* This should be set to TRUE for clients that intend to allocate the device
|
|
* but don't intend to become the modeset owner right away. It should be set
|
|
* to FALSE for clients that may take modeset ownership immediately, in
|
|
* order to suppress hotplug handling between the NVKMS_IOCTL_ALLOC_DEVICE
|
|
* and NVKMS_IOCTL_GRAB_OWNERSHIP calls when the calling client is the first
|
|
* to allocate the device.
|
|
*
|
|
* Note that NVKMS_IOCTL_RELEASE_OWNERSHIP also enables console hotplug
|
|
* handling. Once enabled, console hotplug handling remains enabled until
|
|
* the last client frees the device.
|
|
*/
|
|
NvBool enableConsoleHotplugHandling;
|
|
|
|
struct {
|
|
/* name[0] == '\0' for unused registryKeys[] array elements. */
|
|
char name[NVKMS_MAX_DEVICE_REGISTRY_KEYNAME_LEN];
|
|
NvU32 value;
|
|
} registryKeys[NVKMS_MAX_DEVICE_REGISTRY_KEYS];
|
|
};
|
|
|
|
enum NvKmsAllocDeviceStatus {
|
|
NVKMS_ALLOC_DEVICE_STATUS_SUCCESS,
|
|
NVKMS_ALLOC_DEVICE_STATUS_VERSION_MISMATCH,
|
|
NVKMS_ALLOC_DEVICE_STATUS_BAD_REQUEST,
|
|
NVKMS_ALLOC_DEVICE_STATUS_FATAL_ERROR,
|
|
NVKMS_ALLOC_DEVICE_STATUS_NO_HARDWARE_AVAILABLE,
|
|
NVKMS_ALLOC_DEVICE_STATUS_CORE_CHANNEL_ALLOC_FAILED,
|
|
};
|
|
|
|
|
|
struct NvKmsAllocDeviceReply {
|
|
|
|
enum NvKmsAllocDeviceStatus status;
|
|
|
|
/*!
|
|
* The handle to use when identifying this NVKMS device in
|
|
* subsequent calls.
|
|
*/
|
|
NvKmsDeviceHandle deviceHandle;
|
|
|
|
/*!
|
|
* A bitmask, indicating the GPUs, one per bit, contained by this
|
|
* device.
|
|
*/
|
|
NvU32 subDeviceMask;
|
|
|
|
/*! The number of heads on each disp. */
|
|
NvU32 numHeads;
|
|
|
|
/*! The number of disps. */
|
|
NvU32 numDisps;
|
|
|
|
/*! The handle to identify each disp, in dispHandles[0..numDisps). */
|
|
NvKmsDispHandle dispHandles[NVKMS_MAX_SUBDEVICES];
|
|
|
|
/*!
|
|
* Device-wide Capabilities: of the display engine.
|
|
*
|
|
* IMPLEMENTATION NOTE: this is the portion of DispHalRec::caps
|
|
* that can vary between EVO classes.
|
|
*/
|
|
NvBool requiresVrrSemaphores;
|
|
NvBool inputLutAppliesToBase;
|
|
|
|
/*!
|
|
* Whether the client can allocate and manipulate SwapGroup objects via
|
|
* NVKMS_IOCTL_ALLOC_SWAP_GROUP and friends.
|
|
*/
|
|
NvBool supportsSwapGroups;
|
|
|
|
/*!
|
|
* Whether NVKMS supports Warp and Blend on this device.
|
|
*/
|
|
NvBool supportsWarpAndBlend;
|
|
|
|
/*!
|
|
* When nIsoSurfacesInVidmemOnly=TRUE, then only video memory
|
|
* surfaces can be used for the surface in
|
|
* NvKmsCompletionNotifierDescription or NvKmsSemaphore.
|
|
*/
|
|
NvBool nIsoSurfacesInVidmemOnly;
|
|
|
|
/*
|
|
* When requiresAllAllocationsInSysmem=TRUE, then all memory allocations
|
|
* that will be accessed by display must come from sysmem.
|
|
*/
|
|
NvBool requiresAllAllocationsInSysmem;
|
|
|
|
/*
|
|
* Whether the device that NVKMS is driving supports headSurface GPU
|
|
* composition.
|
|
*/
|
|
NvBool supportsHeadSurface;
|
|
|
|
/*!
|
|
* The display engine supports a "legacy" format for notifiers and
|
|
* semaphores (one word for semaphores and base channel notifiers;
|
|
* two words for overlay notifiers). On newer GPUs, the display
|
|
* engine also supports a similar four word semaphore and notifier
|
|
* format used by graphics.
|
|
*
|
|
* This describes which values are valid for NvKmsNIsoFormat.
|
|
*
|
|
* Iff a particular enum NvKmsNIsoFormat 'value' is supported,
|
|
* then (1 << value) will be set in validNIsoFormatMask.
|
|
*/
|
|
NvU8 validNIsoFormatMask;
|
|
|
|
NvU32 surfaceAlignment;
|
|
NvU32 maxWidthInBytes;
|
|
NvU32 maxWidthInPixels;
|
|
NvU32 maxHeightInPixels;
|
|
NvU32 maxCursorSize;
|
|
|
|
/*!
|
|
* The page kind used by the GPU's MMU for uncompressed block-linear color
|
|
* formats.
|
|
*/
|
|
NvU8 genericPageKind;
|
|
|
|
/*!
|
|
* Describes the supported Color Key selects and blending modes for match
|
|
* and nomatch cursor pixels.
|
|
*/
|
|
struct NvKmsCompositionCapabilities cursorCompositionCaps;
|
|
|
|
/*! The number of layers attached to each head. */
|
|
NvU32 numLayers[NVKMS_MAX_HEADS_PER_DISP];
|
|
|
|
/*!
|
|
* Describes supported functionalities for each layer.
|
|
*/
|
|
struct NvKmsLayerCapabilities layerCaps[NVKMS_MAX_LAYERS_PER_HEAD];
|
|
|
|
/*!
|
|
* This bitmask specifies all of the (rotation, reflectionX, reflectionY)
|
|
* combinations that are supported for the main and overlay layers.
|
|
* Each bit in this bitmask is mapped to one combination per the scheme
|
|
* in NvKmsRRParamsToCapBit().
|
|
*/
|
|
NvU16 validLayerRRTransforms;
|
|
|
|
/*!
|
|
* IO coherency modes that display supports for ISO and NISO memory
|
|
* allocations, respectively.
|
|
*/
|
|
NvKmsDispIOCoherencyModes isoIOCoherencyModes;
|
|
NvKmsDispIOCoherencyModes nisoIOCoherencyModes;
|
|
|
|
/*!
|
|
* 'displayIsGpuL2Coherent' indicates whether display is coherent with
|
|
* GPU's L2 cache.
|
|
*/
|
|
NvBool displayIsGpuL2Coherent;
|
|
|
|
/*!
|
|
* 'supportsSyncpts' indicates whether NVKMS supports the use of syncpts
|
|
* for synchronization.
|
|
*/
|
|
NvBool supportsSyncpts;
|
|
|
|
/*!
|
|
* 'supportsIndependentAcqRelSemaphore' indicates whether HW supports
|
|
* configuring different semaphores for acquire and release for a buffer
|
|
* flip on a given layer.
|
|
*/
|
|
NvBool supportsIndependentAcqRelSemaphore;
|
|
|
|
/*!
|
|
* 'supportsVblankSyncObjects' indicates whether HW supports raster
|
|
* generator sync objects that signal at vblank.
|
|
*/
|
|
NvBool supportsVblankSyncObjects;
|
|
};
|
|
|
|
struct NvKmsAllocDeviceParams {
|
|
struct NvKmsAllocDeviceRequest request; /*! in */
|
|
struct NvKmsAllocDeviceReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_FREE_DEVICE: Free the NVKMS device object specified by
|
|
* deviceHandle.
|
|
*
|
|
* The underlying device is not actually freed until all callers of
|
|
* NVKMS_IOCTL_ALLOC_DEVICE have freed their reference to the device.
|
|
*
|
|
* When a client calls FREE_DEVICE, any configuration specified by
|
|
* that client will be removed:
|
|
* - Any EDID overrides.
|
|
* - Any interest declared on dynamic dpys.
|
|
* - Any cursor image on any head.
|
|
* - Any custom LUT contents.
|
|
* - Any interest declared on any events.
|
|
*
|
|
* XXX define how FREE_DEVICE interacts with:
|
|
* - concurrent X servers on different VTs
|
|
* - console restore
|
|
*/
|
|
|
|
struct NvKmsFreeDeviceRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
};
|
|
|
|
struct NvKmsFreeDeviceReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsFreeDeviceParams {
|
|
struct NvKmsFreeDeviceRequest request; /*! in */
|
|
struct NvKmsFreeDeviceReply reply; /*!out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_QUERY_DISP: Query information about the NVKMS disp
|
|
* object specified by the tuple (deviceHandle, dispHandle).
|
|
*
|
|
* The returned information will remain static until the NVKMS device
|
|
* object is freed.
|
|
*/
|
|
|
|
struct NvKmsQueryDispRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
};
|
|
|
|
struct NvKmsQueryDispReply {
|
|
/*! The possible dpys for this disp, excluding any dynamic dpys. */
|
|
NVDpyIdList validDpys;
|
|
|
|
/*! The dpys that were driven at boot-time, if any. */
|
|
NVDpyIdList bootDpys;
|
|
|
|
/*! The dpys that are capable of dynamic mux switching, if any. */
|
|
NVDpyIdList muxDpys;
|
|
|
|
/*! The framelock device, if any, connected to this disp. */
|
|
NvKmsFrameLockHandle frameLockHandle;
|
|
|
|
/*! The number of connectors on this disp. */
|
|
NvU32 numConnectors;
|
|
|
|
/*!
|
|
* The handle to identify each connector, in
|
|
* connectorHandles[0..numConnectors)
|
|
*/
|
|
NvKmsConnectorHandle connectorHandles[NVKMS_MAX_CONNECTORS_PER_DISP];
|
|
|
|
/*!
|
|
* A string describing one of the the GPUs used by this disp. The
|
|
* NVKMS log will also print this string to the kernel log. Users
|
|
* should be able to correlate GPUs between NVKMS and NVKMS
|
|
* clients using this string.
|
|
*/
|
|
char gpuString[NVKMS_GPU_STRING_SIZE];
|
|
};
|
|
|
|
struct NvKmsQueryDispParams {
|
|
struct NvKmsQueryDispRequest request; /*! in */
|
|
struct NvKmsQueryDispReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_QUERY_CONNECTOR_STATIC_DATA: Query information about the NVKMS
|
|
* connector object specified by the triplet (deviceHandle, dispHandle,
|
|
* connectorHandle).
|
|
*
|
|
* The returned information will remain static until the NVKMS device
|
|
* object is freed.
|
|
*/
|
|
|
|
struct NvKmsQueryConnectorStaticDataRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvKmsConnectorHandle connectorHandle;
|
|
};
|
|
|
|
struct NvKmsQueryConnectorStaticDataReply {
|
|
NVDpyId dpyId;
|
|
NvBool isDP;
|
|
NvBool isLvds;
|
|
NvBool locationOnChip;
|
|
NvU32 legacyTypeIndex;
|
|
NvKmsConnectorType type;
|
|
NvU32 typeIndex;
|
|
NvKmsConnectorSignalFormat signalFormat;
|
|
NvU32 physicalIndex;
|
|
NvU32 physicalLocation;
|
|
};
|
|
|
|
struct NvKmsQueryConnectorStaticDataParams {
|
|
struct NvKmsQueryConnectorStaticDataRequest request; /*! in */
|
|
struct NvKmsQueryConnectorStaticDataReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_QUERY_CONNECTOR_DYNAMIC_DATA: Query dynamic information about the
|
|
* NVKMS connector object specified by the triplet (deviceHandle, dispHandle,
|
|
* connectorHandle).
|
|
*/
|
|
|
|
struct NvKmsQueryConnectorDynamicDataRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvKmsConnectorHandle connectorHandle;
|
|
};
|
|
|
|
struct NvKmsQueryConnectorDynamicDataReply {
|
|
#define NVKMS_DP_DETECT_COMPLETE_POLL_INTERVAL_USEC 100000 /* in microseconds */
|
|
#define NVKMS_DP_DETECT_COMPLETE_TIMEOUT_USEC 10000000 /* in microseconds */
|
|
|
|
/*
|
|
* For DisplayPort devices, indicates whether the DisplayPort library is
|
|
* finished detecting devices on this connector. This is set to TRUE for
|
|
* other devices because NVKMS knows as soon as ALLOC_DEVICE is complete
|
|
* whether the device is connected or not.
|
|
*/
|
|
NvBool detectComplete;
|
|
/*
|
|
* Contains the list of display IDs for dynamic dpys detected on this
|
|
* connector.
|
|
*/
|
|
NVDpyIdList dynamicDpyIdList;
|
|
};
|
|
|
|
struct NvKmsQueryConnectorDynamicDataParams {
|
|
struct NvKmsQueryConnectorDynamicDataRequest request; /*! in */
|
|
struct NvKmsQueryConnectorDynamicDataReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_QUERY_DPY_STATIC_DATA: Query static information about
|
|
* the NVKMS dpy object specified by the triplet (deviceHandle,
|
|
* dispHandle, dpyId). This information should remain static for the
|
|
* lifetime of the dpy.
|
|
*/
|
|
|
|
struct NvKmsQueryDpyStaticDataRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
};
|
|
|
|
struct NvKmsQueryDpyStaticDataReply {
|
|
NvKmsConnectorHandle connectorHandle; /*! The connector driving this dpy. */
|
|
NvU32 type; /*! NV0073_CTRL_SPECIFIC_DISPLAY_TYPE_ */
|
|
char dpAddress[NVKMS_DP_ADDRESS_STRING_LENGTH];
|
|
NvBool mobileInternal;
|
|
NvBool isDpMST;
|
|
/* Bitmask of valid heads to drive this dpy. */
|
|
NvU32 headMask;
|
|
};
|
|
|
|
struct NvKmsQueryDpyStaticDataParams {
|
|
struct NvKmsQueryDpyStaticDataRequest request; /*! in */
|
|
struct NvKmsQueryDpyStaticDataReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_QUERY_DPY_DYNAMIC_DATA: Query dynamic information about
|
|
* the NVKMS dpy object specified by the triplet (deviceHandle,
|
|
* dispHandle, dpyId).
|
|
*
|
|
* This information should be re-queried after an
|
|
* NVKMS_EVENT_TYPE_DPY_CHANGED event.
|
|
*/
|
|
|
|
struct NvKmsQueryDpyDynamicDataRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
|
|
NvBool forceConnected;
|
|
NvBool forceDisconnected;
|
|
NvBool overrideEdid;
|
|
NvBool ignoreEdid;
|
|
NvBool ignoreEdidChecksum;
|
|
NvBool allowDVISpecPClkOverride;
|
|
NvBool dpInbandStereoSignaling;
|
|
NvBool disableACPIBrightnessHotkeys;
|
|
|
|
/*
|
|
* If overrideEdid is TRUE, then edid::buffer[] contains an EDID
|
|
* to override anything detected.
|
|
*/
|
|
struct {
|
|
NvU16 bufferSize;
|
|
NvU8 buffer[NVKMS_EDID_BUFFER_SIZE];
|
|
} edid;
|
|
};
|
|
|
|
enum NvKmsDpyVRRType {
|
|
NVKMS_DPY_VRR_TYPE_NONE,
|
|
NVKMS_DPY_VRR_TYPE_GSYNC,
|
|
NVKMS_DPY_VRR_TYPE_ADAPTIVE_SYNC_DEFAULTLISTED,
|
|
NVKMS_DPY_VRR_TYPE_ADAPTIVE_SYNC_NON_DEFAULTLISTED,
|
|
};
|
|
|
|
struct NvKmsQueryDpyDynamicDataReply {
|
|
char name[NVKMS_DPY_NAME_SIZE];
|
|
|
|
NvU32 maxPixelClockKHz;
|
|
NvBool connected;
|
|
NvBool isVirtualRealityHeadMountedDisplay;
|
|
|
|
struct {
|
|
NvU8 heightInCM; /* vertical screen size */
|
|
NvU8 widthInCM; /* horizontal screen size */
|
|
} physicalDimensions;
|
|
|
|
/*!
|
|
* Which VRR type has been selected for this display, either true
|
|
* G-SYNC, Adaptive-Sync defaultlisted, or Adaptive-Sync non-defaultlisted.
|
|
*/
|
|
enum NvKmsDpyVRRType vrrType;
|
|
|
|
struct {
|
|
NvBool supported;
|
|
NvBool isDLP;
|
|
NvBool isAegis;
|
|
NvU32 subType; /*! STEREO_PLUG_AND_PLAY_ from nvStereoDisplayDef.h */
|
|
} stereo3DVision;
|
|
|
|
struct {
|
|
struct {
|
|
NvBool valid;
|
|
NvU8 buffer[NVKMS_GUID_SIZE];
|
|
char str[NVKMS_GUID_STRING_SIZE];
|
|
} guid;
|
|
} dp;
|
|
|
|
struct {
|
|
/*!
|
|
* The size of the EDID in buffer[], or 0 if there is no EDID
|
|
* available in buffer[].
|
|
*/
|
|
NvU16 bufferSize;
|
|
|
|
/*!
|
|
* Whether NVKMS determined that the EDID is valid. If the
|
|
* EDID is not valid, there may still be information available
|
|
* in infoString: the infoString will describe why the EDID
|
|
* was deemed invalid.
|
|
*/
|
|
NvBool valid;
|
|
|
|
/*!
|
|
* The raw EDID bytes.
|
|
*/
|
|
NvU8 buffer[NVKMS_EDID_BUFFER_SIZE];
|
|
|
|
/*!
|
|
* Parsed information from the EDID. For the raw EDID bytes,
|
|
* see NvKmsQueryDpyDynamicDataParams::edid::buffer[].
|
|
*/
|
|
char infoString[NVKMS_EDID_INFO_STRING_LENGTH];
|
|
} edid;
|
|
|
|
struct NvKmsSuperframeInfo superframeInfo;
|
|
};
|
|
|
|
struct NvKmsQueryDpyDynamicDataParams {
|
|
struct NvKmsQueryDpyDynamicDataRequest request; /*! in */
|
|
struct NvKmsQueryDpyDynamicDataReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_VALIDATE_MODE_INDEX: Validate a particular mode from a
|
|
* dpy's candidate modes.
|
|
*
|
|
* NVKMS can consider modes from a dpy's EDID, as well as a
|
|
* variety of builtin modes.
|
|
*
|
|
* This ioctl identifies one of those candidate modes by index. NVKMS
|
|
* will attempt to validate that candidate mode for the dpy, using the
|
|
* specified mode validation parameters.
|
|
*
|
|
* If the mode index is larger than the list of candidate modes,
|
|
* reply::end will be TRUE. Otherwise, reply::end will be FALSE, and
|
|
* reply::mode will contain the candidate mode.
|
|
*
|
|
* If the mode is valid, then reply::valid will be TRUE. Otherwise,
|
|
* reply::valid will be FALSE. In either case, request::pInfoString[]
|
|
* will contain a description of what happened during mode validation.
|
|
*
|
|
* To query the full modepool, clients should repeatedly call
|
|
* NVKMS_IOCTL_VALIDATE_MODE_INDEX with increasing mode index values,
|
|
* until NVKMS reports end==TRUE.
|
|
*
|
|
* Note that the candidate mode list can change when the dpy changes
|
|
* (reported by the NVKMS_EVENT_TYPE_DPY_CHANGED event). The client
|
|
* should restart its modepool querying if it receives a DPY_CHANGED
|
|
* event. The candidate mode list can also change based on the
|
|
* parameters in request::modeValidation. Clients should not change
|
|
* request::modeValidation while looping over candidate mode indices.
|
|
*
|
|
* Pseudocode example usage pattern:
|
|
*
|
|
* struct NvKmsModeValidationParams modeValidation = Initialize();
|
|
*
|
|
* retry:
|
|
* NvU32 modeIndex = 0;
|
|
*
|
|
* while (1) {
|
|
* char infoString[INFO_STRING_LENGTH];
|
|
* memset(¶ms);
|
|
* params.request.dpyId = dpyId;
|
|
* params.request.modeIndex = modeIndex++;
|
|
* params.request.modeValidation = modeValidation;
|
|
* params.request.pInfoString = nvKmsPointerToNvU64(infoString);
|
|
* params.request.infoStringLength = sizeof(infoString);
|
|
*
|
|
* ioctl(¶ms);
|
|
*
|
|
* if (params.reply.end) break;
|
|
*
|
|
* print(infoString);
|
|
*
|
|
* if (params.reply.valid) {
|
|
* AddToModePool(params.reply.mode);
|
|
* }
|
|
* }
|
|
*
|
|
* if (dpyChanged) goto retry;
|
|
*
|
|
*/
|
|
|
|
struct NvKmsValidateModeIndexRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
struct NvKmsModeValidationParams modeValidation;
|
|
NvU32 modeIndex;
|
|
|
|
/*
|
|
* Pointer to a string of size 'infoStringSize'.
|
|
* Use nvKmsPointerToNvU64() to assign pInfoString.
|
|
* The maximum size allowed is
|
|
* NVKMS_MODE_VALIDATION_MAX_INFO_STRING_LENGTH.
|
|
*/
|
|
NvU32 infoStringSize;
|
|
NvU64 pInfoString NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsValidateModeIndexReply {
|
|
NvBool end;
|
|
NvBool valid;
|
|
|
|
struct NvKmsMode mode;
|
|
|
|
/*! The validSyncs used by NVKMS when validating the mode. */
|
|
struct NvKmsModeValidationValidSyncs validSyncs;
|
|
|
|
/*! Whether this mode is marked as "preferred" by the EDID. */
|
|
NvBool preferredMode;
|
|
|
|
/*! A text description of the mode. */
|
|
char description[64];
|
|
|
|
/*! Where the mode came from. */
|
|
enum NvKmsModeSource {
|
|
NvKmsModeSourceUnknown = 0,
|
|
NvKmsModeSourceEdid = 1,
|
|
NvKmsModeSourceVesa = 2,
|
|
} source;
|
|
|
|
/* The number of bytes written to 'pInfoString' (from the request) */
|
|
NvU32 infoStringLenWritten;
|
|
|
|
/*!
|
|
* These are the usage bounds that may be possible with this mode,
|
|
* assuming that only one head is active. For actual usage bounds,
|
|
* see guaranteedUsage and possibleUsage returned in
|
|
* NvKmsSetModeOneHeadReply.
|
|
*/
|
|
struct NvKmsUsageBounds modeUsage;
|
|
};
|
|
|
|
struct NvKmsValidateModeIndexParams {
|
|
struct NvKmsValidateModeIndexRequest request; /*! in */
|
|
struct NvKmsValidateModeIndexReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_VALIDATE_MODE: Validate an individual mode for the
|
|
* specified dpy.
|
|
*
|
|
* Given the validation parameters, NVKMS will test whether the given
|
|
* mode is currently valid for the specified dpy.
|
|
*
|
|
* If the mode is valid, then reply::valid will be TRUE. Otherwise,
|
|
* reply::valid will be FALSE. In either case, reply::infoString[]
|
|
* will contain a description of what happened during mode validation.
|
|
*/
|
|
|
|
struct NvKmsValidateModeRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
struct NvKmsModeValidationParams modeValidation;
|
|
struct NvKmsMode mode;
|
|
|
|
/*
|
|
* Pointer to a string of size 'infoStringSize'.
|
|
* Use nvKmsPointerToNvU64() to assign pInfoString.
|
|
* The maximum size allowed is
|
|
* NVKMS_MODE_VALIDATION_MAX_INFO_STRING_LENGTH.
|
|
*/
|
|
NvU32 infoStringSize;
|
|
NvU64 pInfoString NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsValidateModeReply {
|
|
NvBool valid;
|
|
|
|
/*! The validSyncs used by NVKMS when validating the mode. */
|
|
struct NvKmsModeValidationValidSyncs validSyncs;
|
|
|
|
/* The number of bytes written to 'pInfoString' (from the request) */
|
|
NvU32 infoStringLenWritten;
|
|
|
|
/*!
|
|
* These are the usage bounds that may be possible with this mode,
|
|
* assuming that only one head is active. For actual usage bounds,
|
|
* see guaranteedUsage and possibleUsage returned in
|
|
* NvKmsSetModeOneHeadReply.
|
|
*/
|
|
struct NvKmsUsageBounds modeUsage;
|
|
};
|
|
|
|
struct NvKmsValidateModeParams {
|
|
struct NvKmsValidateModeRequest request; /*! in */
|
|
struct NvKmsValidateModeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_MODE: Perform a modeset.
|
|
*
|
|
* NvKmsSetModeRequest can describe the modetiming configuration
|
|
* across all heads of all disps within the SLI device.
|
|
*
|
|
* The elements in NvKmsSetModeRequest::disp[] correspond to the disps
|
|
* returned in NvKmsAllocDeviceReply::dispHandles[].
|
|
*
|
|
* To only touch certain heads and disps, use the
|
|
* requestedHeadsBitMask and requestedDispsBitMask fields to limit
|
|
* which array elements are honored.
|
|
*
|
|
* If the request is invalid, one or more of the
|
|
* NvKmsSetMode{,OneDisp,OneHead}Reply::status fields will have a
|
|
* non-SUCCESS value. If the mode set completed successfully, then
|
|
* all {NvKmsSetMode{,OneDisp,OneHead}Reply::status fields should be
|
|
* SUCCESS.
|
|
*/
|
|
|
|
struct NvKmsSetModeHeadSurfaceParams {
|
|
NvBool forceCompositionPipeline;
|
|
NvBool forceFullCompositionPipeline;
|
|
NvBool fakeOverlay;
|
|
NvBool blendAfterWarp;
|
|
NvBool transformSpecified;
|
|
|
|
/* Reflect the image along the X axis. */
|
|
NvBool reflectionX;
|
|
|
|
/* Reflect the image along the Y axis. */
|
|
NvBool reflectionY;
|
|
|
|
/*
|
|
* Rotate the image counter-clockwise in 90 degree increments.
|
|
*
|
|
* Reflection (specified above by ::reflection[XY]) is applied
|
|
* before rotation. This matches the semantics of RandR. From:
|
|
*
|
|
* https://cgit.freedesktop.org/xorg/proto/randrproto/tree/randrproto.txt
|
|
*
|
|
* "Rotation and reflection and how they interact can be confusing. In
|
|
* Randr, the coordinate system is rotated in a counter-clockwise direction
|
|
* relative to the normal orientation. Reflection is along the window system
|
|
* coordinate system, not the physical screen X and Y axis, so that rotation
|
|
* and reflection do not interact. The other way to consider reflection is
|
|
* to is specified in the 'normal' orientation, before rotation, if you find
|
|
* the other way confusing."
|
|
*/
|
|
enum NvKmsRotation rotation;
|
|
enum NvKmsPixelShiftMode pixelShift;
|
|
enum NvKmsResamplingMethod resamplingMethod;
|
|
struct NvKmsMatrix transform; /* Only honored if transformSpecified. */
|
|
|
|
NvKmsSurfaceHandle blendTexSurfaceHandle;
|
|
NvKmsSurfaceHandle offsetTexSurfaceHandle;
|
|
|
|
/*
|
|
* When warpMesh::surfaceHandle is non-zero, it indicates a surface
|
|
* containing warp mesh vertex data. The surface should:
|
|
*
|
|
* - Have a width multiple of 1024 pixels.
|
|
* - Have a depth of 32.
|
|
* - Contain a binary representation of a list of six-component
|
|
* vertices. Each of these components is a 32-bit floating point value.
|
|
*
|
|
* The X, Y components should contain normalized vertex coordinates, to be
|
|
* rendered as a triangle list or strip. The X and Y components' [0,1]
|
|
* range map to the head's ViewportOut X and Y, respectively.
|
|
*
|
|
* The U, V, R, and Q components should contain normalized, projective
|
|
* texture coordinates:
|
|
*
|
|
* U, V: 2D texture coordinate. U and V components' [0,1] range maps to the
|
|
* display's MetaMode ViewportIn X and Y, respectively.
|
|
*
|
|
* R: unused
|
|
*
|
|
* Q: Used for interpolation purposes. This is typically the third
|
|
* component of the result of a multiplication by a 3x3 projective transform
|
|
* matrix.
|
|
*
|
|
* warpMesh::vertexCount should contain the amount of vertices stored in the
|
|
* surface.
|
|
*
|
|
* warpMesh::dataType indicates if the vertices describe a triangle list or
|
|
* a triangle strip. A triangle list must have a vertexCount that is a
|
|
* multiple of 3.
|
|
*/
|
|
struct {
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
NvU32 vertexCount;
|
|
enum NvKmsWarpMeshDataType dataType;
|
|
} warpMesh;
|
|
};
|
|
|
|
#define NVKMS_VRR_MIN_REFRESH_RATE_MAX_VARIANCE 10 // 10hz
|
|
|
|
enum NvKmsAllowAdaptiveSync {
|
|
NVKMS_ALLOW_ADAPTIVE_SYNC_DISABLED = 0,
|
|
NVKMS_ALLOW_ADAPTIVE_SYNC_DEFAULTLISTED_ONLY,
|
|
NVKMS_ALLOW_ADAPTIVE_SYNC_ALL,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_REQUESTED_COLOR_SPACE attribute. */
|
|
enum NvKmsDpyAttributeRequestedColorSpaceValue {
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_COLOR_SPACE_RGB = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_COLOR_SPACE_YCbCr422 = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_COLOR_SPACE_YCbCr444 = 2,
|
|
};
|
|
|
|
/*!
|
|
* Values for the NV_KMS_DPY_ATTRIBUTE_REQUESTED_COLOR_RANGE and
|
|
* NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_RANGE attributes.
|
|
*/
|
|
enum NvKmsDpyAttributeColorRangeValue {
|
|
NV_KMS_DPY_ATTRIBUTE_COLOR_RANGE_FULL = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_COLOR_RANGE_LIMITED = 1,
|
|
};
|
|
|
|
struct NvKmsSetModeOneHeadRequest {
|
|
/*!
|
|
* The list of dpys to drive with this head; or, empty to disable
|
|
* the head.
|
|
*/
|
|
NVDpyIdList dpyIdList;
|
|
|
|
/*! The modetimings to set on the head. */
|
|
struct NvKmsMode mode;
|
|
|
|
/*! The above mode will be validated, using these validation parameters. */
|
|
struct NvKmsModeValidationParams modeValidationParams;
|
|
|
|
/*!
|
|
* The region within the raster timings that should contain an image.
|
|
* This is only used when viewPortOutSpecified is TRUE. Otherwise, the
|
|
* viewPortOut is inferred from the raster timings.
|
|
*
|
|
* For YUV420 modes, the viewPortOut should be in "full"
|
|
* horizontal space. See the explanation in NvKmsMode.
|
|
*/
|
|
struct NvKmsRect viewPortOut;
|
|
|
|
/*!
|
|
* The size, in pixels, that the head will fetch from any surface
|
|
* it scans from. The viewPortPointIn is specified in
|
|
* NvKmsFlipCommonParams.
|
|
*
|
|
* For YUV420 modes, the viewPortSizeIn should be in "half"
|
|
* horizontal space. See the explanation in NvKmsMode.
|
|
*/
|
|
struct NvKmsSize viewPortSizeIn;
|
|
|
|
/*!
|
|
* Describe the LUT to be used with the modeset.
|
|
*/
|
|
struct NvKmsSetLutCommonParams lut;
|
|
|
|
/*!
|
|
* Describe the surfaces to present on this head.
|
|
*/
|
|
struct NvKmsFlipCommonParams flip;
|
|
|
|
/*!
|
|
* The headSurface configuration requested, if any.
|
|
*/
|
|
struct NvKmsSetModeHeadSurfaceParams headSurface;
|
|
|
|
NvBool viewPortOutSpecified; /*! Whether to use viewPortOut. */
|
|
|
|
/*!
|
|
* Allow this head to be flipLocked to any other heads, set as
|
|
* part of this NVKMS_IOCTL_SET_MODE, who also have allowFlipLock
|
|
* set. FlipLock will only be enabled if additional criteria,
|
|
* such as identical modetimings, are also met.
|
|
*/
|
|
NvBool allowFlipLock;
|
|
|
|
/*!
|
|
* Allow G-SYNC to be enabled on this head if it is supported by the GPU
|
|
* and monitor.
|
|
*/
|
|
NvBool allowGsync;
|
|
|
|
/*!
|
|
* Whether to allow Adaptive-Sync to be enabled on this head if it is
|
|
* supported by the GPU:
|
|
*
|
|
* NVKMS_ALLOW_ADAPTIVE_SYNC_ALL:
|
|
* VRR is enabled as long as this monitor supports Adaptive-Sync.
|
|
*
|
|
* NVKMS_ALLOW_ADAPTIVE_SYNC_DEFAULTLISTED_ONLY:
|
|
* VRR is only enabled on this head if the monitor is on the
|
|
* Adaptive-Sync defaultlist.
|
|
*
|
|
* NVKMS_ALLOW_ADAPTIVE_SYNC_DISABLED:
|
|
* VRR is forced to be disabled if this is an Adaptive-Sync monitor.
|
|
*/
|
|
enum NvKmsAllowAdaptiveSync allowAdaptiveSync;
|
|
|
|
/*!
|
|
* Override the minimum refresh rate for VRR monitors specified by the
|
|
* EDID (0 to not override the EDID-provided value). Clamped at modeset
|
|
* time to within NVKMS_VRR_MIN_REFRESH_RATE_MAX_VARIANCE of the
|
|
* EDID-specified minimum refresh rate, as long as the minimum is no
|
|
* lower than 1hz and the maximum does not exceed the maximum refresh rate
|
|
* defined by the mode timings. The current minimum refresh rate and this
|
|
* valid range are exposed through
|
|
* NV_KMS_DPY_ATTRIBUTE_VRR_MIN_REFRESH_RATE.
|
|
*
|
|
* Does not affect G-SYNC monitors, which do not have a minimum refresh
|
|
* rate.
|
|
*/
|
|
NvU32 vrrOverrideMinRefreshRate;
|
|
|
|
/*!
|
|
* Output colorspace. Valid only when colorSpaceSpecified is true.
|
|
*/
|
|
enum NvKmsDpyAttributeRequestedColorSpaceValue colorSpace;
|
|
NvBool colorSpaceSpecified;
|
|
|
|
/*!
|
|
* Output color range. Valid only when colorRangeSpecified is true.
|
|
*/
|
|
enum NvKmsDpyAttributeColorRangeValue colorRange;
|
|
NvBool colorRangeSpecified;
|
|
};
|
|
|
|
struct NvKmsSetModeOneDispRequest {
|
|
/*!
|
|
* The bit mask of which head[] elements to look at on this disp;
|
|
* any other head will use its existing configuration.
|
|
*/
|
|
NvU32 requestedHeadsBitMask;
|
|
struct NvKmsSetModeOneHeadRequest head[NVKMS_MAX_HEADS_PER_DISP];
|
|
};
|
|
|
|
struct NvKmsSetModeRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
|
|
/*!
|
|
* When a modeset request is made, NVKMS will first perform
|
|
* validation to confirm whether the request can be satisfied. If
|
|
* the requested configuration cannot be fulfilled, the request
|
|
* returns FALSE.
|
|
*
|
|
* Only the modeset owner can issue a modeset with commit set to TRUE.
|
|
*
|
|
* If 'commit' is FALSE, then the status of validation will be returned.
|
|
*
|
|
* If 'commit' is TRUE, and validation passes, then NVKMS will
|
|
* apply the requested configuration.
|
|
*/
|
|
NvBool commit;
|
|
|
|
/*!
|
|
* The bitmask of which indices within disp[] describe requested
|
|
* configuration changes. Any other disps will use their existing
|
|
* configuration.
|
|
*/
|
|
NvU32 requestedDispsBitMask;
|
|
|
|
/*
|
|
* disp[n] corresponds to the disp named by
|
|
* NvKmsAllocDeviceReply::dispHandles[n].
|
|
*/
|
|
struct NvKmsSetModeOneDispRequest disp[NVKMS_MAX_SUBDEVICES];
|
|
|
|
/*!
|
|
* Whether to use NVKMS's builtin headSurface support when necessary.
|
|
*
|
|
* XXX NVKMS HEADSURFACE TODO: Make this the default and remove this field.
|
|
*/
|
|
NvBool allowHeadSurfaceInNvKms;
|
|
};
|
|
|
|
enum NvKmsSetModeOneHeadStatus {
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_SUCCESS = 0,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_MODE = 1,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_DPY = 2,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_CURSOR_IMAGE = 3,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_CURSOR_POSITION = 4,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_LUT = 5,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_FLIP = 6,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_PERMISSIONS = 7,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_INVALID_HEAD_SURFACE = 8,
|
|
NVKMS_SET_MODE_ONE_HEAD_STATUS_UNSUPPORTED_HEAD_SURFACE_COMBO = 9,
|
|
};
|
|
|
|
struct NvKmsSetModeOneHeadReply {
|
|
/*!
|
|
* When the NVKMS_IOCTL_SET_MODE succeeds, then this will be SUCCESS.
|
|
* Otherwise, 'status' will be a non-SUCCESS value for one or more
|
|
* heads and/or one or more disps.
|
|
*
|
|
* Note that a failure could occur for a preexisting head
|
|
* configuration, so this status could be != SUCCESS for a head
|
|
* not listed in NvKmsSetModeOneDispRequest::requestedHeadsBitMask.
|
|
*/
|
|
enum NvKmsSetModeOneHeadStatus status;
|
|
|
|
NvU32 hwHead;
|
|
|
|
/*!
|
|
* The usage bounds that may be possible on this head based on the ISO
|
|
* BW at that point.
|
|
*
|
|
* If a flip request is within the bounds of NvKmsSetModeOneHeadReply::
|
|
* guaranteedUsage, then clients can expect the flip to succeed.
|
|
* If a flip request is beyond the bounds of NvKmsSetModeOneHeadReply::
|
|
* guaranteedUsage but within NvKmsSetModeOneHeadReply::possibleUsage,
|
|
* then the request may legitimately fail due to insufficient display
|
|
* bandwidth and clients need to be prepared to handle that flip
|
|
* request failure.
|
|
*/
|
|
struct NvKmsUsageBounds possibleUsage;
|
|
|
|
/*!
|
|
* The guaranteed usage bounds usable on this head.
|
|
*/
|
|
struct NvKmsUsageBounds guaranteedUsage;
|
|
|
|
/*!
|
|
* Whether NVKMS chose to use headSurface on this head.
|
|
*/
|
|
NvBool usingHeadSurface;
|
|
|
|
/*!
|
|
* Whether NVKMS enabled VRR on this head.
|
|
*/
|
|
NvBool vrrEnabled;
|
|
|
|
/*!
|
|
* Contains the 'postSyncObject' that the client requested via
|
|
* NvKmsSetModeOneHeadRequest::flip.
|
|
*/
|
|
struct NvKmsFlipCommonReplyOneHead flipReply;
|
|
};
|
|
|
|
enum NvKmsSetModeOneDispStatus {
|
|
NVKMS_SET_MODE_ONE_DISP_STATUS_SUCCESS = 0,
|
|
NVKMS_SET_MODE_ONE_DISP_STATUS_INVALID_REQUESTED_HEADS_BITMASK = 1,
|
|
NVKMS_SET_MODE_ONE_DISP_STATUS_FAILED_EXTENDED_GPU_CAPABILITIES_CHECK = 2,
|
|
NVKMS_SET_MODE_ONE_DISP_STATUS_FAILED_DISPLAY_PORT_BANDWIDTH_CHECK = 3,
|
|
NVKMS_SET_MODE_ONE_DISP_STATUS_INCOMPATIBLE_DPYS = 4,
|
|
NVKMS_SET_MODE_ONE_DISP_STATUS_DUPLICATE_DPYS = 5,
|
|
NVKMS_SET_MODE_ONE_DISP_STATUS_FAILED_TO_ASSIGN_HARDWARE_HEADS = 6,
|
|
};
|
|
|
|
struct NvKmsSetModeOneDispReply {
|
|
/*!
|
|
* When the NVKMS_IOCTL_SET_MODE succeeds, then this will be SUCCESS.
|
|
* Otherwise, 'status' will be a non-SUCCESS value for one or more
|
|
* heads and/or one or more disps.
|
|
*
|
|
* Note that a failure could occur for a preexisting disp
|
|
* configuration, so this status could be != SUCCESS for a disp
|
|
* not listed in NvKmsSetModeRequest::requestedDispsBitMask.
|
|
*/
|
|
enum NvKmsSetModeOneDispStatus status;
|
|
struct NvKmsSetModeOneHeadReply head[NVKMS_MAX_HEADS_PER_DISP];
|
|
};
|
|
|
|
enum NvKmsSetModeStatus {
|
|
NVKMS_SET_MODE_STATUS_SUCCESS = 0,
|
|
NVKMS_SET_MODE_STATUS_INVALID_REQUESTED_DISPS_BITMASK = 1,
|
|
NVKMS_SET_MODE_STATUS_NOT_MODESET_OWNER = 2,
|
|
};
|
|
|
|
struct NvKmsSetModeReply {
|
|
enum NvKmsSetModeStatus status;
|
|
struct NvKmsSetModeOneDispReply disp[NVKMS_MAX_SUBDEVICES];
|
|
};
|
|
|
|
struct NvKmsSetModeParams {
|
|
struct NvKmsSetModeRequest request; /*! in */
|
|
struct NvKmsSetModeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_CURSOR_IMAGE: Set the cursor image for the
|
|
* specified head.
|
|
*/
|
|
|
|
struct NvKmsSetCursorImageRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
|
|
struct NvKmsSetCursorImageCommonParams common;
|
|
};
|
|
|
|
struct NvKmsSetCursorImageReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSetCursorImageParams {
|
|
struct NvKmsSetCursorImageRequest request; /*! in */
|
|
struct NvKmsSetCursorImageReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_MOVE_CURSOR: Set the cursor position for the specified
|
|
* head.
|
|
*
|
|
* x,y are relative to the current viewPortIn configured on the head.
|
|
*/
|
|
|
|
struct NvKmsMoveCursorRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
|
|
struct NvKmsMoveCursorCommonParams common;
|
|
};
|
|
|
|
struct NvKmsMoveCursorReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsMoveCursorParams {
|
|
struct NvKmsMoveCursorRequest request; /*! in */
|
|
struct NvKmsMoveCursorReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_LUT: Set the LUT contents for the specified head.
|
|
*/
|
|
|
|
struct NvKmsSetLutRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
|
|
struct NvKmsSetLutCommonParams common;
|
|
};
|
|
|
|
struct NvKmsSetLutReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSetLutParams {
|
|
struct NvKmsSetLutRequest request; /*! in */
|
|
struct NvKmsSetLutReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_IDLE_BASE_CHANNEL: Wait for the base channel to be idle on
|
|
* the requested heads on the requested subdevices of a device.
|
|
*
|
|
* Each (head,sd) pair to be idled is described by:
|
|
*
|
|
* subDevicesPerHead[head] |= NVBIT(sd)
|
|
*/
|
|
|
|
struct NvKmsIdleBaseChannelRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvU32 subDevicesPerHead[NVKMS_MAX_HEADS_PER_DISP];
|
|
};
|
|
|
|
struct NvKmsIdleBaseChannelReply {
|
|
/*!
|
|
* If stopping the base channel is necessary due to a timeout, (head,sd)
|
|
* pairs will be described with:
|
|
*
|
|
* stopSubDevicesPerHead[head] |= NVBIT(sd)
|
|
*
|
|
* indicating that semaphore releases from the stalled channels may not have
|
|
* occurred.
|
|
*/
|
|
NvU32 stopSubDevicesPerHead[NVKMS_MAX_HEADS_PER_DISP];
|
|
};
|
|
|
|
struct NvKmsIdleBaseChannelParams {
|
|
struct NvKmsIdleBaseChannelRequest request; /*! in */
|
|
struct NvKmsIdleBaseChannelReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_FLIP: Flip one or more heads on the subdevices of a device.
|
|
*
|
|
* At least one head must be specified in a flip request, and at most
|
|
* NV_MAX_FLIP_REQUEST_HEADS may be specified.
|
|
*/
|
|
|
|
struct NvKmsFlipRequestOneHead {
|
|
NvU32 sd;
|
|
NvU32 head;
|
|
struct NvKmsFlipCommonParams flip;
|
|
};
|
|
|
|
#define NV_MAX_FLIP_REQUEST_HEADS (NV_MAX_SUBDEVICES * NV_MAX_HEADS)
|
|
|
|
struct NvKmsFlipRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
|
|
/* Pointer to an array of length 'numFlipHeads'; each entry in the array is
|
|
* of type 'struct NvKmsFlipRequestOneHead'. */
|
|
NvU64 pFlipHead NV_ALIGN_BYTES(8);
|
|
NvU32 numFlipHeads;
|
|
|
|
/*!
|
|
* When a flip request is made, NVKMS will first perform
|
|
* validation to confirm whether the request can be satisfied. If
|
|
* the requested configuration cannot be fulfilled, the request
|
|
* returns FALSE.
|
|
*
|
|
* If 'commit' is FALSE, then the status of validation will be returned.
|
|
*
|
|
* If 'commit' is TRUE, and validation passes, then NVKMS will
|
|
* apply the requested configuration.
|
|
*/
|
|
NvBool commit;
|
|
|
|
/*!
|
|
* When set, indicates that the client is capable of releasing the VRR
|
|
* semaphore to indicate when the flip is ready. Setting this to FALSE
|
|
* disables VRR.
|
|
*/
|
|
NvBool allowVrr;
|
|
};
|
|
|
|
enum NvKmsVrrFlipType {
|
|
NV_KMS_VRR_FLIP_NON_VRR = 0,
|
|
NV_KMS_VRR_FLIP_GSYNC,
|
|
NV_KMS_VRR_FLIP_ADAPTIVE_SYNC,
|
|
};
|
|
|
|
struct NvKmsFlipReply {
|
|
/*!
|
|
* If vrrFlipType != NV_KMS_VRR_FLIP_NON_VRR, then VRR was used for the
|
|
* requested flip. In this case, vrrSemaphoreIndex indicates the index
|
|
* into the VRR semaphore surface that the client should release to
|
|
* trigger the flip.
|
|
*
|
|
* A value of -1 indicates that no VRR semaphore release is needed.
|
|
*/
|
|
NvS32 vrrSemaphoreIndex;
|
|
|
|
/*!
|
|
* Indicates whether the flip was non-VRR, was a VRR flip on one or more
|
|
* G-SYNC displays, or was a VRR flip exclusively on Adaptive-Sync
|
|
* displays.
|
|
*/
|
|
enum NvKmsVrrFlipType vrrFlipType;
|
|
|
|
/*!
|
|
* Entries correspond to the heads specified in
|
|
* NvKmsFlipRequest::pFlipHead, in the same order.
|
|
*/
|
|
struct NvKmsFlipCommonReplyOneHead flipHead[NV_MAX_FLIP_REQUEST_HEADS];
|
|
};
|
|
|
|
struct NvKmsFlipParams {
|
|
struct NvKmsFlipRequest request; /*! in */
|
|
struct NvKmsFlipReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_DECLARE_DYNAMIC_DPY_INTEREST: "Dynamic dpy" reference
|
|
* counting.
|
|
*
|
|
* Most dpys have a lifetime equal to the NVKMS device. However, some
|
|
* dpys are dynamic and are created and destroyed in response to
|
|
* getting connected or disconnected. DisplayPort MST dpys are dynamic dpys.
|
|
*
|
|
* When a dynamic dpy is disconnected, its NVDpyId will be freed and
|
|
* made available for use by dynamic dpys connected later, unless any
|
|
* client has declared "interest" in the NVDpyId. The dynamic NVDpyId
|
|
* will persist as long as a client has declared interest on it, and
|
|
* will be reused for newly connected monitors at the same dynamic dpy
|
|
* address (port address, in the case of DP MST dynamic dpys).
|
|
*
|
|
* The 'interest' field selects interest in the dynamic dpy.
|
|
*
|
|
* If the dynamic dpy has already been disconnected (and therefore
|
|
* removed) before the client has declared interest in it, this ioctl
|
|
* will fail.
|
|
*
|
|
* The recommended usage pattern is:
|
|
*
|
|
* - Declare interest in the event types:
|
|
* NVKMS_EVENT_TYPE_DYNAMIC_DPY_CONNECTED
|
|
* NVKMS_EVENT_TYPE_DYNAMIC_DPY_DISCONNECTED
|
|
*
|
|
* - When a DYNAMIC_DPY_CONNECTED event is received, call
|
|
* NVKMS_IOCTL_DECLARE_DYNAMIC_DPY_INTEREST
|
|
* to declare interest on the dpy. Be sure to check the return
|
|
* value, in case the dynamic dpy was already removed. Update any
|
|
* client bookkeeping, to start tracking the dpy.
|
|
*
|
|
* - When a DYNAMIC_DPY_DISCONNECTED event is received, update any
|
|
* client bookkeeping, to stop tracking this dynamic dpy. Call
|
|
* NVKMS_IOCTL_DECLARE_DYNAMIC_DPY_INTEREST
|
|
* to remove interest on the dpy.
|
|
*/
|
|
|
|
struct NvKmsDeclareDynamicDpyInterestRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
NvBool interest;
|
|
};
|
|
|
|
struct NvKmsDeclareDynamicDpyInterestReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsDeclareDynamicDpyInterestParams {
|
|
struct NvKmsDeclareDynamicDpyInterestRequest request; /*! in */
|
|
struct NvKmsDeclareDynamicDpyInterestReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_{,UN}REGISTER_SURFACE: Register and unregister an
|
|
* RM-allocated surface with NVKMS.
|
|
*
|
|
* A surface must be registered with NVKMS before NVKMS can display
|
|
* it. Note that NVKMS will create its own RM object for the registered
|
|
* surface. The surface will not be freed by resman until the surface
|
|
* is unregistered by the client.
|
|
*/
|
|
|
|
struct NvKmsRegisterSurfaceRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
|
|
/*!
|
|
* Surfaces can be specified either by file descriptor or by
|
|
* (rmClient, rmObject) tuple. useFd indicates which is specified
|
|
* in this request. Userspace clients are required to specify surface by
|
|
* file descriptor.
|
|
*/
|
|
NvBool useFd;
|
|
|
|
/*!
|
|
* The RM client handle that was used to allocate the surface.
|
|
* NVKMS will use this as the hClientSrc argument to
|
|
* NvRmDupObject(). Only used when useFd is FALSE.
|
|
*/
|
|
NvU32 rmClient;
|
|
|
|
/*
|
|
* For multi-plane formats, clients are free to use one memory allocation
|
|
* for all planes, or a separate memory allocation per plane:
|
|
* - For the first usecase, 'rmObject'/'fd' and 'rmObjectSizeInBytes'
|
|
* should be the same for all planes, and each plane should have a
|
|
* different 'offset'.
|
|
* - For the second usecase, 'rmObject'/'fd' should be different for each
|
|
* plane.
|
|
*
|
|
* The 'planes' array is indexed as follows:
|
|
* - For RGB and YUV packed formats, 'planes[0]' refers to the single plane
|
|
* that's used for these formats.
|
|
* - For YUV semi-planar formats, 'planes[0]' refers to the Y-plane and
|
|
* 'planes[1]' refers to the UV-plane.
|
|
* - For YUV planar formats, 'planes[0]' refers to the Y-plane, 'planes[1]'
|
|
* refers to the U plane, and 'planes[2]' refers to the V plane.
|
|
*/
|
|
struct {
|
|
|
|
union {
|
|
NvU32 rmObject; /* RM memory handle */
|
|
NvS32 fd; /* file descriptor describing memory */
|
|
} u;
|
|
|
|
/*
|
|
* This byte offset will be added to the base address of the RM memory
|
|
* allocation, and determines the starting address of this plane within
|
|
* that allocation. This offset must be 1KB-aligned.
|
|
*/
|
|
NvU64 offset NV_ALIGN_BYTES(8);
|
|
|
|
/*
|
|
* If the surface layout is NvKmsSurfaceMemoryLayoutPitch, then
|
|
* 'pitch' should be the pitch of this plane in bytes, and must
|
|
* have an alignment of 256 bytes. If the surface layout is
|
|
* NvKmsSurfaceMemoryLayoutBlockLinear, then 'pitch' should be the
|
|
* pitch of this plane in _blocks_. Blocks are always 64 bytes
|
|
* wide.
|
|
*/
|
|
NvU32 pitch;
|
|
|
|
/*
|
|
* This is the size of the entire RM memory allocation pointed to by
|
|
* rmObject or fd prior to taking the offset into account. This is
|
|
* _not_ always the size of this plane since a single RM memory
|
|
* allocation can contain multiple planes, and we're also not taking
|
|
* the offset into account.
|
|
*/
|
|
NvU64 rmObjectSizeInBytes NV_ALIGN_BYTES(8);
|
|
} planes[NVKMS_MAX_PLANES_PER_SURFACE];
|
|
|
|
NvU32 widthInPixels;
|
|
NvU32 heightInPixels;
|
|
|
|
enum NvKmsSurfaceMemoryLayout layout;
|
|
enum NvKmsSurfaceMemoryFormat format;
|
|
|
|
NvBool noDisplayHardwareAccess;
|
|
|
|
/*
|
|
* This flag should be set if the surface can potentially be updated
|
|
* directly on the screen after the flip. For example, this is the case
|
|
* if the surface is CPU mapped, accessible by more than one GPU, or in
|
|
* a similar situation. If this flag is set NVKMS knows not to consider
|
|
* the surface content cacheable between flips.
|
|
*/
|
|
NvBool noDisplayCaching;
|
|
|
|
/*
|
|
* If isoType == NVKMS_MEMORY_NISO, NVKMS will create CPU and GPU mappings
|
|
* for the surface memory.
|
|
*/
|
|
NvKmsMemoryIsoType isoType;
|
|
|
|
NvU32 log2GobsPerBlockY;
|
|
};
|
|
|
|
struct NvKmsRegisterSurfaceReply {
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
};
|
|
|
|
struct NvKmsRegisterSurfaceParams {
|
|
struct NvKmsRegisterSurfaceRequest request; /*! in */
|
|
struct NvKmsRegisterSurfaceReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsUnregisterSurfaceRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
};
|
|
|
|
struct NvKmsUnregisterSurfaceReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsUnregisterSurfaceParams {
|
|
struct NvKmsUnregisterSurfaceRequest request; /*! in */
|
|
struct NvKmsUnregisterSurfaceReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_GRANT_SURFACE:
|
|
* NVKMS_IOCTL_ACQUIRE_SURFACE:
|
|
* NVKMS_IOCTL_RELEASE_SURFACE:
|
|
*
|
|
* An NVKMS client can "grant" a registered surface to another NVKMS
|
|
* client through the following steps:
|
|
*
|
|
* - The granting NVKMS client should open /dev/nvidia-modeset, and
|
|
* call NVKMS_IOCTL_GRANT_SURFACE to associate an NvKmsSurfaceHandle
|
|
* with the file descriptor.
|
|
*
|
|
* - The granting NVKMS client should pass the file descriptor over a
|
|
* UNIX domain socket to one or more clients who should acquire the
|
|
* surface.
|
|
*
|
|
* - The granting NVKMS client can optionally close the file
|
|
* descriptor now or later.
|
|
*
|
|
* - Each acquiring client should call NVKMS_IOCTL_ACQUIRE_SURFACE,
|
|
* and pass in the file descriptor it received. This returns an
|
|
* NvKmsSurfaceHandle that the acquiring client can use to refer to
|
|
* the surface in any other NVKMS API call that takes an
|
|
* NvKmsSurfaceHandle.
|
|
*
|
|
* - The acquiring clients can optionally close the file descriptor
|
|
* now or later.
|
|
*
|
|
* - Each acquiring client should call NVKMS_IOCTL_RELEASE_SURFACE to
|
|
* release it when they are done with the surface.
|
|
*
|
|
* - When the granting client unregisters the surface, it is
|
|
* "orphaned": NVKMS will flip away from the surface if necessary,
|
|
* the RM surface allocation is unduped, and the surface is
|
|
* unregistered from EVO. But, the acquiring clients will continue
|
|
* to hold a reference to this orphaned surface until they release
|
|
* it.
|
|
*
|
|
* Notes:
|
|
*
|
|
* - It is an error to call NVKMS_IOCTL_GRANT_SURFACE more than once
|
|
* on a /dev/nvidia-modeset file descriptor, or to use a file
|
|
* descriptor other than one created by opening /dev/nvidia-modeset,
|
|
* or to use a file descriptor that was previously used as the first
|
|
* argument to ioctl(2).
|
|
*
|
|
* - The special handling of surfaces when the granting client
|
|
* unregisters the surface might be a little asymmetric. However,
|
|
* this strikes a balance between:
|
|
*
|
|
* (a) Making sure modesetting NVKMS clients can free memory when
|
|
* they intend to.
|
|
*
|
|
* (b) Making sure acquiring clients don't get a stale view of their
|
|
* surface handle namespace: if the surface were completely
|
|
* unregistered out from under them, the surface handle could be
|
|
* recycled without them knowing. If they later attempted to
|
|
* release the original surface, they could inadvertently release a
|
|
* different surface that happened to have the recycled handle.
|
|
*
|
|
* - Do we need an NVKMS_IOCTL_REVOKE_SURFACE? Or is the
|
|
* automatic-unregistration-in-acquiring-clients behavior
|
|
* sufficient?
|
|
*/
|
|
|
|
struct NvKmsGrantSurfaceRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
int fd;
|
|
};
|
|
|
|
struct NvKmsGrantSurfaceReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsGrantSurfaceParams {
|
|
struct NvKmsGrantSurfaceRequest request; /*! in */
|
|
struct NvKmsGrantSurfaceReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsAcquireSurfaceRequest {
|
|
int fd;
|
|
};
|
|
|
|
struct NvKmsAcquireSurfaceReply {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
};
|
|
|
|
struct NvKmsAcquireSurfaceParams {
|
|
struct NvKmsAcquireSurfaceRequest request; /*! in */
|
|
struct NvKmsAcquireSurfaceReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsReleaseSurfaceRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
};
|
|
|
|
struct NvKmsReleaseSurfaceReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsReleaseSurfaceParams {
|
|
struct NvKmsReleaseSurfaceRequest request; /*! in */
|
|
struct NvKmsReleaseSurfaceReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_DPY_ATTRIBUTE:
|
|
* NVKMS_IOCTL_GET_DPY_ATTRIBUTE:
|
|
* NVKMS_IOCTL_GET_DPY_ATTRIBUTE_VALID_VALUES:
|
|
*
|
|
* Dpys have several attributes that can be queried and set.
|
|
*
|
|
* An attribute has a type (defined by NvKmsAttributeType), read/write
|
|
* permissions, and potentially other descriptions of its valid
|
|
* values. Use NVKMS_IOCTL_GET_DPY_ATTRIBUTE_VALID_VALUES to get the
|
|
* valid values of an attribute.
|
|
*/
|
|
|
|
enum NvKmsAttributeType {
|
|
NV_KMS_ATTRIBUTE_TYPE_INTEGER = 0,
|
|
NV_KMS_ATTRIBUTE_TYPE_BOOLEAN,
|
|
NV_KMS_ATTRIBUTE_TYPE_INTBITS,
|
|
NV_KMS_ATTRIBUTE_TYPE_RANGE,
|
|
NV_KMS_ATTRIBUTE_TYPE_BITMASK,
|
|
NV_KMS_ATTRIBUTE_TYPE_DPY_ID,
|
|
NV_KMS_ATTRIBUTE_TYPE_DPY_ID_LIST,
|
|
};
|
|
|
|
enum NvKmsDpyAttribute {
|
|
NV_KMS_DPY_ATTRIBUTE_BACKLIGHT_BRIGHTNESS = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_SCANLINE,
|
|
NV_KMS_DPY_ATTRIBUTE_HW_HEAD,
|
|
NV_KMS_DPY_ATTRIBUTE_HEAD,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_MODE,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_DEPTH,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_MODE,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_DEPTH,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_VIBRANCE,
|
|
NV_KMS_DPY_ATTRIBUTE_IMAGE_SHARPENING,
|
|
NV_KMS_DPY_ATTRIBUTE_IMAGE_SHARPENING_AVAILABLE,
|
|
NV_KMS_DPY_ATTRIBUTE_IMAGE_SHARPENING_DEFAULT,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_COLOR_SPACE,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_SPACE,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_COLOR_RANGE,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_RANGE,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_SIGNAL,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_LINK_TYPE,
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_LINK_RATE,
|
|
NV_KMS_DPY_ATTRIBUTE_FRAMELOCK_DISPLAY_CONFIG,
|
|
/*
|
|
* XXX NVKMS TODO: Delete UPDATE_GLS_FRAMELOCK; this event-only
|
|
* attribute is a kludge to tell GLS about a change in framelock
|
|
* configuration made by NVKMS. Eventually, NVKMS should manage
|
|
* framelock itself and GLS shouldn't need to be notified.
|
|
*
|
|
* Note that the event data reports two boolean values: enable
|
|
* (bit 0) and server (bit 1).
|
|
*/
|
|
NV_KMS_DPY_ATTRIBUTE_UPDATE_GLS_FRAMELOCK,
|
|
NV_KMS_DPY_ATTRIBUTE_RASTER_LOCK,
|
|
NV_KMS_DPY_ATTRIBUTE_UPDATE_FLIPLOCK,
|
|
NV_KMS_DPY_ATTRIBUTE_UPDATE_STEREO,
|
|
NV_KMS_DPY_ATTRIBUTE_DPMS,
|
|
NV_KMS_DPY_ATTRIBUTE_VRR_MIN_REFRESH_RATE,
|
|
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_CONNECTOR_TYPE,
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_IS_MULTISTREAM,
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_SINK_IS_AUDIO_CAPABLE,
|
|
|
|
NV_KMS_DPY_ATTRIBUTE_NUMBER_OF_HARDWARE_HEADS_USED,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING attribute. */
|
|
enum NvKmsDpyAttributeRequestedDitheringValue {
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_AUTO = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_ENABLED = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_DISABLED = 2,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_MODE attribute. */
|
|
enum NvKmsDpyAttributeRequestedDitheringModeValue {
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_MODE_AUTO = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_MODE_DYNAMIC_2X2 = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_MODE_STATIC_2X2 = 2,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_MODE_TEMPORAL = 3,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_MODE attribute. */
|
|
enum NvKmsDpyAttributeCurrentDitheringModeValue {
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_MODE_NONE = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_MODE_DYNAMIC_2X2 = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_MODE_STATIC_2X2 = 2,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_MODE_TEMPORAL = 3,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_DEPTH attribute. */
|
|
enum NvKmsDpyAttributeRequestedDitheringDepthValue {
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_DEPTH_AUTO = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_DEPTH_6_BITS = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_REQUESTED_DITHERING_DEPTH_8_BITS = 2,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_DEPTH attribute. */
|
|
enum NvKmsDpyAttributeCurrentDitheringDepthValue {
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_DEPTH_NONE = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_DEPTH_6_BITS = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_DITHERING_DEPTH_8_BITS = 2,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_SPACE attribute. */
|
|
enum NvKmsDpyAttributeCurrentColorSpaceValue {
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_SPACE_RGB = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_SPACE_YCbCr422 = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_SPACE_YCbCr444 = 2,
|
|
NV_KMS_DPY_ATTRIBUTE_CURRENT_COLOR_SPACE_YCbCr420 = 3,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_DIGITAL_SIGNAL attribute. */
|
|
enum NvKmsDpyAttributeDigitalSignalValue {
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_SIGNAL_LVDS = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_SIGNAL_TMDS = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_SIGNAL_DISPLAYPORT = 2,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_SIGNAL_HDMI_FRL = 3,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_SIGNAL_DSI = 4,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_DIGITAL_LINK_TYPE attribute. */
|
|
enum NvKmsDpyAttributeDigitalLinkTypeValue {
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_LINK_TYPE_SINGLE = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_LINK_TYPE_DUAL = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_DIGITAL_LINK_TYPE_QUAD = 3,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_FRAMELOCK_DISPLAY_CONFIG attribute. */
|
|
enum NvKmsDpyAttributeFrameLockDisplayConfigValue {
|
|
NV_KMS_DPY_ATTRIBUTE_FRAMELOCK_DISPLAY_CONFIG_DISABLED = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_FRAMELOCK_DISPLAY_CONFIG_CLIENT = 1,
|
|
NV_KMS_DPY_ATTRIBUTE_FRAMELOCK_DISPLAY_CONFIG_SERVER = 2,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_DPMS attribute. */
|
|
enum NvKmsDpyAttributeDpmsValue {
|
|
NV_KMS_DPY_ATTRIBUTE_DPMS_ON,
|
|
NV_KMS_DPY_ATTRIBUTE_DPMS_STANDBY,
|
|
NV_KMS_DPY_ATTRIBUTE_DPMS_SUSPEND,
|
|
NV_KMS_DPY_ATTRIBUTE_DPMS_OFF,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_CONNECTOR_TYPE attribute */
|
|
enum NvKmsDpyAttributeDisplayportConnectorTypeValue {
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_CONNECTOR_TYPE_UNKNOWN = 0,
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_CONNECTOR_TYPE_DISPLAYPORT,
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_CONNECTOR_TYPE_HDMI,
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_CONNECTOR_TYPE_DVI,
|
|
NV_KMS_DPY_ATTRIBUTE_DISPLAYPORT_CONNECTOR_TYPE_VGA,
|
|
};
|
|
|
|
struct NvKmsSetDpyAttributeRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
enum NvKmsDpyAttribute attribute;
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsSetDpyAttributeReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSetDpyAttributeParams {
|
|
struct NvKmsSetDpyAttributeRequest request; /*! in */
|
|
struct NvKmsSetDpyAttributeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
struct NvKmsGetDpyAttributeRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
enum NvKmsDpyAttribute attribute;
|
|
};
|
|
|
|
struct NvKmsGetDpyAttributeReply {
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsGetDpyAttributeParams {
|
|
struct NvKmsGetDpyAttributeRequest request; /*! in */
|
|
struct NvKmsGetDpyAttributeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
struct NvKmsAttributeValidValuesCommonReply {
|
|
NvBool readable;
|
|
NvBool writable;
|
|
enum NvKmsAttributeType type;
|
|
union {
|
|
struct {
|
|
NvS64 min NV_ALIGN_BYTES(8);
|
|
NvS64 max NV_ALIGN_BYTES(8);
|
|
} range; /*! Used when type == NV_KMS_ATTRIBUTE_TYPE_RANGE. */
|
|
struct {
|
|
NvU32 ints;
|
|
} bits; /*! Used when type == NV_KMS_ATTRIBUTE_TYPE_INTBITS. */
|
|
} u;
|
|
};
|
|
|
|
struct NvKmsGetDpyAttributeValidValuesRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
enum NvKmsDpyAttribute attribute;
|
|
};
|
|
|
|
struct NvKmsGetDpyAttributeValidValuesReply {
|
|
struct NvKmsAttributeValidValuesCommonReply common;
|
|
};
|
|
|
|
|
|
struct NvKmsGetDpyAttributeValidValuesParams {
|
|
struct NvKmsGetDpyAttributeValidValuesRequest request; /*! in */
|
|
struct NvKmsGetDpyAttributeValidValuesReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_DISP_ATTRIBUTE:
|
|
* NVKMS_IOCTL_GET_DISP_ATTRIBUTE:
|
|
* NVKMS_IOCTL_GET_DISP_ATTRIBUTE_VALID_VALUES:
|
|
*/
|
|
|
|
|
|
enum NvKmsDispAttribute {
|
|
NV_KMS_DISP_ATTRIBUTE_FRAMELOCK = 0,
|
|
NV_KMS_DISP_ATTRIBUTE_FRAMELOCK_SYNC,
|
|
NV_KMS_DISP_ATTRIBUTE_GPU_FRAMELOCK_FPGA_REVISION_UNSUPPORTED,
|
|
NV_KMS_DISP_ATTRIBUTE_FRAMELOCK_STEREO_SYNC,
|
|
NV_KMS_DISP_ATTRIBUTE_FRAMELOCK_TIMING,
|
|
NV_KMS_DISP_ATTRIBUTE_FRAMELOCK_TEST_SIGNAL,
|
|
NV_KMS_DISP_ATTRIBUTE_FRAMELOCK_RESET,
|
|
NV_KMS_DISP_ATTRIBUTE_FRAMELOCK_SET_SWAP_BARRIER,
|
|
NV_KMS_DISP_ATTRIBUTE_ALLOW_FLIPLOCK,
|
|
NV_KMS_DISP_ATTRIBUTE_QUERY_DP_AUX_LOG,
|
|
};
|
|
|
|
|
|
struct NvKmsSetDispAttributeRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
enum NvKmsDispAttribute attribute;
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsSetDispAttributeReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSetDispAttributeParams {
|
|
struct NvKmsSetDispAttributeRequest request; /*! in */
|
|
struct NvKmsSetDispAttributeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
struct NvKmsGetDispAttributeRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
enum NvKmsDispAttribute attribute;
|
|
};
|
|
|
|
struct NvKmsGetDispAttributeReply {
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsGetDispAttributeParams {
|
|
struct NvKmsGetDispAttributeRequest request; /*! in */
|
|
struct NvKmsGetDispAttributeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
struct NvKmsGetDispAttributeValidValuesRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
enum NvKmsDispAttribute attribute;
|
|
};
|
|
|
|
struct NvKmsGetDispAttributeValidValuesReply {
|
|
struct NvKmsAttributeValidValuesCommonReply common;
|
|
};
|
|
|
|
struct NvKmsGetDispAttributeValidValuesParams {
|
|
struct NvKmsGetDispAttributeValidValuesRequest request; /*! in */
|
|
struct NvKmsGetDispAttributeValidValuesReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_QUERY_FRAMELOCK: Query information about a framelock
|
|
* device.
|
|
*/
|
|
|
|
struct NvKmsQueryFrameLockRequest {
|
|
NvKmsFrameLockHandle frameLockHandle;
|
|
};
|
|
|
|
struct NvKmsQueryFrameLockReply {
|
|
NvU32 gpuIds[NVKMS_MAX_GPUS_PER_FRAMELOCK];
|
|
};
|
|
|
|
struct NvKmsQueryFrameLockParams {
|
|
struct NvKmsQueryFrameLockRequest request; /*! in */
|
|
struct NvKmsQueryFrameLockReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_FRAMELOCK_ATTRIBUTE:
|
|
* NVKMS_IOCTL_GET_FRAMELOCK_ATTRIBUTE:
|
|
* NVKMS_IOCTL_GET_FRAMELOCK_ATTRIBUTE_VALID_VALUES:
|
|
*/
|
|
|
|
enum NvKmsFrameLockAttribute {
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_POLARITY = 0,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_SYNC_DELAY,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_HOUSE_SYNC_MODE,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_SYNC_INTERVAL,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_SYNC_READY,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_VIDEO_MODE,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_FPGA_REVISION,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_FIRMWARE_MAJOR_VERSION,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_FIRMWARE_MINOR_VERSION,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_BOARD_ID,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_SYNC_DELAY_RESOLUTION,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_PORT0_STATUS,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_PORT1_STATUS,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_HOUSE_STATUS,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_ETHERNET_DETECTED,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_SYNC_RATE,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_SYNC_RATE_4,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_INCOMING_HOUSE_SYNC_RATE,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_MULTIPLY_DIVIDE_VALUE,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_MULTIPLY_DIVIDE_MODE,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_FRAMELOCK_ATTRIBUTE_POLARITY attribute. */
|
|
enum NvKmsFrameLockAttributePolarityValue {
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_POLARITY_RISING_EDGE = 0x1,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_POLARITY_FALLING_EDGE = 0x2,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_POLARITY_BOTH_EDGES = 0x3,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_FRAMELOCK_ATTRIBUTE_HOUSE_SYNC_MODE attribute. */
|
|
enum NvKmsFrameLockAttributeHouseSyncModeValue {
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_HOUSE_SYNC_MODE_DISABLED = 0,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_HOUSE_SYNC_MODE_INPUT = 0x1,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_HOUSE_SYNC_MODE_OUTPUT = 0x2,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_FRAMELOCK_ATTRIBUTE_ETHERNET_DETECTED attribute. */
|
|
enum NvKmsFrameLockAttributeEthernetDetectedValue {
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_ETHERNET_DETECTED_NONE = 0,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_ETHERNET_DETECTED_PORT0 = 0x1,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_ETHERNET_DETECTED_PORT1 = 0x2,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_FRAMELOCK_ATTRIBUTE_VIDEO_MODE attribute. */
|
|
enum NvKmsFrameLockAttributeVideoModeValue {
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_VIDEO_MODE_COMPOSITE_AUTO = 0,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_VIDEO_MODE_TTL = 1,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_VIDEO_MODE_COMPOSITE_BI_LEVEL = 2,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_VIDEO_MODE_COMPOSITE_TRI_LEVEL = 3,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_FRAMELOCK_ATTRIBUTE_PORT[01]_STATUS attributes. */
|
|
enum NvKmsFrameLockAttributePortStatusValue {
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_PORT_STATUS_INPUT = 0,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_PORT_STATUS_OUTPUT = 1,
|
|
};
|
|
|
|
/*! Values for the NV_KMS_FRAMELOCK_ATTRIBUTE_MULTIPLY_DIVIDE_MODE attribute. */
|
|
enum NvKmsFrameLockAttributeMulDivModeValue {
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_MULTIPLY_DIVIDE_MODE_MULTIPLY = 0,
|
|
NV_KMS_FRAMELOCK_ATTRIBUTE_MULTIPLY_DIVIDE_MODE_DIVIDE = 1,
|
|
};
|
|
|
|
struct NvKmsSetFrameLockAttributeRequest {
|
|
NvKmsFrameLockHandle frameLockHandle;
|
|
enum NvKmsFrameLockAttribute attribute;
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsSetFrameLockAttributeReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSetFrameLockAttributeParams {
|
|
struct NvKmsSetFrameLockAttributeRequest request; /*! in */
|
|
struct NvKmsSetFrameLockAttributeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
struct NvKmsGetFrameLockAttributeRequest {
|
|
NvKmsFrameLockHandle frameLockHandle;
|
|
enum NvKmsFrameLockAttribute attribute;
|
|
};
|
|
|
|
struct NvKmsGetFrameLockAttributeReply {
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsGetFrameLockAttributeParams {
|
|
struct NvKmsGetFrameLockAttributeRequest request; /*! in */
|
|
struct NvKmsGetFrameLockAttributeReply reply; /*! out */
|
|
};
|
|
|
|
|
|
struct NvKmsGetFrameLockAttributeValidValuesRequest {
|
|
NvKmsFrameLockHandle frameLockHandle;
|
|
enum NvKmsFrameLockAttribute attribute;
|
|
};
|
|
|
|
struct NvKmsGetFrameLockAttributeValidValuesReply {
|
|
struct NvKmsAttributeValidValuesCommonReply common;
|
|
};
|
|
|
|
struct NvKmsGetFrameLockAttributeValidValuesParams {
|
|
struct NvKmsGetFrameLockAttributeValidValuesRequest request; /*! in */
|
|
struct NvKmsGetFrameLockAttributeValidValuesReply reply; /*! out */
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_GET_NEXT_EVENT, NVKMS_IOCTL_DECLARE_EVENT_INTEREST:
|
|
* Event handling.
|
|
*
|
|
* Clients should call NVKMS_IOCTL_DECLARE_EVENT_INTEREST to indicate
|
|
* the events in which they are interested. Then, block on poll(2) or
|
|
* select(2) until there are events available to read on the file
|
|
* descriptor.
|
|
*
|
|
* When events are available, the client should call
|
|
* NVKMS_IOCTL_GET_NEXT_EVENT to get an NvKmsEvent structure, and
|
|
* interpret the union based on eventType.
|
|
*
|
|
* Clients can remove interest for events by calling
|
|
* NVKMS_IOCTL_DECLARE_EVENT_INTEREST again, specifying a new
|
|
* interestMask.
|
|
*
|
|
* Note that there may still be events queued for the client when the
|
|
* client calls NVKMS_IOCTL_DECLARE_EVENT_INTEREST to change its
|
|
* interestMask. So, clients should be prepared to ignore unexpected
|
|
* events after calling NVKMS_IOCTL_DECLARE_EVENT_INTEREST.
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
* NVKMS_EVENT_TYPE_DPY_CHANGED
|
|
*
|
|
* When a dpy changes, this event will be generated. The client
|
|
* should call NVKMS_IOCTL_QUERY_DPY_DYNAMIC_DATA to get an updated
|
|
* NvKmsQueryDpyDynamicDataReply.
|
|
*/
|
|
|
|
struct NvKmsEventDpyChanged {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_EVENT_TYPE_DYNAMIC_DPY_CONNECTED
|
|
*
|
|
* When a dynamic dpy is connected, this event will be generated.
|
|
*/
|
|
|
|
struct NvKmsEventDynamicDpyConnected {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_EVENT_TYPE_DYNAMIC_DPY_DISCONNECTED
|
|
*
|
|
* When a dynamic dpy is disconnected, this event will be generated.
|
|
*/
|
|
|
|
struct NvKmsEventDynamicDpyDisconnected {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_EVENT_TYPE_DPY_ATTRIBUTE_CHANGED
|
|
*
|
|
* When a dpy attribute changes, this event will be generated.
|
|
*/
|
|
|
|
struct NvKmsEventDpyAttributeChanged {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
enum NvKmsDpyAttribute attribute;
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_EVENT_TYPE_FRAMELOCK_ATTRIBUTE_CHANGED
|
|
*
|
|
* When a framelock attribute changes, this event will be generated.
|
|
*/
|
|
|
|
struct NvKmsEventFrameLockAttributeChanged {
|
|
NvKmsFrameLockHandle frameLockHandle;
|
|
enum NvKmsFrameLockAttribute attribute;
|
|
NvS64 value NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_EVENT_TYPE_FLIP_OCCURRED
|
|
*
|
|
* When a client requests a flip and specifies a completion notifier
|
|
* with NvKmsCompletionNotifierDescription::awaken == TRUE, this event
|
|
* will be generated. This event is only delivered to clients with
|
|
* flipping permission.
|
|
*/
|
|
|
|
struct NvKmsEventFlipOccurred {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
/* XXX NVKMS TODO: the dispHandle is currently hard-coded to 0. */
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
NvU32 layer;
|
|
};
|
|
|
|
|
|
struct NvKmsEvent {
|
|
enum NvKmsEventType eventType;
|
|
union {
|
|
struct NvKmsEventDpyChanged dpyChanged;
|
|
struct NvKmsEventDynamicDpyConnected dynamicDpyConnected;
|
|
struct NvKmsEventDynamicDpyDisconnected dynamicDpyDisconnected;
|
|
struct NvKmsEventDpyAttributeChanged dpyAttributeChanged;
|
|
struct NvKmsEventFrameLockAttributeChanged frameLockAttributeChanged;
|
|
struct NvKmsEventFlipOccurred flipOccurred;
|
|
} u;
|
|
};
|
|
|
|
|
|
struct NvKmsGetNextEventRequest {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsGetNextEventReply {
|
|
/*!
|
|
* If an event is available, valid = TRUE and the NvKmsEvent
|
|
* contains the event. If no event is available, valid = FALSE.
|
|
*/
|
|
NvBool valid;
|
|
struct NvKmsEvent event;
|
|
};
|
|
|
|
struct NvKmsGetNextEventParams {
|
|
struct NvKmsGetNextEventRequest request; /*! in */
|
|
struct NvKmsGetNextEventReply reply; /*! out */
|
|
};
|
|
|
|
|
|
struct NvKmsDeclareEventInterestRequest {
|
|
/*!
|
|
* Mask of event types, where each event type is indicated by (1
|
|
* << NVKMS_EVENT_TYPE_).
|
|
*/
|
|
NvU32 interestMask;
|
|
};
|
|
|
|
struct NvKmsDeclareEventInterestReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsDeclareEventInterestParams {
|
|
struct NvKmsDeclareEventInterestRequest request; /*! in */
|
|
struct NvKmsDeclareEventInterestReply reply; /*! out */
|
|
};
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_CLEAR_UNICAST_EVENT
|
|
*
|
|
* The events generated through NVKMS_IOCTL_DECLARE_EVENT_INTEREST and
|
|
* NVKMS_IOCTL_GET_NEXT_EVENT are most useful for system-wide events which
|
|
* multiple clients may be interested in. Clients declare their interest in a
|
|
* collection of event types, and when they are notified that some number of
|
|
* events arrived, they have to query the events from the event queue.
|
|
*
|
|
* In contrast, "Unicast Events" are for use in cases where a client is only
|
|
* interested in a particular type of event on a particular object.
|
|
*
|
|
* To use a Unicast Event:
|
|
*
|
|
* - Create an fd through nvKmsOpen().
|
|
*
|
|
* - Do _not_ use the fd for anything else (the first argument to ioctl(2), the
|
|
* fd in any of the granting APIs such as NvKmsGrantSurfaceParams::request:fd,
|
|
* etc).
|
|
*
|
|
* - Pass the fd into an API that allows a unicast event. E.g.,
|
|
* NvKmsJoinSwapGroupParams::request::member::unicastEvent::fd
|
|
*
|
|
* - Clear the unicast event with NVKMS_IOCTL_CLEAR_UNICAST_EVENT.
|
|
*
|
|
* - Check if the event arrived; if it hasn't, then wait for the event through
|
|
* poll(2) or select(2).
|
|
*/
|
|
|
|
struct NvKmsClearUnicastEventRequest {
|
|
int unicastEventFd;
|
|
};
|
|
|
|
struct NvKmsClearUnicastEventReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsClearUnicastEventParams {
|
|
struct NvKmsClearUnicastEventRequest request; /*! in */
|
|
struct NvKmsClearUnicastEventReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_LAYER_POSITION: Set the position of the layer
|
|
* for the specified heads on the specified disps. The layer
|
|
* position is in "desktop coordinate space", i.e., relative to the
|
|
* upper left corner of the input viewport.
|
|
*
|
|
* Note that this is only valid if
|
|
* NvKmsAllocDeviceReply::layerCaps[layer].supportsWindowMode is TRUE.
|
|
*/
|
|
struct NvKmsSetLayerPositionRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
|
|
/*!
|
|
* The bitmask of which indices within disp[] describe requested
|
|
* configuration changes. Any other disps will use their existing
|
|
* configuration.
|
|
*/
|
|
NvU32 requestedDispsBitMask;
|
|
|
|
struct {
|
|
/*!
|
|
* The bitmask of which head[] elements to look at on this
|
|
* disp; any other head will use its existing configuration.
|
|
*/
|
|
NvU32 requestedHeadsBitMask;
|
|
|
|
struct {
|
|
struct NvKmsSignedPoint layerPosition[NVKMS_MAX_LAYERS_PER_HEAD];
|
|
/*!
|
|
* The bitmask of which layerPosition[] elements to look at on this
|
|
* head; any other layer will use its existing configuration.
|
|
*/
|
|
NvU32 requestedLayerBitMask;
|
|
} head[NVKMS_MAX_HEADS_PER_DISP];
|
|
|
|
} disp[NVKMS_MAX_SUBDEVICES];
|
|
};
|
|
|
|
struct NvKmsSetLayerPositionReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSetLayerPositionParams {
|
|
struct NvKmsSetLayerPositionRequest request; /*! in */
|
|
struct NvKmsSetLayerPositionReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_GRAB_OWNERSHIP:
|
|
* NVKMS_IOCTL_RELEASE_OWNERSHIP:
|
|
*
|
|
* NVKMS_IOCTL_GRAB_OWNERSHIP notifies NVKMS that the calling client wants to
|
|
* control modesets on the device, and NVKMS_IOCTL_RELEASE_OWNERSHIP indicates
|
|
* that the modeset ownership should be released and the VT console mode
|
|
* restored.
|
|
*
|
|
* It is not necessary to call NVKMS_IOCTL_RELEASE_OWNERSHIP during shutdown;
|
|
* NVKMS will implicitly clear modeset ownership in nvKmsClose().
|
|
*
|
|
* Releasing modeset ownership enables console hotplug handling. See the
|
|
* explanation in the comment for enableConsoleHotplugHandling above.
|
|
*/
|
|
|
|
struct NvKmsGrabOwnershipRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
};
|
|
|
|
struct NvKmsGrabOwnershipReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsGrabOwnershipParams {
|
|
struct NvKmsGrabOwnershipRequest request; /*! in */
|
|
struct NvKmsGrabOwnershipReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsReleaseOwnershipRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
};
|
|
|
|
struct NvKmsReleaseOwnershipReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsReleaseOwnershipParams {
|
|
struct NvKmsReleaseOwnershipRequest request; /*! in */
|
|
struct NvKmsReleaseOwnershipReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_GRANT_PERMISSIONS:
|
|
* NVKMS_IOCTL_ACQUIRE_PERMISSIONS:
|
|
* NVKMS_IOCTL_REVOKE_PERMISSIONS:
|
|
*
|
|
* By default, only the modeset owning NVKMS client (the one who
|
|
* successfully called NVKMS_IOCTL_GRAB_OWNERSHIP) is allowed to flip
|
|
* or set modes.
|
|
*
|
|
* However, the modeset owner can grant various permissions to other
|
|
* clients through the following steps:
|
|
*
|
|
* - The modeset owner should open /dev/nvidia-modeset, and call
|
|
* NVKMS_IOCTL_GRANT_PERMISSIONS to define a set of permissions
|
|
* associated with the file descriptor.
|
|
*
|
|
* - The modeset owner should pass the file descriptor over a UNIX
|
|
* domain socket to one or more clients who should acquire these
|
|
* permissions.
|
|
*
|
|
* - The modeset owner can optionally close the file descriptor now or
|
|
* later.
|
|
*
|
|
* - The acquiring clients should call NVKMS_IOCTL_ACQUIRE_PERMISSIONS
|
|
* and pass in the file descriptor they received, to update their
|
|
* client connection to include the permissions specified by the modeset
|
|
* owner in the first bullet.
|
|
*
|
|
* - The acquiring clients can optionally close the file descriptor
|
|
* now or later.
|
|
*
|
|
* - From this point forward, both the modeset owner and the clients
|
|
* are allowed to perform the actions allowed by the granted
|
|
* permissions.
|
|
*
|
|
* - The modeset owner can optionally revoke any previously granted
|
|
* permissions with NVKMS_IOCTL_REVOKE_PERMISSIONS. This can be
|
|
* device-scope for all of a type, or just a set of permissions.
|
|
*
|
|
* Notes:
|
|
*
|
|
* - NvKmsPermissions::disp[n] corresponds to the disp named by
|
|
* NvKmsAllocDeviceReply::dispHandles[n].
|
|
*
|
|
* - It is an error to call NVKMS_IOCTL_GRANT_PERMISSIONS more than
|
|
* once on a /dev/nvidia-modeset file descriptor, or to use a file
|
|
* descriptor other than one created by opening /dev/nvidia-modeset,
|
|
* or to use a file descriptor that was previously used as the first
|
|
* argument to ioctl(2).
|
|
*
|
|
* - Calling NVKMS_IOCTL_ACQUIRE_PERMISSIONS more than once on the
|
|
* same NVKMS client will cause the new permissions for that client
|
|
* to be the union of the previous permissions and the latest
|
|
* permissions being acquired.
|
|
*/
|
|
|
|
enum NvKmsPermissionsType {
|
|
NV_KMS_PERMISSIONS_TYPE_FLIPPING = 1,
|
|
NV_KMS_PERMISSIONS_TYPE_MODESET = 2,
|
|
};
|
|
|
|
struct NvKmsFlipPermissions {
|
|
struct {
|
|
struct {
|
|
/*
|
|
* Bitmask of flippable layers, where each layer is
|
|
* indicated by '1 << layer'. It is an error for bits
|
|
* above NVKMS_MAX_LAYERS_PER_HEAD to be set.
|
|
*
|
|
* Only applicable when type==FLIPPING.
|
|
*/
|
|
NvU8 layerMask;
|
|
} head[NVKMS_MAX_HEADS_PER_DISP];
|
|
} disp[NVKMS_MAX_SUBDEVICES];
|
|
};
|
|
|
|
struct NvKmsModesetPermissions {
|
|
struct {
|
|
struct {
|
|
/*
|
|
* A list of dpys which a particular NVKMS client is
|
|
* allowed to use when performing a modeset on this head.
|
|
*
|
|
* If the NVKMS client is not allowed to set a mode on
|
|
* this head, this list will be empty.
|
|
*
|
|
* If an NVKMS client can drive the head without
|
|
* restrictions, this will be nvAllDpyIdList().
|
|
*
|
|
* Only applicable when type==MODESET.
|
|
*/
|
|
NVDpyIdList dpyIdList;
|
|
} head[NVKMS_MAX_HEADS_PER_DISP];
|
|
} disp[NVKMS_MAX_SUBDEVICES];
|
|
};
|
|
|
|
struct NvKmsPermissions {
|
|
enum NvKmsPermissionsType type;
|
|
union {
|
|
struct NvKmsFlipPermissions flip;
|
|
struct NvKmsModesetPermissions modeset;
|
|
};
|
|
};
|
|
|
|
struct NvKmsGrantPermissionsRequest {
|
|
int fd;
|
|
NvKmsDeviceHandle deviceHandle;
|
|
struct NvKmsPermissions permissions;
|
|
};
|
|
|
|
struct NvKmsGrantPermissionsReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsGrantPermissionsParams {
|
|
struct NvKmsGrantPermissionsRequest request; /*! in */
|
|
struct NvKmsGrantPermissionsReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsAcquirePermissionsRequest {
|
|
int fd;
|
|
};
|
|
|
|
struct NvKmsAcquirePermissionsReply {
|
|
/*! This client's handle for the device which acquired new permissions */
|
|
NvKmsDeviceHandle deviceHandle;
|
|
|
|
/*!
|
|
* The acquired permissions.
|
|
*
|
|
* If permissions::type == FLIPPING, the new combined flipping
|
|
* permissions of the calling client on this device, including
|
|
* prior permissions and permissions added by this operation.
|
|
*/
|
|
struct NvKmsPermissions permissions;
|
|
};
|
|
|
|
struct NvKmsAcquirePermissionsParams {
|
|
struct NvKmsAcquirePermissionsRequest request; /*! in */
|
|
struct NvKmsAcquirePermissionsReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsRevokePermissionsRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
|
|
/*
|
|
* A bitmask of permission types to be revoked for this device.
|
|
* It should be the bitwise 'or' of any number of
|
|
* NVBIT(NV_KMS_PERMISSIONS_TYPE_*) values.
|
|
*/
|
|
NvU32 permissionsTypeBitmask;
|
|
|
|
/*
|
|
* If permissionsTypeBitmask is 0, instead revoke only these permissions.
|
|
*/
|
|
struct NvKmsPermissions permissions;
|
|
};
|
|
|
|
struct NvKmsRevokePermissionsReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsRevokePermissionsParams {
|
|
struct NvKmsRevokePermissionsRequest request; /*! in */
|
|
struct NvKmsRevokePermissionsReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_QUERY_DPY_CRC32
|
|
*
|
|
* Query last CRC32 value from the NVKMS disp head specified by the triplet
|
|
* (deviceHandle, dispHandle, head).
|
|
*/
|
|
|
|
struct NvKmsQueryDpyCRC32Request {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
};
|
|
|
|
/*!
|
|
* Generic CRC-structure type to represent CRC value obtained and if
|
|
* hardware architecture supports collection of the CRC type. If
|
|
* the CRC is not supported by hardware, its value is undefined.
|
|
*/
|
|
struct NvKmsDpyCRC32 {
|
|
/*!
|
|
* Value of the CRC. If it is not supported, value is undefined.
|
|
*/
|
|
NvU32 value;
|
|
|
|
/*!
|
|
* Boolean which represents if hardware supports CRC collection
|
|
* If this boolean is FALSE, CRC hardware collection is not supported.
|
|
*/
|
|
NvBool supported;
|
|
};
|
|
|
|
/*!
|
|
* Reply structure that contains CRC32 values returned from hardware.
|
|
* Supported CRCs obtained are represented by supported boolean in crc struct
|
|
* Note- Crcs that are not supported will not be updated and will remain at 0
|
|
*/
|
|
struct NvKmsQueryDpyCRC32Reply {
|
|
/*!
|
|
* CRC generated from the Compositor hardware
|
|
*/
|
|
struct NvKmsDpyCRC32 compositorCrc32;
|
|
|
|
/*!
|
|
* CRC generated from the RG hardware, if head is driving RG/SF.
|
|
* Note that if Dithering is enabled, this CRC will vary across reads
|
|
* from the same frame.
|
|
*/
|
|
struct NvKmsDpyCRC32 rasterGeneratorCrc32;
|
|
|
|
/*!
|
|
* Crc value generated from the target SF/OR depending on connector's OR type
|
|
* Note that if Dithering is enabled, this CRC will vary across reads
|
|
* from the same frame.
|
|
*/
|
|
struct NvKmsDpyCRC32 outputCrc32;
|
|
|
|
};
|
|
|
|
struct NvKmsQueryDpyCRC32Params {
|
|
struct NvKmsQueryDpyCRC32Request request; /*! in */
|
|
struct NvKmsQueryDpyCRC32Reply reply; /*! out */
|
|
};
|
|
|
|
/*!
|
|
* User-space pointers are always passed to NVKMS in an NvU64.
|
|
* This user-space address is eventually passed into the platform's
|
|
* copyin/copyout functions, in a void* argument.
|
|
*
|
|
* This utility function converts from a pointer to an NvU64.
|
|
*/
|
|
|
|
static inline NvU64 nvKmsPointerToNvU64(const void *ptr)
|
|
{
|
|
return (NvU64)(NvUPtr)ptr;
|
|
}
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_REGISTER_DEFERRED_REQUEST_FIFO:
|
|
* NVKMS_IOCTL_UNREGISTER_DEFERRED_REQUEST_FIFO:
|
|
*
|
|
* To make a request that is deferred until after a specific point in a client's
|
|
* graphics channel, a client should register a surface with NVKMS as a
|
|
* "deferred request fifo". The surface is interpreted as having the layout of
|
|
* struct NvKmsDeferredRequestFifo.
|
|
*
|
|
* To make deferred requests, the client should:
|
|
*
|
|
* - Write the NVKMS_DEFERRED_REQUEST_OPCODE for the desired operation to
|
|
* NvKmsDeferredRequestFifo::request[i], where 'i' is the next available
|
|
* element in the request[] array. Repeat as necessary.
|
|
*
|
|
* - Push NV906F_SEMAPHORE[ABCD] methods in its graphics channel to write
|
|
* '(i + 1) % NVKMS_MAX_DEFERRED_REQUESTS' to
|
|
* NvKmsDeferredRequestFifo::put.
|
|
*
|
|
* - Push an NV906F_NON_STALL_INTERRUPT method in its graphics channel.
|
|
*
|
|
* NVKMS will be notified of the non-stall interrupt, and scan all clients'
|
|
* deferred request fifos for put != get. NVKMS will then perform the requests
|
|
* specified in request[get] through request[put-1]. Finally, NVKMS will update
|
|
* get to indicate how much of the fifo it consumed.
|
|
*
|
|
* Wrapping behaves as expected. In pseudo code:
|
|
*
|
|
* while (get != put) {
|
|
* do(request[get]);
|
|
* get = (get + 1) % NVKMS_MAX_DEFERRED_REQUESTS;
|
|
* }
|
|
*
|
|
* The only time it is safe for clients to write to get is when get == put and
|
|
* there are no outstanding semaphore releases to gpuPut.
|
|
*
|
|
* The surface used for the deferred request fifo must be:
|
|
*
|
|
* - In system memory (NVKMS will create one device-scoped mapping, not one per
|
|
* subdevice, as would be needed if the surface were in video memory).
|
|
*
|
|
* - At least as large as sizeof(NvKmsDeferredRequestFifo).
|
|
*
|
|
* Some NVKMS_DEFERRED_REQUESTs may need to write to a semaphore after some
|
|
* operation is performed (e.g., to indicate that a SwapGroup is ready, or that
|
|
* we've reached vblank). The NVKMS_DEFERRED_REQUEST_SEMAPHORE_INDEX field
|
|
* within the request specifies a semaphore within the
|
|
* NvKmsDeferredRequestFifo::semaphore[] array. The semantics of that semaphore
|
|
* index are opcode-specific.
|
|
*
|
|
* The opcode and semaphore index are in the low 16-bits of the request. The
|
|
* upper 16-bits are opcode-specific.
|
|
*/
|
|
|
|
#define NVKMS_MAX_DEFERRED_REQUESTS 128
|
|
|
|
#define NVKMS_DEFERRED_REQUEST_OPCODE 7:0
|
|
|
|
#define NVKMS_DEFERRED_REQUEST_SEMAPHORE_INDEX 15:8
|
|
|
|
#define NVKMS_DEFERRED_REQUEST_OPCODE_NOP 0
|
|
|
|
/*
|
|
* The SWAP_GROUP_READY request means that this NvKmsDeferredRequestFifo is
|
|
* ready for the next swap of the SwapGroup (see NVKMS_IOCTL_JOIN_SWAP_GROUP,
|
|
* below). NVKMS_DEFERRED_REQUEST_SEMAPHORE_INDEX should specify an element in
|
|
* the semaphore[] array which will be released to
|
|
*
|
|
* NVKMS_DEFERRED_REQUEST_SEMAPHORE_VALUE_SWAP_GROUP_READY
|
|
*
|
|
* when the SwapGroup actually swaps.
|
|
*/
|
|
#define NVKMS_DEFERRED_REQUEST_OPCODE_SWAP_GROUP_READY 1
|
|
#define NVKMS_DEFERRED_REQUEST_SEMAPHORE_VALUE_SWAP_GROUP_NOT_READY 0x00000000
|
|
#define NVKMS_DEFERRED_REQUEST_SEMAPHORE_VALUE_SWAP_GROUP_READY 0xFFFFFFFF
|
|
|
|
|
|
/*
|
|
* The SWAP_GROUP_READY_PER_EYE_STEREO field indicates whether this deferred
|
|
* request fifo wants the SwapGroup to present new content at every eye boundary
|
|
* (PER_EYE), or present new content only when transitioning from the right eye
|
|
* to the left eye (PER_PAIR).
|
|
*/
|
|
#define NVKMS_DEFERRED_REQUEST_SWAP_GROUP_READY_PER_EYE_STEREO 16:16
|
|
#define NVKMS_DEFERRED_REQUEST_SWAP_GROUP_READY_PER_EYE_STEREO_PER_PAIR 0
|
|
#define NVKMS_DEFERRED_REQUEST_SWAP_GROUP_READY_PER_EYE_STEREO_PER_EYE 1
|
|
|
|
|
|
struct NvKmsDeferredRequestFifo {
|
|
NvU32 put;
|
|
NvU32 get;
|
|
NvU32 request[NVKMS_MAX_DEFERRED_REQUESTS];
|
|
NvGpuSemaphore semaphore[NVKMS_MAX_DEFERRED_REQUESTS];
|
|
};
|
|
|
|
struct NvKmsRegisterDeferredRequestFifoRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSurfaceHandle surfaceHandle;
|
|
};
|
|
|
|
struct NvKmsRegisterDeferredRequestFifoReply {
|
|
NvKmsDeferredRequestFifoHandle deferredRequestFifoHandle;
|
|
};
|
|
|
|
struct NvKmsRegisterDeferredRequestFifoParams {
|
|
struct NvKmsRegisterDeferredRequestFifoRequest request; /*! in */
|
|
struct NvKmsRegisterDeferredRequestFifoReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsUnregisterDeferredRequestFifoRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDeferredRequestFifoHandle deferredRequestFifoHandle;
|
|
};
|
|
|
|
struct NvKmsUnregisterDeferredRequestFifoReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsUnregisterDeferredRequestFifoParams {
|
|
struct NvKmsUnregisterDeferredRequestFifoRequest request; /*! in */
|
|
struct NvKmsUnregisterDeferredRequestFifoReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_ALLOC_SWAP_GROUP
|
|
* NVKMS_IOCTL_FREE_SWAP_GROUP
|
|
*
|
|
* An NVKMS client creates a SwapGroup by calling NVKMS_IOCTL_ALLOC_SWAP_GROUP
|
|
* and specifying the heads in the SwapGroup with
|
|
* NvKmsAllocSwapGroupRequest::disp[]::headMask.
|
|
*
|
|
* The SwapGroup can be shared with clients through
|
|
* NVKMS_IOCTL_GRANT_SWAP_GROUP, and it is destroyed once all clients that have
|
|
* acquired the swap group through NVKMS_IOCTL_ACQUIRE_SWAP_GROUP have released
|
|
* it through NVKMS_IOCTL_RELEASE_SWAP_GROUP and when the client that created
|
|
* the swap group has called NVKMS_IOCTL_FREE_SWAP_GROUP or freed the device.
|
|
*
|
|
* The SwapGroup allocation is expected to have a long lifetime (e.g., the X
|
|
* driver might call ALLOC_SWAP_GROUP from ScreenInit and FREE_SWAP_GROUP from
|
|
* CloseScreen). The point of these requests is to define the head topology of
|
|
* the SwapGroup (for X driver purposes, presumably all the heads that are
|
|
* assigned to the X screen).
|
|
*
|
|
* As such:
|
|
*
|
|
* - Not all heads described in the ALLOC_SWAP_GROUP request need to be active
|
|
* (they can come and go with different modesets).
|
|
*
|
|
* - The SwapGroup persists across modesets.
|
|
*
|
|
* - SwapGroup allocation is expected to be lightweight: the heavyweight
|
|
* operations like allocating and freeing headSurface resources are done when
|
|
* the number of SwapGroup members (see {JOIN,LEAVE}_SWAP_GROUP below)
|
|
* transitions between 0 and 1.
|
|
*
|
|
* Only an NVKMS modeset owner can alloc or free a SwapGroup.
|
|
*/
|
|
|
|
struct NvKmsSwapGroupConfig {
|
|
struct {
|
|
NvU32 headMask;
|
|
} disp[NVKMS_MAX_SUBDEVICES];
|
|
};
|
|
|
|
struct NvKmsAllocSwapGroupRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
struct NvKmsSwapGroupConfig config;
|
|
};
|
|
|
|
struct NvKmsAllocSwapGroupReply {
|
|
NvKmsSwapGroupHandle swapGroupHandle;
|
|
};
|
|
|
|
struct NvKmsAllocSwapGroupParams {
|
|
struct NvKmsAllocSwapGroupRequest request; /*! in */
|
|
struct NvKmsAllocSwapGroupReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsFreeSwapGroupRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSwapGroupHandle swapGroupHandle;
|
|
};
|
|
|
|
struct NvKmsFreeSwapGroupReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsFreeSwapGroupParams {
|
|
struct NvKmsFreeSwapGroupRequest request; /*! in */
|
|
struct NvKmsFreeSwapGroupReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_JOIN_SWAP_GROUP
|
|
* NVKMS_IOCTL_LEAVE_SWAP_GROUP
|
|
*
|
|
* Clients can join NvKmsDeferredRequestFifos to SwapGroups using
|
|
* NVKMS_IOCTL_JOIN_SWAP_GROUP, and remove NvKmsDeferredRequestFifos from
|
|
* SwapGroups using NVKMS_IOCTL_LEAVE_SWAP_GROUP (or freeing the
|
|
* NvKmsDeferredRequestFifo, or freeing the device).
|
|
*
|
|
* Once an NvKmsDeferredRequestFifo is joined to a SwapGroup, the SwapGroup will
|
|
* not become ready again until the SwapGroup member sends the
|
|
* NVKMS_DEFERRED_REQUEST_OPCODE_SWAP_GROUP_READY request through their
|
|
* NvKmsDeferredRequestFifo. The NVKMS_DEFERRED_REQUEST_SEMAPHORE_INDEX
|
|
* specified as part of the request indicates an index into
|
|
* NvKmsDeferredRequestFifo::semaphore[] where NVKMS will write
|
|
*
|
|
* NVKMS_DEFERRED_REQUEST_SEMAPHORE_VALUE_SWAP_GROUP_READY
|
|
*
|
|
* when the SwapGroup becomes ready.
|
|
*
|
|
* If unicastEvent::specified is TRUE, then unicastEvent::fd will be interpreted
|
|
* as a unicast event file descriptor. See NVKMS_IOCTL_CLEAR_UNICAST_EVENT for
|
|
* details. Whenever SWAP_GROUP_READY is written to a semaphore within
|
|
* NvKmsDeferredRequestFifo, the unicastEvent fd will be notified.
|
|
*
|
|
* An NvKmsDeferredRequestFifo can be joined to at most one SwapGroup at a time.
|
|
*
|
|
* If one client uses multiple NvKmsDeferredRequestFifos joined to multiple
|
|
* SwapGroups and wants to synchronize swaps between these fifos, it should
|
|
* bundle all of the (deviceHandle, swapGroupHandle, deferredRequestFifoHandle)
|
|
* tuples into a single join/leave request.
|
|
*
|
|
* If any client joins multiple NvKmsDeferredRequestFifos to multiple
|
|
* SwapGroups, all NVKMS_IOCTL_JOIN_SWAP_GROUP requests must specify the same
|
|
* set of SwapGroups.
|
|
*/
|
|
|
|
struct NvKmsJoinSwapGroupRequestOneMember {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSwapGroupHandle swapGroupHandle;
|
|
NvKmsDeferredRequestFifoHandle deferredRequestFifoHandle;
|
|
|
|
struct {
|
|
int fd;
|
|
NvBool specified;
|
|
} unicastEvent;
|
|
};
|
|
|
|
struct NvKmsJoinSwapGroupRequest {
|
|
NvU32 numMembers;
|
|
struct NvKmsJoinSwapGroupRequestOneMember member[NVKMS_MAX_SWAPGROUPS];
|
|
};
|
|
|
|
struct NvKmsJoinSwapGroupReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsJoinSwapGroupParams {
|
|
struct NvKmsJoinSwapGroupRequest request; /*! in */
|
|
struct NvKmsJoinSwapGroupReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsLeaveSwapGroupRequestOneMember {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDeferredRequestFifoHandle deferredRequestFifoHandle;
|
|
};
|
|
|
|
struct NvKmsLeaveSwapGroupRequest {
|
|
NvU32 numMembers;
|
|
struct NvKmsLeaveSwapGroupRequestOneMember member[NVKMS_MAX_SWAPGROUPS];
|
|
};
|
|
|
|
struct NvKmsLeaveSwapGroupReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsLeaveSwapGroupParams {
|
|
struct NvKmsLeaveSwapGroupRequest request; /*! in */
|
|
struct NvKmsLeaveSwapGroupReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SET_SWAP_GROUP_CLIP_LIST
|
|
*
|
|
* The X driver needs to define which pixels on-screen are owned by the
|
|
* SwapGroup. NVKMS will use this to prevent those pixels from updating until
|
|
* all SwapGroup members indicate that they are ready.
|
|
*
|
|
* The clip list is interpreted by NVKMS as relative to the surface specified
|
|
* during a flip or modeset. The clip list is intersected with the ViewPortIn
|
|
* of the head, described by
|
|
*
|
|
* NvKmsFlipCommonParams::viewPortIn::point
|
|
*
|
|
* and
|
|
*
|
|
* NvKmsSetModeOneHeadRequest::viewPortSizeIn
|
|
*
|
|
* The clip list is exclusive. I.e., each NvKmsRect is a region outside of the
|
|
* SwapGroup. One surface-sized NvKmsRect would mean that there are no
|
|
* SwapGroup-owned pixels.
|
|
*
|
|
* When no clip list is specified, NVKMS behaves as if there were no
|
|
* SwapGroup-owned pixels.
|
|
*
|
|
* Only an NVKMS modeset owner can set the clip list of a SwapGroup.
|
|
*/
|
|
|
|
struct NvKmsSetSwapGroupClipListRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSwapGroupHandle swapGroupHandle;
|
|
|
|
/*! The number of struct NvKmsRects pointed to by pClipList. */
|
|
NvU16 nClips;
|
|
|
|
/*!
|
|
* Pointer to an array of struct NvKmsRects describing the inclusive clip
|
|
* list for the SwapGroup. The NvKmsRects are in desktop coordinate space.
|
|
*
|
|
* Use nvKmsPointerToNvU64() to assign pClipList.
|
|
*/
|
|
NvU64 pClipList NV_ALIGN_BYTES(8);
|
|
};
|
|
|
|
struct NvKmsSetSwapGroupClipListReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSetSwapGroupClipListParams {
|
|
struct NvKmsSetSwapGroupClipListRequest request; /*! in */
|
|
struct NvKmsSetSwapGroupClipListReply reply; /*! out */
|
|
};
|
|
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_GRANT_SWAP_GROUP:
|
|
* NVKMS_IOCTL_ACQUIRE_SWAP_GROUP:
|
|
* NVKMS_IOCTL_RELEASE_SWAP_GROUP:
|
|
*
|
|
* An NVKMS client can "grant" a swap group that it has allocated through
|
|
* NVKMS_IOCTL_ALLOC_SWAP_GROUP to another NVKMS client through the following
|
|
* steps:
|
|
*
|
|
* - The granting NVKMS client should open /dev/nvidia-modeset, and call
|
|
* NVKMS_IOCTL_GRANT_SWAP_GROUP to associate an NvKmsSwapGroupHandle
|
|
* with the file descriptor.
|
|
*
|
|
* - The granting NVKMS client should pass the file descriptor over a
|
|
* UNIX domain socket to one or more clients who should acquire the
|
|
* swap group.
|
|
*
|
|
* - The granting NVKMS client can optionally close the file
|
|
* descriptor now or later.
|
|
*
|
|
* - Each acquiring client should call NVKMS_IOCTL_ACQUIRE_SWAP_GROUP,
|
|
* and pass in the file descriptor it received. This returns an
|
|
* NvKmsSwapGroupHandle that the acquiring client can use to refer to
|
|
* the swap group in any other NVKMS API call that takes an
|
|
* NvKmsSwapGroupHandle.
|
|
*
|
|
* - The acquiring clients can optionally close the file descriptor
|
|
* now or later.
|
|
*
|
|
* - Each acquiring client should call NVKMS_IOCTL_RELEASE_SWAP_GROUP to
|
|
* release it when they are done with the swap group.
|
|
*/
|
|
|
|
struct NvKmsGrantSwapGroupRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSwapGroupHandle swapGroupHandle;
|
|
int fd;
|
|
};
|
|
|
|
struct NvKmsGrantSwapGroupReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsGrantSwapGroupParams {
|
|
struct NvKmsGrantSwapGroupRequest request; /*! in */
|
|
struct NvKmsGrantSwapGroupReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsAcquireSwapGroupRequest {
|
|
int fd;
|
|
};
|
|
|
|
struct NvKmsAcquireSwapGroupReply {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSwapGroupHandle swapGroupHandle;
|
|
};
|
|
|
|
struct NvKmsAcquireSwapGroupParams {
|
|
struct NvKmsAcquireSwapGroupRequest request; /*! in */
|
|
struct NvKmsAcquireSwapGroupReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsReleaseSwapGroupRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsSwapGroupHandle swapGroupHandle;
|
|
};
|
|
|
|
struct NvKmsReleaseSwapGroupReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsReleaseSwapGroupParams {
|
|
struct NvKmsReleaseSwapGroupRequest request; /*! in */
|
|
struct NvKmsReleaseSwapGroupReply reply; /*! out */
|
|
};
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_SWITCH_MUX:
|
|
*
|
|
* Switch the mux for the given Dpy in the given direction. The mux switch is
|
|
* performed in three stages.
|
|
*/
|
|
|
|
enum NvKmsMuxOperation {
|
|
NVKMS_SWITCH_MUX_PRE,
|
|
NVKMS_SWITCH_MUX,
|
|
NVKMS_SWITCH_MUX_POST,
|
|
};
|
|
|
|
struct NvKmsSwitchMuxRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
enum NvKmsMuxOperation operation;
|
|
NvMuxState state;
|
|
};
|
|
|
|
struct NvKmsSwitchMuxReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsSwitchMuxParams {
|
|
struct NvKmsSwitchMuxRequest request;
|
|
struct NvKmsSwitchMuxReply reply;
|
|
};
|
|
|
|
struct NvKmsGetMuxStateRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NVDpyId dpyId;
|
|
};
|
|
|
|
struct NvKmsGetMuxStateReply {
|
|
NvMuxState state;
|
|
};
|
|
|
|
struct NvKmsGetMuxStateParams {
|
|
struct NvKmsGetMuxStateRequest request;
|
|
struct NvKmsGetMuxStateReply reply;
|
|
};
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_EXPORT_VRR_SEMAPHORE_SURFACE:
|
|
*
|
|
* Export the VRR semaphore surface onto the provided RM 'memFd'.
|
|
* The RM memory FD should be "empty". An empty FD can be allocated by calling
|
|
* NV0000_CTRL_OS_UNIX_EXPORT_OBJECT_TO_FD with 'EMPTY_FD' set.
|
|
*/
|
|
|
|
struct NvKmsExportVrrSemaphoreSurfaceRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
int memFd;
|
|
};
|
|
|
|
struct NvKmsExportVrrSemaphoreSurfaceReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsExportVrrSemaphoreSurfaceParams {
|
|
struct NvKmsExportVrrSemaphoreSurfaceRequest request;
|
|
struct NvKmsExportVrrSemaphoreSurfaceReply reply;
|
|
};
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_ENABLE_VBLANK_SYNC_OBJECT:
|
|
* NVKMS_IOCTL_DISABLE_VBLANK_SYNC_OBJECT:
|
|
*
|
|
* The NVKMS client can use NVKMS_IOCTL_ENABLE_VBLANK_SYNC_OBJECT to request a
|
|
* vblank syncpt that continuously triggers each time the raster generator
|
|
* reaches the start of vblank. NVKMS will return the syncpt id in
|
|
* 'NvKmsEnableVblankSyncObjectReply::syncptId'.
|
|
*
|
|
* The NVKMS client can use NVKMS_IOCTL_DISABLE_VBLANK_SYNC_OBJECT to disable
|
|
* the vblank syncpt.
|
|
*
|
|
* If a vblank syncpt is currently enabled on a head, and a modeset request is
|
|
* issued to reconfigure that head with a new set of mode timings, NVKMS will
|
|
* automatically reenable the vblank syncpt so it continues to trigger with the
|
|
* new mode timings.
|
|
*
|
|
* Clients can use these IOCTLs only if both NvKmsAllocDeviceReply::
|
|
* supportsVblankSyncObjects and NvKmsAllocDeviceReply::supportsSyncpts are
|
|
* TRUE.
|
|
*/
|
|
|
|
struct NvKmsEnableVblankSyncObjectRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
};
|
|
|
|
struct NvKmsEnableVblankSyncObjectReply {
|
|
/*
|
|
* Clients should explicitly disable the vblank sync object to consume the
|
|
* handle.
|
|
*/
|
|
NvKmsVblankSyncObjectHandle vblankHandle;
|
|
|
|
NvU32 syncptId;
|
|
};
|
|
|
|
struct NvKmsEnableVblankSyncObjectParams {
|
|
struct NvKmsEnableVblankSyncObjectRequest request; /*! in */
|
|
struct NvKmsEnableVblankSyncObjectReply reply; /*! out */
|
|
};
|
|
|
|
struct NvKmsDisableVblankSyncObjectRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
|
|
/* This handle is received in NVKMS_IOCTL_ENABLE_VBLANK_SYNC_OBJECT. */
|
|
NvKmsVblankSyncObjectHandle vblankHandle;
|
|
};
|
|
|
|
struct NvKmsDisableVblankSyncObjectReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsDisableVblankSyncObjectParams {
|
|
struct NvKmsDisableVblankSyncObjectRequest request; /*! in */
|
|
struct NvKmsDisableVblankSyncObjectReply reply; /*! out */
|
|
};
|
|
|
|
/*!
|
|
* NVKMS_IOCTL_NOTIFY_VBLANK:
|
|
*
|
|
* Register a unicast event fd to be notified when the next vblank event occurs
|
|
* on the specified head. This is a one-shot notification, and in order to be
|
|
* notified of subsequent vblank events the caller must clear and re-register
|
|
* the unicast event fd.
|
|
*/
|
|
|
|
struct NvKmsNotifyVblankRequest {
|
|
NvKmsDeviceHandle deviceHandle;
|
|
NvKmsDispHandle dispHandle;
|
|
NvU32 head;
|
|
|
|
struct {
|
|
int fd;
|
|
} unicastEvent;
|
|
};
|
|
|
|
struct NvKmsNotifyVblankReply {
|
|
NvU32 padding;
|
|
};
|
|
|
|
struct NvKmsNotifyVblankParams {
|
|
struct NvKmsNotifyVblankRequest request; /*! in */
|
|
struct NvKmsNotifyVblankReply reply; /*! out */
|
|
};
|
|
|
|
#endif /* NVKMS_API_H */
|