-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathglBindTexture.c
69 lines (52 loc) · 1.59 KB
/
glBindTexture.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include <string.h>
#include "pspgl_internal.h"
#include "pspgl_texobj.h"
void glBindTexture(GLenum target, GLuint id)
{
struct pspgl_texobj *tobj, *bound;
struct hashtable *hash = &pspgl_curctx->shared->texture_objects;
unsigned i;
GLenum error;
bound = pspgl_curctx->texture.bound;
tobj = __pspgl_hash_lookup(hash, id);
if (likely(tobj != NULL)) {
error = GL_INVALID_OPERATION;
if (unlikely(tobj->target == 0))
tobj->target = target;
else if (unlikely(tobj->target != target))
goto out_error;
} else {
/* if this is a new id, create the texture */
tobj = __pspgl_texobj_new(id, target);
psp_log("id %u unknown; creating new texture %p\n", id, tobj);
error = GL_OUT_OF_MEMORY;
if (unlikely(tobj == NULL))
goto out_error;
__pspgl_hash_insert(hash, id, tobj);
}
if (bound == tobj)
return;
if (bound != NULL) {
int i;
psp_log("unbinding previous texture %p\n", bound);
/* save per-texture state in texture object */
for(i = TEXSTATE_START; i <= TEXSTATE_END; i++)
bound->ge_texreg[i - TEXSTATE_START] = getReg(i);
__pspgl_texobj_free(bound);
}
psp_log("binding to %u (%p)\n", id, tobj);
tobj->refcount++;
pspgl_curctx->texture.bound = tobj;
/* restore texture state */
psp_log("updating register state\n");
for(i = TEXSTATE_START; i <= TEXSTATE_END; i++)
if (i != CMD_CLUT_LOAD)
sendCommandi(i, tobj->ge_texreg[i - TEXSTATE_START]);
if (__pspgl_texobj_cmap(tobj) != NULL)
pspgl_curctx->hw.dirty |= HWD_CLUT;
__pspgl_update_texenv(tobj);
sendCommandi(CMD_TEXCACHE_FLUSH, getReg(CMD_TEXCACHE_FLUSH)+1);
return;
out_error:
GLERROR(error);
}