mirror of https://gitee.com/openkylin/linux.git
drm/i915: s/for_each_sgt_dma/for_each_sgt_daddr/
The sg_table for our backing store might contain addresses from stolen-memory or in the future local-memory, at which point this is no longer a dma-iterator. As a consequence we should now break on NULL iter.sgp, instead of dmap == 0 which is considered an invalid dma address. As a bonus, gcc much prefers this construct, Function old new delta gen8_ggtt_insert_entries 211 192 -19 gen6_ggtt_insert_entries 292 262 -30 i915_error_object_create 996 954 -42 Signed-off-by: Matthew Auld <matthew.auld@intel.com> Cc: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Link: https://patchwork.freedesktop.org/patch/msgid/20190829201919.21493-1-matthew.auld@intel.com
This commit is contained in:
parent
9be02fde93
commit
31444afb46
|
@ -2208,7 +2208,7 @@ static void gen8_ggtt_insert_entries(struct i915_address_space *vm,
|
||||||
|
|
||||||
gtt_entries = (gen8_pte_t __iomem *)ggtt->gsm;
|
gtt_entries = (gen8_pte_t __iomem *)ggtt->gsm;
|
||||||
gtt_entries += vma->node.start / I915_GTT_PAGE_SIZE;
|
gtt_entries += vma->node.start / I915_GTT_PAGE_SIZE;
|
||||||
for_each_sgt_dma(addr, sgt_iter, vma->pages)
|
for_each_sgt_daddr(addr, sgt_iter, vma->pages)
|
||||||
gen8_set_pte(gtt_entries++, pte_encode | addr);
|
gen8_set_pte(gtt_entries++, pte_encode | addr);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -2249,7 +2249,7 @@ static void gen6_ggtt_insert_entries(struct i915_address_space *vm,
|
||||||
unsigned int i = vma->node.start / I915_GTT_PAGE_SIZE;
|
unsigned int i = vma->node.start / I915_GTT_PAGE_SIZE;
|
||||||
struct sgt_iter iter;
|
struct sgt_iter iter;
|
||||||
dma_addr_t addr;
|
dma_addr_t addr;
|
||||||
for_each_sgt_dma(addr, iter, vma->pages)
|
for_each_sgt_daddr(addr, iter, vma->pages)
|
||||||
iowrite32(vm->pte_encode(addr, level, flags), &entries[i++]);
|
iowrite32(vm->pte_encode(addr, level, flags), &entries[i++]);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -148,8 +148,8 @@ typedef u64 gen8_pte_t;
|
||||||
#define GEN8_PDE_IPS_64K BIT(11)
|
#define GEN8_PDE_IPS_64K BIT(11)
|
||||||
#define GEN8_PDE_PS_2M BIT(7)
|
#define GEN8_PDE_PS_2M BIT(7)
|
||||||
|
|
||||||
#define for_each_sgt_dma(__dmap, __iter, __sgt) \
|
#define for_each_sgt_daddr(__dp, __iter, __sgt) \
|
||||||
__for_each_sgt_dma(__dmap, __iter, __sgt, I915_GTT_PAGE_SIZE)
|
__for_each_sgt_daddr(__dp, __iter, __sgt, I915_GTT_PAGE_SIZE)
|
||||||
|
|
||||||
struct intel_remapped_plane_info {
|
struct intel_remapped_plane_info {
|
||||||
/* in gtt pages */
|
/* in gtt pages */
|
||||||
|
|
|
@ -990,7 +990,7 @@ i915_error_object_create(struct drm_i915_private *i915,
|
||||||
dst->unused = 0;
|
dst->unused = 0;
|
||||||
|
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
for_each_sgt_dma(dma, iter, vma->pages) {
|
for_each_sgt_daddr(dma, iter, vma->pages) {
|
||||||
void __iomem *s;
|
void __iomem *s;
|
||||||
|
|
||||||
ggtt->vm.insert_page(&ggtt->vm, dma, slot, I915_CACHE_NONE, 0);
|
ggtt->vm.insert_page(&ggtt->vm, dma, slot, I915_CACHE_NONE, 0);
|
||||||
|
|
|
@ -67,15 +67,15 @@ static inline struct scatterlist *__sg_next(struct scatterlist *sg)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* __for_each_sgt_dma - iterate over the DMA addresses of the given sg_table
|
* __for_each_sgt_daddr - iterate over the device addresses of the given sg_table
|
||||||
* @__dmap: DMA address (output)
|
* @__dp: Device address (output)
|
||||||
* @__iter: 'struct sgt_iter' (iterator state, internal)
|
* @__iter: 'struct sgt_iter' (iterator state, internal)
|
||||||
* @__sgt: sg_table to iterate over (input)
|
* @__sgt: sg_table to iterate over (input)
|
||||||
* @__step: step size
|
* @__step: step size
|
||||||
*/
|
*/
|
||||||
#define __for_each_sgt_dma(__dmap, __iter, __sgt, __step) \
|
#define __for_each_sgt_daddr(__dp, __iter, __sgt, __step) \
|
||||||
for ((__iter) = __sgt_iter((__sgt)->sgl, true); \
|
for ((__iter) = __sgt_iter((__sgt)->sgl, true); \
|
||||||
((__dmap) = (__iter).dma + (__iter).curr); \
|
((__dp) = (__iter).dma + (__iter).curr), (__iter).sgp; \
|
||||||
(((__iter).curr += (__step)) >= (__iter).max) ? \
|
(((__iter).curr += (__step)) >= (__iter).max) ? \
|
||||||
(__iter) = __sgt_iter(__sg_next((__iter).sgp), true), 0 : 0)
|
(__iter) = __sgt_iter(__sg_next((__iter).sgp), true), 0 : 0)
|
||||||
|
|
||||||
|
|
|
@ -623,7 +623,7 @@ static bool assert_partial(struct drm_i915_gem_object *obj,
|
||||||
struct sgt_iter sgt;
|
struct sgt_iter sgt;
|
||||||
dma_addr_t dma;
|
dma_addr_t dma;
|
||||||
|
|
||||||
for_each_sgt_dma(dma, sgt, vma->pages) {
|
for_each_sgt_daddr(dma, sgt, vma->pages) {
|
||||||
dma_addr_t src;
|
dma_addr_t src;
|
||||||
|
|
||||||
if (!size) {
|
if (!size) {
|
||||||
|
|
Loading…
Reference in New Issue