diff options
| author | 2016-12-01 09:25:58 +1000 | |
|---|---|---|
| committer | 2016-12-01 09:25:58 +1000 | |
| commit | f5590134365f6f23dba723f140f72effcc71773f (patch) | |
| tree | 2094f339374fa0b37b22f33a9f40950de8950def /drivers/gpu/drm/msm/msm_gpu.c | |
| parent | Merge tag 'drm-misc-next-2016-11-29' of git://anongit.freedesktop.org/git/drm-misc into drm-next (diff) | |
| parent | drm/msm: gpu: Add support for the GPMU (diff) | |
| download | linux-dev-f5590134365f6f23dba723f140f72effcc71773f.tar.xz linux-dev-f5590134365f6f23dba723f140f72effcc71773f.zip | |
Merge branch 'msm-next' of git://people.freedesktop.org/~robclark/linux into drm-next
On the userspace side, all the basics are working, and most of glmark2
is working.  I've been working through deqp, and I've got a couple more
things to fix (but we've gone from 70% to 80+% pass in last day, and
current deqp run that is going should pick up another 5-10%).  I expect
to push the mesa patches today or tomorrow.
There are a couple more a5xx related patches to take the gpu out of
secure mode (for the devices that come up in secure mode, like the hw
I have), but those depend on an scm patch that would come in through
another tree.  If that can land in the next day or two, there might
be a second late pull request for drm/msm.
In addition to the new-shiny, there have also been a lot of overlay/
plane related fixes for issues found using drm-hwc2 (in the process of
testing/debugging the atomic/kms fence patches), resulting in rework
to assign hwpipes to kms planes dynamically (as part of global atomic
state) and also handling SMP (fifo) block allocation atomically as
part of the ->atomic_check() step.  All those patches should also help
out atomic weston (when those patches eventually land).
* 'msm-next' of git://people.freedesktop.org/~robclark/linux: (36 commits)
  drm/msm: gpu: Add support for the GPMU
  drm/msm: gpu: Add A5XX target support
  drm/msm: Disable interrupts during init
  drm/msm: Remove 'src_clk' from adreno configuration
  drm/msm: gpu: Add OUT_TYPE4 and OUT_TYPE7
  drm/msm: Add adreno_gpu_write64()
  drm/msm: gpu Add new gpu register read/write functions
  drm/msm: gpu: Return error on hw_init failure
  drm/msm: gpu: Cut down the list of "generic" registers to the ones we use
  drm/msm: update generated headers
  drm/msm/adreno: move scratch register dumping to per-gen code
  drm/msm/rd: support for 64b iova
  drm/msm: convert iova to 64b
  drm/msm: set dma_mask properly
  drm/msm: Remove bad calls to of_node_put()
  drm/msm/mdp5: move LM bounds check into plane->atomic_check()
  drm/msm/mdp5: dump smp state on errors too
  drm/msm/mdp5: add debugfs to show smp block status
  drm/msm/mdp5: handle SMP block allocations "atomically"
  drm/msm/mdp5: dynamically assign hw pipes to planes
  ...
