Module Name: src Committed By: riastradh Date: Tue Jul 1 16:29:57 UTC 2014
Modified Files: src/sys/external/bsd/drm2/drm: drm_memory.c Log Message: Honour write-combining flag in drm_ioremap. To generate a diff of this commit: cvs rdiff -u -r1.4 -r1.5 src/sys/external/bsd/drm2/drm/drm_memory.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/external/bsd/drm2/drm/drm_memory.c diff -u src/sys/external/bsd/drm2/drm/drm_memory.c:1.4 src/sys/external/bsd/drm2/drm/drm_memory.c:1.5 --- src/sys/external/bsd/drm2/drm/drm_memory.c:1.4 Thu Jun 12 15:05:29 2014 +++ src/sys/external/bsd/drm2/drm/drm_memory.c Tue Jul 1 16:29:57 2014 @@ -1,4 +1,4 @@ -/* $NetBSD: drm_memory.c,v 1.4 2014/06/12 15:05:29 riastradh Exp $ */ +/* $NetBSD: drm_memory.c,v 1.5 2014/07/01 16:29:57 riastradh Exp $ */ /*- * Copyright (c) 2013 The NetBSD Foundation, Inc. @@ -30,7 +30,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: drm_memory.c,v 1.4 2014/06/12 15:05:29 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: drm_memory.c,v 1.5 2014/07/01 16:29:57 riastradh Exp $"); #ifdef _KERNEL_OPT #include "agp_i810.h" @@ -85,6 +85,7 @@ drm_ioremap(struct drm_device *dev, stru */ for (unit = 0; unit < dev->bus_nmaps; unit++) { struct drm_bus_map *const bm = &dev->bus_maps[unit]; + int flags = bm->bm_flags; /* Reject maps starting after the request. */ if (map->offset < bm->bm_base) @@ -100,12 +101,16 @@ drm_ioremap(struct drm_device *dev, stru continue; /* Ensure we can map the space into virtual memory. */ - if (!ISSET(bm->bm_flags, BUS_SPACE_MAP_LINEAR)) + if (!ISSET(flags, BUS_SPACE_MAP_LINEAR)) continue; + /* Reflect requested flags in the bus_space map. */ + if (ISSET(map->flags, _DRM_WRITE_COMBINING)) + flags |= BUS_SPACE_MAP_PREFETCHABLE; + /* Map it. */ - if (bus_space_map(bst, map->offset, map->size, - bm->bm_flags, &map->lm_data.bus_space.bsh)) + if (bus_space_map(bst, map->offset, map->size, flags, + &map->lm_data.bus_space.bsh)) break; map->lm_data.bus_space.bus_map = bm;