| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define R100_TRACK_MAX_TEXTURE 3
 | 
					
						
							|  |  |  | #define R200_TRACK_MAX_TEXTURE 6
 | 
					
						
							|  |  |  | #define R300_TRACK_MAX_TEXTURE 16
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define R100_MAX_CB 1
 | 
					
						
							|  |  |  | #define R300_MAX_CB 4
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CS functions | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct r100_cs_track_cb { | 
					
						
							| 
									
										
										
										
											2009-11-20 14:29:23 +01:00
										 |  |  | 	struct radeon_bo	*robj; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	unsigned		pitch; | 
					
						
							|  |  |  | 	unsigned		cpp; | 
					
						
							|  |  |  | 	unsigned		offset; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct r100_cs_track_array { | 
					
						
							| 
									
										
										
										
											2009-11-20 14:29:23 +01:00
										 |  |  | 	struct radeon_bo	*robj; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	unsigned		esize; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct r100_cs_cube_info { | 
					
						
							| 
									
										
										
										
											2009-11-20 14:29:23 +01:00
										 |  |  | 	struct radeon_bo	*robj; | 
					
						
							|  |  |  | 	unsigned		offset; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	unsigned		width; | 
					
						
							|  |  |  | 	unsigned		height; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-07 13:16:06 +10:00
										 |  |  | #define R100_TRACK_COMP_NONE   0
 | 
					
						
							|  |  |  | #define R100_TRACK_COMP_DXT1   1
 | 
					
						
							|  |  |  | #define R100_TRACK_COMP_DXT35  2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | struct r100_cs_track_texture { | 
					
						
							| 
									
										
										
										
											2009-11-20 14:29:23 +01:00
										 |  |  | 	struct radeon_bo	*robj; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	struct r100_cs_cube_info cube_info[5]; /* info for 5 non-primary faces */ | 
					
						
							|  |  |  | 	unsigned		pitch; | 
					
						
							|  |  |  | 	unsigned		width; | 
					
						
							|  |  |  | 	unsigned		height; | 
					
						
							|  |  |  | 	unsigned		num_levels; | 
					
						
							|  |  |  | 	unsigned		cpp; | 
					
						
							|  |  |  | 	unsigned		tex_coord_type; | 
					
						
							|  |  |  | 	unsigned		txdepth; | 
					
						
							|  |  |  | 	unsigned		width_11; | 
					
						
							|  |  |  | 	unsigned		height_11; | 
					
						
							|  |  |  | 	bool			use_pitch; | 
					
						
							|  |  |  | 	bool			enabled; | 
					
						
							| 
									
										
										
										
											2010-10-27 01:02:35 -04:00
										 |  |  | 	bool                    lookup_disable; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	bool			roundup_w; | 
					
						
							|  |  |  | 	bool			roundup_h; | 
					
						
							| 
									
										
										
										
											2009-12-07 13:16:06 +10:00
										 |  |  | 	unsigned                compress_format; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct r100_cs_track { | 
					
						
							|  |  |  | 	unsigned			num_cb; | 
					
						
							|  |  |  | 	unsigned                        num_texture; | 
					
						
							|  |  |  | 	unsigned			maxy; | 
					
						
							|  |  |  | 	unsigned			vtx_size; | 
					
						
							|  |  |  | 	unsigned			vap_vf_cntl; | 
					
						
							| 
									
										
										
										
											2010-02-21 21:24:15 +01:00
										 |  |  | 	unsigned			vap_alt_nverts; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	unsigned			immd_dwords; | 
					
						
							|  |  |  | 	unsigned			num_arrays; | 
					
						
							|  |  |  | 	unsigned			max_indx; | 
					
						
							| 
									
										
										
										
											2009-12-17 06:02:28 +01:00
										 |  |  | 	unsigned			color_channel_mask; | 
					
						
							| 
									
										
										
										
											2011-06-10 14:41:26 +00:00
										 |  |  | 	struct r100_cs_track_array	arrays[16]; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	struct r100_cs_track_cb 	cb[R300_MAX_CB]; | 
					
						
							|  |  |  | 	struct r100_cs_track_cb 	zb; | 
					
						
							| 
									
										
										
										
											2011-02-14 01:01:10 +01:00
										 |  |  | 	struct r100_cs_track_cb 	aa; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | 	struct r100_cs_track_texture	textures[R300_TRACK_MAX_TEXTURE]; | 
					
						
							|  |  |  | 	bool				z_enabled; | 
					
						
							|  |  |  | 	bool                            separate_cube; | 
					
						
							| 
									
										
										
										
											2010-04-13 02:33:36 +02:00
										 |  |  | 	bool				zb_cb_clear; | 
					
						
							| 
									
										
										
										
											2009-12-17 06:02:28 +01:00
										 |  |  | 	bool				blend_read_enable; | 
					
						
							| 
									
										
										
										
											2011-02-12 19:21:35 +01:00
										 |  |  | 	bool				cb_dirty; | 
					
						
							|  |  |  | 	bool				zb_dirty; | 
					
						
							|  |  |  | 	bool				tex_dirty; | 
					
						
							| 
									
										
										
										
											2011-02-14 01:01:10 +01:00
										 |  |  | 	bool				aa_dirty; | 
					
						
							|  |  |  | 	bool				aaresolve; | 
					
						
							| 
									
										
										
										
											2009-09-01 15:25:57 +10:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int r100_cs_track_check(struct radeon_device *rdev, struct r100_cs_track *track); | 
					
						
							|  |  |  | void r100_cs_track_clear(struct radeon_device *rdev, struct r100_cs_track *track); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int r100_cs_packet_parse_vline(struct radeon_cs_parser *p); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int r200_packet0_check(struct radeon_cs_parser *p, | 
					
						
							|  |  |  | 		       struct radeon_cs_packet *pkt, | 
					
						
							|  |  |  | 		       unsigned idx, unsigned reg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-13 16:08:46 -07:00
										 |  |  | int r100_reloc_pitch_offset(struct radeon_cs_parser *p, | 
					
						
							|  |  |  | 			    struct radeon_cs_packet *pkt, | 
					
						
							|  |  |  | 			    unsigned idx, | 
					
						
							|  |  |  | 			    unsigned reg); | 
					
						
							|  |  |  | int r100_packet3_load_vbpntr(struct radeon_cs_parser *p, | 
					
						
							|  |  |  | 			     struct radeon_cs_packet *pkt, | 
					
						
							|  |  |  | 			     int idx); |