131 lines
3.4 KiB
C
131 lines
3.4 KiB
C
/*
|
|
* 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 "intel_sample_positions.h"
|
|
|
|
/**
|
|
* 1x MSAA has a single sample at the center: (0.5, 0.5) -> (0x8, 0x8).
|
|
*/
|
|
const struct intel_sample_position intel_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 intel_sample_position intel_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 intel_sample_position intel_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 intel_sample_position intel_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 intel_sample_position intel_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 },
|
|
};
|