intel/common: store sample position in plain arrays

Allows to extract the values in different ways than just the genxml
format.

v2 (Jason Ekstrand):
 - Add a struct gen_sample_location so that we can re-use the array
   macros from the earlier commit.

Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Reviewed-by: Jason Ekstrand <jason@jlekstrand.net>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1887>
This commit is contained in:
Lionel Landwerlin
2020-11-05 09:58:21 +02:00
committed by Marge Bot
parent cb082d8260
commit 43acc10bd0
4 changed files with 163 additions and 122 deletions
+1
View File
@@ -24,6 +24,7 @@ COMMON_FILES = \
common/gen_l3_config.c \
common/gen_l3_config.h \
common/gen_urb_config.c \
common/gen_sample_positions.c \
common/gen_sample_positions.h \
common/gen_uuid.c \
common/gen_uuid.h
+130
View File
@@ -0,0 +1,130 @@
/*
* Copyright © 2020 Intel Corporation
*
* 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 (including the next
* paragraph) 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.
*/
#include "gen_sample_positions.h"
/**
* 1x MSAA has a single sample at the center: (0.5, 0.5) -> (0x8, 0x8).
*/
const struct gen_sample_position gen_sample_positions_1x[] = {
{ 0.5, 0.5, },
};
/**
* 2x MSAA sample positions are (0.25, 0.25) and (0.75, 0.75):
* 4 c
* 4 0
* c 1
*/
const struct gen_sample_position gen_sample_positions_2x[] = {
{ 0.75, 0.75 },
{ 0.25, 0.25 },
};
/**
* Sample positions:
* 2 6 a e
* 2 0
* 6 1
* a 2
* e 3
*/
const struct gen_sample_position gen_sample_positions_4x[] = {
{ 0.375, 0.125 },
{ 0.875, 0.375 },
{ 0.125, 0.625 },
{ 0.625, 0.875 },
};
/**
* Sample positions:
*
* From the Ivy Bridge PRM, Vol2 Part1 p304 (3DSTATE_MULTISAMPLE:
* Programming Notes):
* "When programming the sample offsets (for NUMSAMPLES_4 or _8 and
* MSRASTMODE_xxx_PATTERN), the order of the samples 0 to 3 (or 7
* for 8X) must have monotonically increasing distance from the
* pixel center. This is required to get the correct centroid
* computation in the device."
*
* Sample positions:
* 1 3 5 7 9 b d f
* 1 7
* 3 3
* 5 0
* 7 5
* 9 2
* b 1
* d 4
* f 6
*/
const struct gen_sample_position gen_sample_positions_8x[] = {
{ 0.5625, 0.3125 },
{ 0.4375, 0.6875 },
{ 0.8125, 0.5625 },
{ 0.3125, 0.1875 },
{ 0.1875, 0.8125 },
{ 0.0625, 0.4375 },
{ 0.6875, 0.9375 },
{ 0.9375, 0.0625 },
};
/**
* Sample positions:
*
* 0 1 2 3 4 5 6 7 8 9 a b c d e f
* 0 15
* 1 9
* 2 10
* 3 7
* 4 13
* 5 1
* 6 4
* 7 3
* 8 12
* 9 0
* a 2
* b 6
* c 11
* d 5
* e 8
* f 14
*/
const struct gen_sample_position gen_sample_positions_16x[] = {
{ 0.5625, 0.5625 },
{ 0.4375, 0.3125 },
{ 0.3125, 0.6250 },
{ 0.7500, 0.4375 },
{ 0.1875, 0.3750 },
{ 0.6250, 0.8125 },
{ 0.8125, 0.6875 },
{ 0.6875, 0.1875 },
{ 0.3750, 0.8750 },
{ 0.5000, 0.0625 },
{ 0.2500, 0.1250 },
{ 0.1250, 0.7500 },
{ 0.0000, 0.5000 },
{ 0.9375, 0.2500 },
{ 0.8750, 0.9375 },
{ 0.0625, 0.0000 },
};
+31 -122
View File
@@ -23,11 +23,37 @@
#ifndef GEN_SAMPLE_POSITIONS_H
#define GEN_SAMPLE_POSITIONS_H
#include <util/macros.h>
/*
* This file defines the standard multisample positions used by both GL and
* Vulkan. These correspond to the Vulkan "standard sample locations".
*/
struct gen_sample_position {
float x;
float y;
};
extern const struct gen_sample_position gen_sample_positions_1x[];
extern const struct gen_sample_position gen_sample_positions_2x[];
extern const struct gen_sample_position gen_sample_positions_4x[];
extern const struct gen_sample_position gen_sample_positions_8x[];
extern const struct gen_sample_position gen_sample_positions_16x[];
static inline const struct gen_sample_position *
gen_get_sample_positions(int samples)
{
switch (samples) {
case 1: return gen_sample_positions_1x;
case 2: return gen_sample_positions_2x;
case 4: return gen_sample_positions_4x;
case 8: return gen_sample_positions_8x;
case 16: return gen_sample_positions_16x;
default: unreachable("Invalid sample count");
}
}
/* Examples:
* in case of GEN_GEN < 8:
* GEN_SAMPLE_POS_ELEM(ms.Sample, info->pSampleLocations, 0); expands to:
@@ -85,136 +111,19 @@ prefix##sample_idx##YOffset = arr[sample_idx].y;
GEN_SAMPLE_POS_ELEM(prefix, arr, 14); \
GEN_SAMPLE_POS_ELEM(prefix, arr, 15);
/**
* 1x MSAA has a single sample at the center: (0.5, 0.5) -> (0x8, 0x8).
*/
#define GEN_SAMPLE_POS_1X(prefix) \
prefix##0XOffset = 0.5; \
prefix##0YOffset = 0.5;
GEN_SAMPLE_POS_1X_ARRAY(prefix, gen_sample_positions_1x)
/**
* 2x MSAA sample positions are (0.25, 0.25) and (0.75, 0.75):
* 4 c
* 4 0
* c 1
*/
#define GEN_SAMPLE_POS_2X(prefix) \
prefix##0XOffset = 0.75; \
prefix##0YOffset = 0.75; \
prefix##1XOffset = 0.25; \
prefix##1YOffset = 0.25;
GEN_SAMPLE_POS_2X_ARRAY(prefix, gen_sample_positions_2x)
/**
* Sample positions:
* 2 6 a e
* 2 0
* 6 1
* a 2
* e 3
*/
#define GEN_SAMPLE_POS_4X(prefix) \
prefix##0XOffset = 0.375; \
prefix##0YOffset = 0.125; \
prefix##1XOffset = 0.875; \
prefix##1YOffset = 0.375; \
prefix##2XOffset = 0.125; \
prefix##2YOffset = 0.625; \
prefix##3XOffset = 0.625; \
prefix##3YOffset = 0.875;
GEN_SAMPLE_POS_4X_ARRAY(prefix, gen_sample_positions_4x)
/**
* Sample positions:
*
* From the Ivy Bridge PRM, Vol2 Part1 p304 (3DSTATE_MULTISAMPLE:
* Programming Notes):
* "When programming the sample offsets (for NUMSAMPLES_4 or _8 and
* MSRASTMODE_xxx_PATTERN), the order of the samples 0 to 3 (or 7
* for 8X) must have monotonically increasing distance from the
* pixel center. This is required to get the correct centroid
* computation in the device."
*
* Sample positions:
* 1 3 5 7 9 b d f
* 1 7
* 3 3
* 5 0
* 7 5
* 9 2
* b 1
* d 4
* f 6
*/
#define GEN_SAMPLE_POS_8X(prefix) \
prefix##0XOffset = 0.5625; \
prefix##0YOffset = 0.3125; \
prefix##1XOffset = 0.4375; \
prefix##1YOffset = 0.6875; \
prefix##2XOffset = 0.8125; \
prefix##2YOffset = 0.5625; \
prefix##3XOffset = 0.3125; \
prefix##3YOffset = 0.1875; \
prefix##4XOffset = 0.1875; \
prefix##4YOffset = 0.8125; \
prefix##5XOffset = 0.0625; \
prefix##5YOffset = 0.4375; \
prefix##6XOffset = 0.6875; \
prefix##6YOffset = 0.9375; \
prefix##7XOffset = 0.9375; \
prefix##7YOffset = 0.0625;
GEN_SAMPLE_POS_8X_ARRAY(prefix, gen_sample_positions_8x)
/**
* Sample positions:
*
* 0 1 2 3 4 5 6 7 8 9 a b c d e f
* 0 15
* 1 9
* 2 10
* 3 7
* 4 13
* 5 1
* 6 4
* 7 3
* 8 12
* 9 0
* a 2
* b 6
* c 11
* d 5
* e 8
* f 14
*/
#define GEN_SAMPLE_POS_16X(prefix) \
prefix##0XOffset = 0.5625; \
prefix##0YOffset = 0.5625; \
prefix##1XOffset = 0.4375; \
prefix##1YOffset = 0.3125; \
prefix##2XOffset = 0.3125; \
prefix##2YOffset = 0.6250; \
prefix##3XOffset = 0.7500; \
prefix##3YOffset = 0.4375; \
prefix##4XOffset = 0.1875; \
prefix##4YOffset = 0.3750; \
prefix##5XOffset = 0.6250; \
prefix##5YOffset = 0.8125; \
prefix##6XOffset = 0.8125; \
prefix##6YOffset = 0.6875; \
prefix##7XOffset = 0.6875; \
prefix##7YOffset = 0.1875; \
prefix##8XOffset = 0.3750; \
prefix##8YOffset = 0.8750; \
prefix##9XOffset = 0.5000; \
prefix##9YOffset = 0.0625; \
prefix##10XOffset = 0.2500; \
prefix##10YOffset = 0.1250; \
prefix##11XOffset = 0.1250; \
prefix##11YOffset = 0.7500; \
prefix##12XOffset = 0.0000; \
prefix##12YOffset = 0.5000; \
prefix##13XOffset = 0.9375; \
prefix##13YOffset = 0.2500; \
prefix##14XOffset = 0.8750; \
prefix##14YOffset = 0.9375; \
prefix##15XOffset = 0.0625; \
prefix##15YOffset = 0.0000;
GEN_SAMPLE_POS_16X_ARRAY(prefix, gen_sample_positions_16x)
#endif /* GEN_SAMPLE_POSITIONS_H */
+1
View File
@@ -36,6 +36,7 @@ files_libintel_common = files(
'gen_l3_config.c',
'gen_l3_config.h',
'gen_urb_config.c',
'gen_sample_positions.c',
'gen_sample_positions.h',
'gen_uuid.c',
'gen_uuid.h',