mirror of
git://nv-tegra.nvidia.com/linux-nvgpu.git
synced 2025-12-23 09:57:08 +03:00
Clean up gk20a.c by removing direct accesses to MC and moving the accesses to happen via MC HAL. The chip detection logic has to violate the HAL and call gk20a version directly, because HAL ops cannot be set up before chip has been identified. Change-Id: I4cdd0ef3fcf7d3b561a3fca4247a8356fe8d18e1 Signed-off-by: Terje Bergstrom <tbergstrom@nvidia.com> Reviewed-on: http://git-master/r/1321576 Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com> Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
36 lines
1.2 KiB
C
36 lines
1.2 KiB
C
/*
|
|
* GK20A memory interface
|
|
*
|
|
* Copyright (c) 2014-2017, NVIDIA CORPORATION. All rights reserved.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*/
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include "gk20a/gk20a.h"
|
|
#include "gk20a/mc_gk20a.h"
|
|
#include "mc_gm20b.h"
|
|
|
|
void gm20b_init_mc(struct gpu_ops *gops)
|
|
{
|
|
gops->mc.intr_enable = mc_gk20a_intr_enable;
|
|
gops->mc.intr_unit_config = mc_gk20a_intr_unit_config;
|
|
gops->mc.isr_stall = mc_gk20a_isr_stall;
|
|
gops->mc.isr_nonstall = mc_gk20a_isr_nonstall;
|
|
gops->mc.isr_thread_stall = mc_gk20a_intr_thread_stall;
|
|
gops->mc.isr_thread_nonstall = mc_gk20a_intr_thread_nonstall;
|
|
gops->mc.isr_nonstall_cb = mc_gk20a_nonstall_cb;
|
|
gops->mc.enable = gk20a_mc_enable;
|
|
gops->mc.disable = gk20a_mc_disable;
|
|
gops->mc.reset = gk20a_mc_reset;
|
|
gops->mc.boot_0 = gk20a_mc_boot_0;
|
|
}
|