diff options
Diffstat (limited to 'drivers/gpu/nvgpu/gv11b')
-rw-r--r-- | drivers/gpu/nvgpu/gv11b/fifo_gv11b.c | 63 | ||||
-rw-r--r-- | drivers/gpu/nvgpu/gv11b/hw_ram_gv11b.h | 46 |
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 | |||
27 | static 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 | |||
53 | static 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 | ||
25 | void gv11b_init_fifo(struct gpu_ops *gops) | 85 | void 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 | } |
465 | static inline u32 ram_rl_entry_chan_inst_target_target_sys_mem_ncoh_v(void) | 465 | static 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 | } |
473 | static inline u32 ram_rl_entry_chan_userd_target_target_vid_mem_v(void) | 473 | static inline u32 ram_rl_entry_chan_userd_target_vid_mem_v(void) |
474 | { | 474 | { |
475 | return 0x00000000; | 475 | return 0x00000000; |
476 | } | 476 | } |
477 | static inline u32 ram_rl_entry_chan_userd_target_target_vid_mem_nvlink_coh_v(void) | 477 | static inline u32 ram_rl_entry_chan_userd_target_vid_mem_nvlink_coh_v(void) |
478 | { | 478 | { |
479 | return 0x00000001; | 479 | return 0x00000001; |
480 | } | 480 | } |
481 | static inline u32 ram_rl_entry_chan_userd_target_target_sys_mem_coh_v(void) | 481 | static inline u32 ram_rl_entry_chan_userd_target_sys_mem_coh_v(void) |
482 | { | 482 | { |
483 | return 0x00000002; | 483 | return 0x00000002; |
484 | } | 484 | } |
485 | static inline u32 ram_rl_entry_chan_userd_target_target_sys_mem_ncoh_v(void) | 485 | static 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 | } |
497 | static inline u32 ram_rl_entry_chan_userd_ptr_hi_entry_chan_inst_ptr_align_shift_v(void) | ||
498 | { | ||
499 | return 0x0000000c; | ||
500 | } | ||
501 | static inline u32 ram_rl_entry_chan_userd_ptr_hi_entry_chan_userd_ptr_align_shift_v(void) | ||
502 | { | ||
503 | return 0x00000008; | ||
504 | } | ||
505 | static inline u32 ram_rl_entry_chan_userd_ptr_hi_entry_chan_userd_align_shift_v(void) | ||
506 | { | ||
507 | return 0x00000008; | ||
508 | } | ||
509 | static inline u32 ram_rl_entry_chid_f(u32 v) | 497 | static 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 | } |
529 | static inline u32 ram_rl_entry_tsg_timeslice_scale_entry_tsg_timeslice_scale_3_v(void) | 517 | static 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 | } |
537 | static inline u32 ram_rl_entry_tsg_timeslice_timeout_entry_tsg_timeslice_timeout_128_v(void) | 525 | static inline u32 ram_rl_entry_tsg_timeslice_timeout_128_v(void) |
538 | { | 526 | { |
539 | return 0x00000080; | 527 | return 0x00000080; |
540 | } | 528 | } |
541 | static inline u32 ram_rl_entry_tsg_timeslice_timeout_entry_tsg_timeslice_timeout_disable_v(void) | 529 | static 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 | } |
549 | static inline u32 ram_rl_entry_tsg_length_entry_tsg_length_init_v(void) | 537 | static inline u32 ram_rl_entry_tsg_length_init_v(void) |
550 | { | 538 | { |
551 | return 0x00000000; | 539 | return 0x00000000; |
552 | } | 540 | } |
553 | static inline u32 ram_rl_entry_tsg_length_entry_tsg_length_min_v(void) | 541 | static inline u32 ram_rl_entry_tsg_length_min_v(void) |
554 | { | 542 | { |
555 | return 0x00000001; | 543 | return 0x00000001; |
556 | } | 544 | } |
557 | static inline u32 ram_rl_entry_tsg_length_entry_tsg_length_max_v(void) | 545 | static 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 | } |
553 | static inline u32 ram_rl_entry_chan_inst_ptr_align_shift_v(void) | ||
554 | { | ||
555 | return 0x0000000c; | ||
556 | } | ||
557 | static inline u32 ram_rl_entry_chan_userd_ptr_align_shift_v(void) | ||
558 | { | ||
559 | return 0x00000008; | ||
560 | } | ||
561 | static inline u32 ram_rl_entry_chan_userd_align_shift_v(void) | ||
562 | { | ||
563 | return 0x00000008; | ||
564 | } | ||
565 | #endif | 565 | #endif |