158903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul/************************************************************************** 258903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * 358903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * Copyright 2010 VMware, Inc. 458903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * All Rights Reserved. 558903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * 658903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * Permission is hereby granted, free of charge, to any person obtaining a 758903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * copy of this software and associated documentation files (the 858903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * "Software"), to deal in the Software without restriction, including 958903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * without limitation the rights to use, copy, modify, merge, publish, 1058903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * distribute, sub license, and/or sell copies of the Software, and to 1158903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * permit persons to whom the Software is furnished to do so, subject to 1258903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * the following conditions: 1358903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * 1458903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * The above copyright notice and this permission notice (including the 1558903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * next paragraph) shall be included in all copies or substantial portions 1658903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * of the Software. 1758903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * 1858903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 1958903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 2058903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. 2158903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * IN NO EVENT SHALL THE AUTHORS AND/OR ITS SUPPLIERS BE LIABLE FOR 2258903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 2358903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 2458903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 2558903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * 2658903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul **************************************************************************/ 2758903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul 282de31f2bf2b9c68aaa76a63fa0d0d3e0731ccfb5Brian Paul/** 292de31f2bf2b9c68aaa76a63fa0d0d3e0731ccfb5Brian Paul * Implementation limits for LLVMpipe driver. 302de31f2bf2b9c68aaa76a63fa0d0d3e0731ccfb5Brian Paul */ 312de31f2bf2b9c68aaa76a63fa0d0d3e0731ccfb5Brian Paul 322de31f2bf2b9c68aaa76a63fa0d0d3e0731ccfb5Brian Paul#ifndef LP_LIMITS_H 332de31f2bf2b9c68aaa76a63fa0d0d3e0731ccfb5Brian Paul#define LP_LIMITS_H 3458903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul 3558903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul 3658903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul/** 3758903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul * Tile size (width and height). This needs to be a power of two. 3858903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul */ 3958903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul#define TILE_ORDER 6 4058903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul#define TILE_SIZE (1 << TILE_ORDER) 4158903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul 4258903b378188861a6f7a67bbfb07424b73df2a1bBrian Paul 4371dfbb608acca74268cd6c93b121913a374f6b58Brian Paul/** 4471dfbb608acca74268cd6c93b121913a374f6b58Brian Paul * Max texture sizes 4571dfbb608acca74268cd6c93b121913a374f6b58Brian Paul */ 46bc8509b43b591796fa7c3b7a7497053eb298dc8bJosé Fonseca#define LP_MAX_TEXTURE_SIZE (1 * 1024 * 1024 * 1024ULL) /* 1GB for now */ 47bc8509b43b591796fa7c3b7a7497053eb298dc8bJosé Fonseca#define LP_MAX_TEXTURE_2D_LEVELS 14 /* 8K x 8K for now */ 48bc8509b43b591796fa7c3b7a7497053eb298dc8bJosé Fonseca#define LP_MAX_TEXTURE_3D_LEVELS 11 /* 1K x 1K x 1K for now */ 4971dfbb608acca74268cd6c93b121913a374f6b58Brian Paul 5071dfbb608acca74268cd6c93b121913a374f6b58Brian Paul 5171dfbb608acca74268cd6c93b121913a374f6b58Brian Paul/** This must be the larger of LP_MAX_TEXTURE_2D/3D_LEVELS */ 5271dfbb608acca74268cd6c93b121913a374f6b58Brian Paul#define LP_MAX_TEXTURE_LEVELS LP_MAX_TEXTURE_2D_LEVELS 5371dfbb608acca74268cd6c93b121913a374f6b58Brian Paul 5471dfbb608acca74268cd6c93b121913a374f6b58Brian Paul 5571dfbb608acca74268cd6c93b121913a374f6b58Brian Paul/** 5671dfbb608acca74268cd6c93b121913a374f6b58Brian Paul * Max drawing surface size is the max texture size 5771dfbb608acca74268cd6c93b121913a374f6b58Brian Paul */ 584a72ec49f671015cd556ca2efbe5327f8e02fb28Brian Paul#define LP_MAX_HEIGHT (1 << (LP_MAX_TEXTURE_LEVELS - 1)) 594a72ec49f671015cd556ca2efbe5327f8e02fb28Brian Paul#define LP_MAX_WIDTH (1 << (LP_MAX_TEXTURE_LEVELS - 1)) 6071dfbb608acca74268cd6c93b121913a374f6b58Brian Paul 6171dfbb608acca74268cd6c93b121913a374f6b58Brian Paul 6239be50dcdebe6bcbb48cb6aa8ac151eee811acb1José Fonseca#define LP_MAX_THREADS 8 6339be50dcdebe6bcbb48cb6aa8ac151eee811acb1José Fonseca 6439be50dcdebe6bcbb48cb6aa8ac151eee811acb1José Fonseca 65bb527c0af6c53b335330da1063979f5ac3a19174Brian Paul/** 66bb527c0af6c53b335330da1063979f5ac3a19174Brian Paul * Max bytes per scene. This may be replaced by a runtime parameter. 67bb527c0af6c53b335330da1063979f5ac3a19174Brian Paul */ 68bb527c0af6c53b335330da1063979f5ac3a19174Brian Paul#define LP_MAX_SCENE_SIZE (512 * 1024 * 1024) 69bb527c0af6c53b335330da1063979f5ac3a19174Brian Paul 7017c9d7eea7b3365c59455a731fcb81e69bb86ce2Roland Scheidegger/** 7117c9d7eea7b3365c59455a731fcb81e69bb86ce2Roland Scheidegger * Max number of shader variants (for all shaders combined, 7217c9d7eea7b3365c59455a731fcb81e69bb86ce2Roland Scheidegger * per context) that will be kept around. 7317c9d7eea7b3365c59455a731fcb81e69bb86ce2Roland Scheidegger */ 7417c9d7eea7b3365c59455a731fcb81e69bb86ce2Roland Scheidegger#define LP_MAX_SHADER_VARIANTS 1024 75bb527c0af6c53b335330da1063979f5ac3a19174Brian Paul 765b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell/** 776cf7245f6938e27c9b8a1742f27659aec017bbdcJosé Fonseca * Max number of instructions (for all fragment shaders combined per context) 786cf7245f6938e27c9b8a1742f27659aec017bbdcJosé Fonseca * that will be kept around. 796cf7245f6938e27c9b8a1742f27659aec017bbdcJosé Fonseca */ 806cf7245f6938e27c9b8a1742f27659aec017bbdcJosé Fonseca#define LP_MAX_SHADER_INSTRUCTIONS (128*1024) 816cf7245f6938e27c9b8a1742f27659aec017bbdcJosé Fonseca 826cf7245f6938e27c9b8a1742f27659aec017bbdcJosé Fonseca/** 835b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell * Max number of setup variants that will be kept around. 845b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell * 855b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell * These are determined by the combination of the fragment shader 865b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell * input signature and a small amount of rasterization state (eg 875b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell * flatshading). It is likely that many active fragment shaders will 885b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell * share the same setup variant. 895b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell */ 905b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell#define LP_MAX_SETUP_VARIANTS 64 915b4c43d98556c5a4806757513bcb196a724518c5Keith Whitwell 922de31f2bf2b9c68aaa76a63fa0d0d3e0731ccfb5Brian Paul#endif /* LP_LIMITS_H */ 93