*    Thomas Hellstrom <thomas-at-tungstengraphics-dot-com>
   *    Dave Airlie
   */
+ 
+ #include <linux/dma-mapping.h>
+ #include <linux/iommu.h>
++#include <linux/hmm.h>
+ #include <linux/pagemap.h>
+ #include <linux/sched/task.h>
+ #include <linux/seq_file.h>
+ #include <linux/slab.h>
+ #include <linux/swap.h>
+ #include <linux/swiotlb.h>
+ 
  #include <drm/ttm/ttm_bo_api.h>
  #include <drm/ttm/ttm_bo_driver.h>
  #include <drm/ttm/ttm_placement.h>
  #include <drm/ttm/ttm_module.h>
  #include <drm/ttm/ttm_page_alloc.h>
- #include <drm/drmP.h>
+ 
+ #include <drm/drm_debugfs.h>
  #include <drm/amdgpu_drm.h>
- #include <linux/seq_file.h>
- #include <linux/slab.h>
- #include <linux/swiotlb.h>
- #include <linux/swap.h>
- #include <linux/pagemap.h>
- #include <linux/debugfs.h>
- #include <linux/iommu.h>
- #include <linux/hmm.h>
++
  #include "amdgpu.h"
  #include "amdgpu_object.h"
  #include "amdgpu_trace.h"
 
--- /dev/null
 +/*
 + * Copyright 2012-16 Advanced Micro Devices, Inc.
 + *
 + * Permission is hereby granted, free of charge, to any person obtaining a
 + * copy of this software and associated documentation files (the "Software"),
 + * to deal in the Software without restriction, including without limitation
 + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 + * and/or sell copies of the Software, and to permit persons to whom the
 + * Software is furnished to do so, subject to the following conditions:
 + *
 + * The above copyright notice and this permission notice shall be included in
 + * all copies or substantial portions of the Software.
 + *
 + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
 + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
 + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 + * OTHER DEALINGS IN THE SOFTWARE.
 + *
 + * Authors: AMD
 + *
 + */
 +
++#include <linux/slab.h>
++
 +#include "dal_asic_id.h"
 +#include "dc_types.h"
 +#include "dccg.h"
 +#include "clk_mgr_internal.h"
 +
 +#include "dce100/dce_clk_mgr.h"
 +#include "dce110/dce110_clk_mgr.h"
 +#include "dce112/dce112_clk_mgr.h"
 +#include "dce120/dce120_clk_mgr.h"
 +#include "dcn10/rv1_clk_mgr.h"
 +#include "dcn10/rv2_clk_mgr.h"
 +
 +
 +int clk_mgr_helper_get_active_display_cnt(
 +              struct dc *dc,
 +              struct dc_state *context)
 +{
 +      int i, display_count;
 +
 +      display_count = 0;
 +      for (i = 0; i < context->stream_count; i++) {
 +              const struct dc_stream_state *stream = context->streams[i];
 +
 +              /*
 +               * Only notify active stream or virtual stream.
 +               * Need to notify virtual stream to work around
 +               * headless case. HPD does not fire when system is in
 +               * S0i2.
 +               */
 +              if (!stream->dpms_off || stream->signal == SIGNAL_TYPE_VIRTUAL)
 +                      display_count++;
 +      }
 +
 +      return display_count;
 +}
 +
 +
 +struct clk_mgr *dc_clk_mgr_create(struct dc_context *ctx, struct pp_smu_funcs *pp_smu, struct dccg *dccg)
 +{
 +      struct hw_asic_id asic_id = ctx->asic_id;
 +
 +      struct clk_mgr_internal *clk_mgr = kzalloc(sizeof(*clk_mgr), GFP_KERNEL);
 +
 +      if (clk_mgr == NULL) {
 +              BREAK_TO_DEBUGGER();
 +              return NULL;
 +      }
 +
 +      switch (asic_id.chip_family) {
 +      case FAMILY_CI:
 +      case FAMILY_KV:
 +              dce_clk_mgr_construct(ctx, clk_mgr);
 +              break;
 +      case FAMILY_CZ:
 +              dce110_clk_mgr_construct(ctx, clk_mgr);
 +              break;
 +      case FAMILY_VI:
 +              if (ASIC_REV_IS_TONGA_P(asic_id.hw_internal_rev) ||
 +                              ASIC_REV_IS_FIJI_P(asic_id.hw_internal_rev)) {
 +                      dce_clk_mgr_construct(ctx, clk_mgr);
 +                      break;
 +              }
 +              if (ASIC_REV_IS_POLARIS10_P(asic_id.hw_internal_rev) ||
 +                              ASIC_REV_IS_POLARIS11_M(asic_id.hw_internal_rev) ||
 +                              ASIC_REV_IS_POLARIS12_V(asic_id.hw_internal_rev)) {
 +                      dce112_clk_mgr_construct(ctx, clk_mgr);
 +                      break;
 +              }
 +              if (ASIC_REV_IS_VEGAM(asic_id.hw_internal_rev)) {
 +                      dce112_clk_mgr_construct(ctx, clk_mgr);
 +                      break;
 +              }
 +              break;
 +      case FAMILY_AI:
 +              if (ASICREV_IS_VEGA20_P(asic_id.hw_internal_rev))
 +                      dce121_clk_mgr_construct(ctx, clk_mgr);
 +              else
 +                      dce120_clk_mgr_construct(ctx, clk_mgr);
 +              break;
 +
 +#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
 +      case FAMILY_RV:
 +              if (ASICREV_IS_RAVEN2(asic_id.hw_internal_rev)) {
 +                      rv2_clk_mgr_construct(ctx, clk_mgr, pp_smu);
 +                      break;
 +              }
 +              if (ASICREV_IS_RAVEN(asic_id.hw_internal_rev) ||
 +                              ASICREV_IS_PICASSO(asic_id.hw_internal_rev)) {
 +                      rv1_clk_mgr_construct(ctx, clk_mgr, pp_smu);
 +                      break;
 +              }
 +              break;
 +#endif        /* Family RV */
 +
 +      default:
 +              ASSERT(0); /* Unknown Asic */
 +              break;
 +      }
 +
 +      return &clk_mgr->base;
 +}
 +
 +void dc_destroy_clk_mgr(struct clk_mgr *clk_mgr_base)
 +{
 +      struct clk_mgr_internal *clk_mgr = TO_CLK_MGR_INTERNAL(clk_mgr_base);
 +
 +      kfree(clk_mgr);
 +}
 +
 
   *
   */
  
 -#include "dcn10_clk_mgr.h"
 -
