| 
									
										
										
										
											2011-02-21 06:58:46 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-10-03 16:21:47 +00:00
										 |  |  |  * $Id$ | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. The Blender | 
					
						
							|  |  |  |  * Foundation also sells licenses for use in proprietary software under | 
					
						
							|  |  |  |  * the Blender License.  See http://www.blender.org/BL/ for information
 | 
					
						
							|  |  |  |  * about this. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2005 Blender Foundation. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Brecht Van Lommel. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-21 06:58:46 +00:00
										 |  |  | /** \file GPU_buffers.h
 | 
					
						
							|  |  |  |  *  \ingroup gpu | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | #ifndef __GPU_BUFFERS_H__
 | 
					
						
							|  |  |  | #define __GPU_BUFFERS_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MAX_FREE_GPU_BUFFERS 8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef _DEBUG
 | 
					
						
							|  |  |  | /*#define DEBUG_VBO(X) printf(X)*/ | 
					
						
							|  |  |  | #define DEBUG_VBO(X)
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define DEBUG_VBO(X)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 18:48:02 +00:00
										 |  |  | #ifdef _DEBUG
 | 
					
						
							|  |  |  | #define ERROR_VBO(X) printf(X)
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define ERROR_VBO(X)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | struct DerivedMesh; | 
					
						
							| 
									
										
										
										
											2010-07-14 10:46:12 +00:00
										 |  |  | struct DMGridData; | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | struct GHash; | 
					
						
							| 
									
										
										
										
											2010-07-13 23:51:21 +00:00
										 |  |  | struct DMGridData; | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* V - vertex, N - normal, T - uv, C - color
 | 
					
						
							|  |  |  |    F - float, UB - unsigned byte */ | 
					
						
							|  |  |  | #define GPU_BUFFER_INTER_V3F	1
 | 
					
						
							|  |  |  | #define GPU_BUFFER_INTER_N3F	2
 | 
					
						
							|  |  |  | #define GPU_BUFFER_INTER_T2F	3
 | 
					
						
							|  |  |  | #define GPU_BUFFER_INTER_C3UB	4
 | 
					
						
							|  |  |  | #define GPU_BUFFER_INTER_C4UB	5
 | 
					
						
							|  |  |  | #define GPU_BUFFER_INTER_END	-1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct GPUBuffer | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int size;	/* in bytes */ | 
					
						
							|  |  |  | 	void *pointer;	/* used with vertex arrays */ | 
					
						
							|  |  |  | 	unsigned int id;	/* used with vertex buffer objects */ | 
					
						
							|  |  |  | } GPUBuffer; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-15 19:04:00 +00:00
										 |  |  | /* stores deleted buffers so that new buffers wouldn't have to 
 | 
					
						
							|  |  |  | be recreated that often. */ | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | typedef struct GPUBufferPool | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-13 13:31:43 +00:00
										 |  |  | 	int size;		/* number of allocated buffers stored */ | 
					
						
							|  |  |  | 	int maxsize;	/* size of the array */ | 
					
						
							|  |  |  | 	GPUBuffer **buffers; | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | } GPUBufferPool; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct GPUBufferMaterial | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int start;	/* at which vertex in the buffer the material starts */ | 
					
						
							|  |  |  | 	int end;	/* at which vertex it ends */ | 
					
						
							|  |  |  | 	char mat_nr; | 
					
						
							|  |  |  | } GPUBufferMaterial; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct IndexLink { | 
					
						
							|  |  |  | 	int element; | 
					
						
							|  |  |  | 	struct IndexLink *next; | 
					
						
							|  |  |  | } IndexLink; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct GPUDrawObject | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	GPUBuffer *vertices; | 
					
						
							|  |  |  | 	GPUBuffer *normals; | 
					
						
							|  |  |  | 	GPUBuffer *uv; | 
					
						
							|  |  |  | 	GPUBuffer *colors; | 
					
						
							|  |  |  | 	GPUBuffer *edges; | 
					
						
							|  |  |  | 	GPUBuffer *uvedges; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int	*faceRemap;			/* at what index was the face originally in DerivedMesh */ | 
					
						
							|  |  |  | 	IndexLink *indices;		/* given an index, find all elements using it */ | 
					
						
							|  |  |  | 	IndexLink *indexMem;	/* for faster memory allocation/freeing */ | 
					
						
							|  |  |  | 	int indexMemUsage;		/* how many are already allocated */ | 
					
						
							|  |  |  | 	int colType; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	GPUBufferMaterial *materials; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int nmaterials; | 
					
						
							|  |  |  | 	int nelements;	/* (number of faces) * 3 */ | 
					
						
							|  |  |  | 	int nlooseverts; | 
					
						
							|  |  |  | 	int nedges; | 
					
						
							|  |  |  | 	int nindices; | 
					
						
							|  |  |  | 	int legacy;	/* if there was a failure allocating some buffer, use old rendering code */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } GPUDrawObject; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-15 19:04:00 +00:00
										 |  |  | /* used for GLSL materials */ | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | typedef struct GPUAttrib | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int index; | 
					
						
							|  |  |  | 	int size; | 
					
						
							|  |  |  | 	int type; | 
					
						
							|  |  |  | } GPUAttrib; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | GPUBufferPool *GPU_buffer_pool_new(void); | 
					
						
							| 
									
										
										
										
											2010-07-13 13:31:43 +00:00
										 |  |  | void GPU_buffer_pool_free( GPUBufferPool *pool ); | 
					
						
							|  |  |  | void GPU_buffer_pool_free_unused( GPUBufferPool *pool ); | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | GPUBuffer *GPU_buffer_alloc( int size, GPUBufferPool *pool ); | 
					
						
							|  |  |  | void GPU_buffer_free( GPUBuffer *buffer, GPUBufferPool *pool ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GPUDrawObject *GPU_drawobject_new( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | void GPU_drawobject_free( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | /* Buffers for non-DerivedMesh drawing */ | 
					
						
							| 
									
										
										
										
											2009-11-25 13:40:43 +00:00
										 |  |  | void *GPU_build_mesh_buffers(struct GHash *map, struct MVert *mvert, | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | 			struct MFace *mface, int *face_indices, | 
					
						
							|  |  |  | 			int totface, int *vert_indices, int uniq_verts, | 
					
						
							|  |  |  | 			int totvert); | 
					
						
							| 
									
										
										
										
											2009-11-25 13:40:43 +00:00
										 |  |  | void GPU_update_mesh_buffers(void *buffers, struct MVert *mvert, | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | 			int *vert_indices, int totvert); | 
					
						
							| 
									
										
										
										
											2009-11-25 13:40:43 +00:00
										 |  |  | void *GPU_build_grid_buffers(struct DMGridData **grids, | 
					
						
							|  |  |  | 	int *grid_indices, int totgrid, int gridsize); | 
					
						
							|  |  |  | void GPU_update_grid_buffers(void *buffers_v, struct DMGridData **grids, | 
					
						
							| 
									
										
										
										
											2010-03-22 17:17:36 +00:00
										 |  |  | 	int *grid_indices, int totgrid, int gridsize, int smooth); | 
					
						
							| 
									
										
										
										
											2009-11-25 13:40:43 +00:00
										 |  |  | void GPU_draw_buffers(void *buffers); | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | void GPU_free_buffers(void *buffers); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | /* called before drawing */ | 
					
						
							|  |  |  | void GPU_vertex_setup( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | void GPU_normal_setup( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | void GPU_uv_setup( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | void GPU_color_setup( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | void GPU_edge_setup( struct DerivedMesh *dm );	/* does not mix with other data */ | 
					
						
							|  |  |  | void GPU_uvedge_setup( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | void GPU_interleaved_setup( GPUBuffer *buffer, int data[] ); | 
					
						
							|  |  |  | int GPU_attrib_element_size( GPUAttrib data[], int numdata ); | 
					
						
							|  |  |  | void GPU_interleaved_attrib_setup( GPUBuffer *buffer, GPUAttrib data[], int numdata ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* can't lock more than one buffer at once */ | 
					
						
							|  |  |  | void *GPU_buffer_lock( GPUBuffer *buffer );	 | 
					
						
							|  |  |  | void *GPU_buffer_lock_stream( GPUBuffer *buffer ); | 
					
						
							|  |  |  | void GPU_buffer_unlock( GPUBuffer *buffer ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* upload three unsigned chars, representing RGB colors, for each vertex. Resets dm->drawObject->colType to -1 */ | 
					
						
							| 
									
										
										
										
											2009-10-13 19:02:30 +00:00
										 |  |  | void GPU_color3_upload( struct DerivedMesh *dm, unsigned char *data ); | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | /* upload four unsigned chars, representing RGBA colors, for each vertex. Resets dm->drawObject->colType to -1 */ | 
					
						
							| 
									
										
										
										
											2009-10-13 19:02:30 +00:00
										 |  |  | void GPU_color4_upload( struct DerivedMesh *dm, unsigned char *data ); | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | /* switch color rendering on=1/off=0 */ | 
					
						
							|  |  |  | void GPU_color_switch( int mode ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void GPU_buffer_draw_elements( GPUBuffer *elements, unsigned int mode, int start, int count ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* called after drawing */ | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | void GPU_buffer_unbind(void); | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-15 19:04:00 +00:00
										 |  |  | /* used to check whether to use the old (without buffers) code */ | 
					
						
							| 
									
										
										
										
											2009-10-03 15:35:01 +00:00
										 |  |  | int GPU_buffer_legacy( struct DerivedMesh *dm ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |