summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/nvgpu/gv11b
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/nvgpu/gv11b')
-rw-r--r--drivers/gpu/nvgpu/gv11b/fifo_gv11b.c63
-rw-r--r--drivers/gpu/nvgpu/gv11b/hw_ram_gv11b.h46
2 files changed, 86 insertions, 23 deletions
diff --git a/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c b/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
index af5f094d..35b36ec5 100644
--- a/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
+++ b/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
@@ -21,8 +21,71 @@
21#include "hw_pbdma_gv11b.h" 21#include "hw_pbdma_gv11b.h"
22#include "fifo_gv11b.h" 22#include "fifo_gv11b.h"
23#include "hw_fifo_gv11b.h" 23#include "hw_fifo_gv11b.h"
24#include "hw_ram_gv11b.h"
25#include "hw_ccsr_gv11b.h"
26
27static void gv11b_get_tsg_runlist_entry(struct tsg_gk20a *tsg, u32 *runlist)
28{
29
30 u32 runlist_entry_0 = ram_rl_entry_type_tsg_v();
31
32 if (tsg->timeslice_timeout)
33 runlist_entry_0 |=
34 ram_rl_entry_tsg_timeslice_scale_f(tsg->timeslice_scale) |
35 ram_rl_entry_tsg_timeslice_timeout_f(tsg->timeslice_timeout);
36 else
37 runlist_entry_0 |=
38 ram_rl_entry_tsg_timeslice_scale_f(
39 ram_rl_entry_tsg_timeslice_scale_3_v()) |
40 ram_rl_entry_tsg_timeslice_timeout_f(
41 ram_rl_entry_tsg_timeslice_timeout_128_v());
42
43 runlist[0] = runlist_entry_0;
44 runlist[1] = ram_rl_entry_tsg_length_f(tsg->num_active_channels);
45 runlist[2] = ram_rl_entry_tsg_tsgid_f(tsg->tsgid);
46 runlist[3] = 0;
47
48 gk20a_dbg_info("gv11b tsg runlist [0] %x [1] %x [2] %x [3] %x\n",
49 runlist[0], runlist[1], runlist[2], runlist[3]);
50
51}
52
53static void gv11b_get_ch_runlist_entry(struct channel_gk20a *c, u32 *runlist)
54{
55 struct gk20a *g = c->g;
56 u32 addr_lo, addr_hi;
57 u32 runlist_entry;
58
59 /* Time being use 0 pbdma sequencer */
60 runlist_entry = ram_rl_entry_type_channel_v() |
61 ram_rl_entry_chan_runqueue_selector_f(0) |
62 ram_rl_entry_chan_userd_target_f(
63 ram_rl_entry_chan_userd_target_sys_mem_ncoh_v()) |
64 ram_rl_entry_chan_inst_target_f(
65 ram_rl_entry_chan_userd_target_sys_mem_ncoh_v());
66
67 addr_lo = u64_lo32(c->userd_iova) >>
68 ram_rl_entry_chan_userd_ptr_align_shift_v();
69 addr_hi = u64_hi32(c->userd_iova);
70 runlist[0] = runlist_entry | ram_rl_entry_chan_userd_ptr_lo_f(addr_lo);
71 runlist[1] = ram_rl_entry_chan_userd_ptr_hi_f(addr_hi);
72
73 addr_lo = u64_lo32(gk20a_mm_inst_block_addr(g, &c->inst_block)) >>
74 ram_rl_entry_chan_inst_ptr_align_shift_v();
75 addr_hi = u64_hi32(gk20a_mm_inst_block_addr(g, &c->inst_block));
76
77 runlist[2] = ram_rl_entry_chan_inst_ptr_lo_f(addr_lo) |
78 ram_rl_entry_chid_f(c->hw_chid);
79 runlist[3] = ram_rl_entry_chan_inst_ptr_hi_f(addr_hi);
80
81 gk20a_dbg_info("gv11b channel runlist [0] %x [1] %x [2] %x [3] %x\n",
82 runlist[0], runlist[1], runlist[2], runlist[3]);
83}
24 84
25void gv11b_init_fifo(struct gpu_ops *gops) 85void gv11b_init_fifo(struct gpu_ops *gops)
26{ 86{
27 gp10b_init_fifo(gops); 87 gp10b_init_fifo(gops);
88 gops->fifo.runlist_entry_size = ram_rl_entry_size_v;
89 gops->fifo.get_tsg_runlist_entry = gv11b_get_tsg_runlist_entry;
90 gops->fifo.get_ch_runlist_entry = gv11b_get_ch_runlist_entry;
28} 91}
diff --git a/drivers/gpu/nvgpu/gv11b/hw_ram_gv11b.h b/drivers/gpu/nvgpu/gv11b/hw_ram_gv11b.h
index c6f51acb..9cd2096a 100644
--- a/drivers/gpu/nvgpu/gv11b/hw_ram_gv11b.h
+++ b/drivers/gpu/nvgpu/gv11b/hw_ram_gv11b.h
@@ -462,7 +462,7 @@ static inline u32 ram_rl_entry_chan_inst_target_f(u32 v)
462{ 462{
463 return (v & 0x3) << 4; 463 return (v & 0x3) << 4;
464} 464}
465static inline u32 ram_rl_entry_chan_inst_target_target_sys_mem_ncoh_v(void) 465static inline u32 ram_rl_entry_chan_inst_target_sys_mem_ncoh_v(void)
466{ 466{
467 return 0x00000003; 467 return 0x00000003;
468} 468}
@@ -470,19 +470,19 @@ static inline u32 ram_rl_entry_chan_userd_target_f(u32 v)
470{ 470{
471 return (v & 0x3) << 6; 471 return (v & 0x3) << 6;
472} 472}
473static inline u32 ram_rl_entry_chan_userd_target_target_vid_mem_v(void) 473static inline u32 ram_rl_entry_chan_userd_target_vid_mem_v(void)
474{ 474{
475 return 0x00000000; 475 return 0x00000000;
476} 476}
477static inline u32 ram_rl_entry_chan_userd_target_target_vid_mem_nvlink_coh_v(void) 477static inline u32 ram_rl_entry_chan_userd_target_vid_mem_nvlink_coh_v(void)
478{ 478{
479 return 0x00000001; 479 return 0x00000001;
480} 480}
481static inline u32 ram_rl_entry_chan_userd_target_target_sys_mem_coh_v(void) 481static inline u32 ram_rl_entry_chan_userd_target_sys_mem_coh_v(void)
482{ 482{
483 return 0x00000002; 483 return 0x00000002;
484} 484}
485static inline u32 ram_rl_entry_chan_userd_target_target_sys_mem_ncoh_v(void) 485static inline u32 ram_rl_entry_chan_userd_target_sys_mem_ncoh_v(void)
486{ 486{
487 return 0x00000003; 487 return 0x00000003;
488} 488}
@@ -494,18 +494,6 @@ static inline u32 ram_rl_entry_chan_userd_ptr_hi_f(u32 v)
494{ 494{
495 return (v & 0xffffffff) << 0; 495 return (v & 0xffffffff) << 0;
496} 496}
497static inline u32 ram_rl_entry_chan_userd_ptr_hi_entry_chan_inst_ptr_align_shift_v(void)
498{
499 return 0x0000000c;
500}
501static inline u32 ram_rl_entry_chan_userd_ptr_hi_entry_chan_userd_ptr_align_shift_v(void)
502{
503 return 0x00000008;
504}
505static inline u32 ram_rl_entry_chan_userd_ptr_hi_entry_chan_userd_align_shift_v(void)
506{
507 return 0x00000008;
508}
509static inline u32 ram_rl_entry_chid_f(u32 v) 497static inline u32 ram_rl_entry_chid_f(u32 v)
510{ 498{
511 return (v & 0xfff) << 0; 499 return (v & 0xfff) << 0;
@@ -526,7 +514,7 @@ static inline u32 ram_rl_entry_tsg_timeslice_scale_f(u32 v)
526{ 514{
527 return (v & 0xf) << 16; 515 return (v & 0xf) << 16;
528} 516}
529static inline u32 ram_rl_entry_tsg_timeslice_scale_entry_tsg_timeslice_scale_3_v(void) 517static inline u32 ram_rl_entry_tsg_timeslice_scale_3_v(void)
530{ 518{
531 return 0x00000003; 519 return 0x00000003;
532} 520}
@@ -534,11 +522,11 @@ static inline u32 ram_rl_entry_tsg_timeslice_timeout_f(u32 v)
534{ 522{
535 return (v & 0xff) << 24; 523 return (v & 0xff) << 24;
536} 524}
537static inline u32 ram_rl_entry_tsg_timeslice_timeout_entry_tsg_timeslice_timeout_128_v(void) 525static inline u32 ram_rl_entry_tsg_timeslice_timeout_128_v(void)
538{ 526{
539 return 0x00000080; 527 return 0x00000080;
540} 528}
541static inline u32 ram_rl_entry_tsg_timeslice_timeout_entry_tsg_timeslice_timeout_disable_v(void) 529static inline u32 ram_rl_entry_tsg_timeslice_timeout_disable_v(void)
542{ 530{
543 return 0x00000000; 531 return 0x00000000;
544} 532}
@@ -546,15 +534,15 @@ static inline u32 ram_rl_entry_tsg_length_f(u32 v)
546{ 534{
547 return (v & 0xff) << 0; 535 return (v & 0xff) << 0;
548} 536}
549static inline u32 ram_rl_entry_tsg_length_entry_tsg_length_init_v(void) 537static inline u32 ram_rl_entry_tsg_length_init_v(void)
550{ 538{
551 return 0x00000000; 539 return 0x00000000;
552} 540}
553static inline u32 ram_rl_entry_tsg_length_entry_tsg_length_min_v(void) 541static inline u32 ram_rl_entry_tsg_length_min_v(void)
554{ 542{
555 return 0x00000001; 543 return 0x00000001;
556} 544}
557static inline u32 ram_rl_entry_tsg_length_entry_tsg_length_max_v(void) 545static inline u32 ram_rl_entry_tsg_length_max_v(void)
558{ 546{
559 return 0x00000080; 547 return 0x00000080;
560} 548}
@@ -562,4 +550,16 @@ static inline u32 ram_rl_entry_tsg_tsgid_f(u32 v)
562{ 550{
563 return (v & 0xfff) << 0; 551 return (v & 0xfff) << 0;
564} 552}
553static inline u32 ram_rl_entry_chan_inst_ptr_align_shift_v(void)
554{
555 return 0x0000000c;
556}
557static inline u32 ram_rl_entry_chan_userd_ptr_align_shift_v(void)
558{
559 return 0x00000008;
560}
561static inline u32 ram_rl_entry_chan_userd_align_shift_v(void)
562{
563 return 0x00000008;
564}
565#endif 565#endif