Diffstat (limited to 'drivers/gpu/drm/msm/msm_gpu.c')
| -rw-r--r-- | drivers/gpu/drm/msm/msm_gpu.c | 66 | 
1 files changed, 34 insertions, 32 deletions
| diff --git a/drivers/gpu/drm/msm/msm_gpu.c b/drivers/gpu/drm/msm/msm_gpu.c index 3249707e6834..b28527a65d09 100644 --- a/drivers/gpu/drm/msm/msm_gpu.c +++ b/drivers/gpu/drm/msm/msm_gpu.c @@ -91,21 +91,20 @@ static int disable_pwrrail(struct msm_gpu *gpu)  static int enable_clk(struct msm_gpu *gpu)  { -	struct clk *rate_clk = NULL;  	int i; -	/* NOTE: kgsl_pwrctrl_clk() ignores grp_clks[0].. */ -	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i > 0; i--) { -		if (gpu->grp_clks[i]) { -			clk_prepare(gpu->grp_clks[i]); -			rate_clk = gpu->grp_clks[i]; -		} -	} +	if (gpu->grp_clks[0] && gpu->fast_rate) +		clk_set_rate(gpu->grp_clks[0], gpu->fast_rate); -	if (rate_clk && gpu->fast_rate) -		clk_set_rate(rate_clk, gpu->fast_rate); +	/* Set the RBBM timer rate to 19.2Mhz */ +	if (gpu->grp_clks[2]) +		clk_set_rate(gpu->grp_clks[2], 19200000); -	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i > 0; i--) +	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i >= 0; i--) +		if (gpu->grp_clks[i]) +			clk_prepare(gpu->grp_clks[i]); + +	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i >= 0; i--)  		if (gpu->grp_clks[i])  			clk_enable(gpu->grp_clks[i]); @@ -114,24 +113,22 @@ static int enable_clk(struct msm_gpu *gpu)  static int disable_clk(struct msm_gpu *gpu)  { -	struct clk *rate_clk = NULL;  	int i; -	/* NOTE: kgsl_pwrctrl_clk() ignores grp_clks[0].. */ -	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i > 0; i--) { -		if (gpu->grp_clks[i]) { +	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i >= 0; i--) +		if (gpu->grp_clks[i])  			clk_disable(gpu->grp_clks[i]); -			rate_clk = gpu->grp_clks[i]; -		} -	} - -	if (rate_clk && gpu->slow_rate) -		clk_set_rate(rate_clk, gpu->slow_rate); -	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i > 0; i--) +	for (i = ARRAY_SIZE(gpu->grp_clks) - 1; i >= 0; i--)  		if (gpu->grp_clks[i])  			clk_unprepare(gpu->grp_clks[i]); +	if (gpu->grp_clks[0] && gpu->slow_rate) +		clk_set_rate(gpu->grp_clks[0], gpu->slow_rate); + +	if (gpu->grp_clks[2]) +		clk_set_rate(gpu->grp_clks[2], 0); +  	return 0;  } @@ -528,7 +525,7 @@ void msm_gpu_submit(struct msm_gpu *gpu, struct msm_gem_submit *submit,  	for (i = 0; i < submit->nr_bos; i++) {  		struct msm_gem_object *msm_obj = submit->bos[i].obj; -		uint32_t iova; +		uint64_t iova;  		/* can't happen yet.. but when we add 2d support we'll have  		 * to deal w/ cross-ring synchronization: @@ -563,8 +560,8 @@ static irqreturn_t irq_handler(int irq, void *data)  }  static const char *clk_names[] = { -		"src_clk", "core_clk", "iface_clk", "mem_clk", "mem_iface_clk", -		"alt_mem_iface_clk", +		"core_clk", "iface_clk", "rbbmtimer_clk", "mem_clk", +		"mem_iface_clk", "alt_mem_iface_clk",  };  int msm_gpu_init(struct drm_device *drm, struct platform_device *pdev, @@ -656,12 +653,17 @@ int msm_gpu_init(struct drm_device *drm, struct platform_device *pdev,  	 */  	iommu = iommu_domain_alloc(&platform_bus_type);  	if (iommu) { +		/* TODO 32b vs 64b address space.. */ +		iommu->geometry.aperture_start = SZ_16M; +		iommu->geometry.aperture_end = 0xffffffff; +  		dev_info(drm->dev, "%s: using IOMMU\n", name); -		gpu->mmu = msm_iommu_new(&pdev->dev, iommu); -		if (IS_ERR(gpu->mmu)) { -			ret = PTR_ERR(gpu->mmu); +		gpu->aspace = msm_gem_address_space_create(&pdev->dev, +				iommu, "gpu"); +		if (IS_ERR(gpu->aspace)) { +			ret = PTR_ERR(gpu->aspace);  			dev_err(drm->dev, "failed to init iommu: %d\n", ret); -			gpu->mmu = NULL; +			gpu->aspace = NULL;  			iommu_domain_free(iommu);  			goto fail;  		} @@ -669,7 +671,7 @@ int msm_gpu_init(struct drm_device *drm, struct platform_device *pdev,  	} else {  		dev_info(drm->dev, "%s: no IOMMU, fallback to VRAM carveout!\n", name);  	} -	gpu->id = msm_register_mmu(drm, gpu->mmu); +	gpu->id = msm_register_address_space(drm, gpu->aspace);  	/* Create ringbuffer: */ @@ -705,8 +707,8 @@ void msm_gpu_cleanup(struct msm_gpu *gpu)  		msm_ringbuffer_destroy(gpu->rb);  	} -	if (gpu->mmu) -		gpu->mmu->funcs->destroy(gpu->mmu); +	if (gpu->aspace) +		msm_gem_address_space_destroy(gpu->aspace);  	if (gpu->fctx)  		msm_fence_context_free(gpu->fctx); | 