+ #include <linux/slab.h>
+ 
+ #include "reg_helper.h"
  #include "core_types.h"
 -
 -#define TO_DCE_CLK_MGR(clocks)\
 -      container_of(clocks, struct dce_clk_mgr, base)
 -
 -#define REG(reg) \
 -      (clk_mgr_dce->regs->reg)
 -
 -#undef FN
 -#define FN(reg_name, field_name) \
 -      clk_mgr_dce->clk_mgr_shift->field_name, clk_mgr_dce->clk_mgr_mask->field_name
 -
 -#define CTX \
 -      clk_mgr_dce->base.ctx
 -#define DC_LOGGER \
 -      clk_mgr->ctx->logger
 -
 -static int dcn1_determine_dppclk_threshold(struct clk_mgr *clk_mgr, struct dc_clocks *new_clocks)
 +#include "clk_mgr_internal.h"
 +#include "rv1_clk_mgr.h"
 +#include "dce100/dce_clk_mgr.h"
 +#include "dce112/dce112_clk_mgr.h"
 +#include "rv1_clk_mgr_vbios_smu.h"
 +#include "rv1_clk_mgr_clk.h"
 +
 +static int rv1_determine_dppclk_threshold(struct clk_mgr_internal *clk_mgr, struct dc_clocks *new_clocks)
  {
        bool request_dpp_div = new_clocks->dispclk_khz > new_clocks->dppclk_khz;
 -      bool dispclk_increase = new_clocks->dispclk_khz > clk_mgr->clks.dispclk_khz;
 +      bool dispclk_increase = new_clocks->dispclk_khz > clk_mgr->base.clks.dispclk_khz;
        int disp_clk_threshold = new_clocks->max_supported_dppclk_khz;
 -      bool cur_dpp_div = clk_mgr->clks.dispclk_khz > clk_mgr->clks.dppclk_khz;
 +      bool cur_dpp_div = clk_mgr->base.clks.dispclk_khz > clk_mgr->base.clks.dppclk_khz;
  
        /* increase clock, looking for div is 0 for current, request div is 1*/
        if (dispclk_increase) {