diff options
author | Timothy Arceri <[email protected]> | 2017-01-24 08:41:36 +1100 |
---|---|---|
committer | Jordan Justen <[email protected]> | 2017-10-31 23:36:54 -0700 |
commit | 2589e7ddafb63583498f5f7138914d2a2e634960 (patch) | |
tree | 86876affe556456b499d78a3189bc2f3e637c08f /src/mesa | |
parent | 516d50db319396c23fd599012aec8b3fbc0ee5a6 (diff) |
i965: Add shader cache support for vertex and fragment stages
This enables the cache on vertex and fragment shaders only.
v2:
* Use MAYBE_UNUSED. (Matt)
[[email protected]: reword subject]
[[email protected]: *_cached_program => brw_disk_cache_*_program]
Signed-off-by: Jordan Justen <[email protected]>
Reviewed-by: Jason Ekstrand <[email protected]>
Reviewed-by: Kenneth Graunke <[email protected]>
Diffstat (limited to 'src/mesa')
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_state_upload.c | 2 | ||||
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_vs.c | 20 | ||||
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_wm.c | 24 |
3 files changed, 30 insertions, 16 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_state_upload.c b/src/mesa/drivers/dri/i965/brw_state_upload.c index 23e4ebda259..60f54a9cd0b 100644 --- a/src/mesa/drivers/dri/i965/brw_state_upload.c +++ b/src/mesa/drivers/dri/i965/brw_state_upload.c @@ -418,6 +418,8 @@ brw_upload_programs(struct brw_context *brw, brw_upload_clip_prog(brw); brw_upload_sf_prog(brw); } + + brw_disk_cache_write_program(brw); } else if (pipeline == BRW_COMPUTE_PIPELINE) { brw_upload_cs_prog(brw); } diff --git a/src/mesa/drivers/dri/i965/brw_vs.c b/src/mesa/drivers/dri/i965/brw_vs.c index de0ba79f357..a56b256bc38 100644 --- a/src/mesa/drivers/dri/i965/brw_vs.c +++ b/src/mesa/drivers/dri/i965/brw_vs.c @@ -342,13 +342,19 @@ brw_upload_vs_prog(struct brw_context *brw) brw_vs_populate_key(brw, &key); - if (!brw_search_cache(&brw->cache, BRW_CACHE_VS_PROG, - &key, sizeof(key), - &brw->vs.base.prog_offset, &brw->vs.base.prog_data)) { - bool success = brw_codegen_vs_prog(brw, vp, &key); - (void) success; - assert(success); - } + if (brw_search_cache(&brw->cache, BRW_CACHE_VS_PROG, + &key, sizeof(key), + &brw->vs.base.prog_offset, &brw->vs.base.prog_data)) + return; + + if (brw_disk_cache_upload_program(brw, MESA_SHADER_VERTEX)) + return; + + vp = (struct brw_program *) brw->programs[MESA_SHADER_VERTEX]; + vp->id = key.program_string_id; + + MAYBE_UNUSED bool success = brw_codegen_vs_prog(brw, vp, &key); + assert(success); } bool diff --git a/src/mesa/drivers/dri/i965/brw_wm.c b/src/mesa/drivers/dri/i965/brw_wm.c index 34a3a1e5c16..08bacebd571 100644 --- a/src/mesa/drivers/dri/i965/brw_wm.c +++ b/src/mesa/drivers/dri/i965/brw_wm.c @@ -595,15 +595,21 @@ brw_upload_wm_prog(struct brw_context *brw) brw_wm_populate_key(brw, &key); - if (!brw_search_cache(&brw->cache, BRW_CACHE_FS_PROG, - &key, sizeof(key), - &brw->wm.base.prog_offset, - &brw->wm.base.prog_data)) { - bool success = brw_codegen_wm_prog(brw, fp, &key, - &brw->vue_map_geom_out); - (void) success; - assert(success); - } + if (brw_search_cache(&brw->cache, BRW_CACHE_FS_PROG, + &key, sizeof(key), + &brw->wm.base.prog_offset, + &brw->wm.base.prog_data)) + return; + + if (brw_disk_cache_upload_program(brw, MESA_SHADER_FRAGMENT)) + return; + + fp = (struct brw_program *) brw->programs[MESA_SHADER_FRAGMENT]; + fp->id = key.program_string_id; + + MAYBE_UNUSED bool success = brw_codegen_wm_prog(brw, fp, &key, + &brw->vue_map_geom_out); + assert(success); } bool |