From owner-cvs-all@FreeBSD.ORG Mon Feb 28 21:46:20 2005 Return-Path: Delivered-To: cvs-all@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 9153316A4D0 for ; Mon, 28 Feb 2005 21:46:20 +0000 (GMT) Received: from mail27.sea5.speakeasy.net (mail27.sea5.speakeasy.net [69.17.117.29]) by mx1.FreeBSD.org (Postfix) with ESMTP id E569B43D5A for ; Mon, 28 Feb 2005 21:46:19 +0000 (GMT) (envelope-from jhb@FreeBSD.org) Received: (qmail 2330 invoked from network); 28 Feb 2005 21:46:16 -0000 Received: from server.baldwin.cx ([216.27.160.63]) (envelope-sender )AES256-SHA encrypted SMTP for ; 28 Feb 2005 21:46:15 -0000 Received: from [10.50.40.202] (gw1.twc.weather.com [216.133.140.1]) (authenticated bits=0) by server.baldwin.cx (8.13.1/8.13.1) with ESMTP id j1SLjxf2066044; Mon, 28 Feb 2005 16:46:07 -0500 (EST) (envelope-from jhb@FreeBSD.org) From: John Baldwin To: Maxim Konovalov Date: Mon, 28 Feb 2005 16:23:29 -0500 User-Agent: KMail/1.6.2 References: <200502221356.j1MDuFVH041926@repoman.freebsd.org> <20050225102649.H16332@mp2.macomnet.net> In-Reply-To: <20050225102649.H16332@mp2.macomnet.net> MIME-Version: 1.0 Content-Disposition: inline Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Message-Id: <200502281623.29703.jhb@FreeBSD.org> X-Spam-Status: No, score=-102.8 required=4.2 tests=ALL_TRUSTED, USER_IN_WHITELIST autolearn=failed version=3.0.2 X-Spam-Checker-Version: SpamAssassin 3.0.2 (2004-11-16) on server.baldwin.cx cc: cvs-src@FreeBSD.org cc: src-committers@FreeBSD.org cc: Poul-Henning Kamp cc: cvs-all@FreeBSD.org Subject: Re: cvs commit: src/sys/dev/drm drm_bufs.h X-BeenThere: cvs-all@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: CVS commit messages for the entire tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 28 Feb 2005 21:46:20 -0000 On Friday 25 February 2005 02:35 am, Maxim Konovalov wrote: > On Tue, 22 Feb 2005, 13:56-0000, Poul-Henning Kamp wrote: > > phk 2005-02-22 13:56:15 UTC > > > > FreeBSD src repository > > > > Modified files: > > sys/dev/drm drm_bufs.h > > Log: > > Neuter DRM(mapbufs) until somebody finds time to try to fix it. > > > > It is _never_ OK to find a vnode from a struct cdev because you have > > no way of telling if you get the right one. You might be in jail or > > chroot for instance. > > Thankyou for breaking my workstation and only development machine, > radeon(4) doesn't work now. > > How and who is going to fix this? I have a patch to allow vm_mmap() to operate on a cdev directly. It fixed X for my laptop with a mobility 7500 radeon. This is an older version, I've changed the interface locally to not use a MAP_CDEV flag, but I haven't tested that yet and this is a known-working version. :) --- //depot/vendor/freebsd/src/sys/dev/drm/drm_bufs.h 2005/02/22 14:00:48 +++ //depot/user/jhb/acpipci/dev/drm/drm_bufs.h 2005/02/25 19:55:35 @@ -923,12 +923,8 @@ #ifdef __FreeBSD__ vaddr = round_page((vm_offset_t)vms->vm_daddr + MAXDSIZ); -#ifdef this_is_just_plain_bogus retcode = vm_mmap(&vms->vm_map, &vaddr, size, PROT_READ | PROT_WRITE, - VM_PROT_ALL, MAP_SHARED, SLIST_FIRST(&kdev->si_hlist), foff ); -#else - retcode = EOPNOTSUPP; -#endif + VM_PROT_ALL, MAP_SHARED | MAP_CDEV, kdev, foff ); #elif defined(__NetBSD__) vaddr = round_page((vaddr_t)vms->vm_daddr + MAXDSIZ); retcode = uvm_mmap(&vms->vm_map, &vaddr, size, --- //depot/vendor/freebsd/src/sys/sys/mman.h 2004/04/27 13:15:33 +++ //depot/user/jhb/acpipci/sys/mman.h 2005/02/25 19:55:35 @@ -84,6 +84,10 @@ * Extended flags */ #define MAP_NOCORE 0x00020000 /* dont include these pages in a coredump */ +#ifdef _KERNEL +#define MAP_CDEV 0x00040000 /* map from a cdev, not a vnode */ +#define MAP_KERNEL_ONLY MAP_CDEV +#endif #endif /* __BSD_VISIBLE */ #if __POSIX_VISIBLE >= 199309 --- //depot/vendor/freebsd/src/sys/vm/vm_mmap.c 2005/01/25 00:40:30 +++ //depot/user/jhb/acpipci/vm/vm_mmap.c 2005/02/25 20:00:21 @@ -109,6 +109,8 @@ static int vm_mmap_vnode(struct thread *, vm_size_t, vm_prot_t, vm_prot_t *, int *, struct vnode *, vm_ooffset_t, vm_object_t *); +static int vm_mmap_cdev(struct thread *, vm_size_t, vm_prot_t, vm_prot_t *, + int *, struct cdev *, vm_ooffset_t, vm_object_t *); /* * MPSAFE @@ -218,7 +220,7 @@ fp = NULL; /* make sure mapping fits into numeric range etc */ if ((ssize_t) uap->len < 0 || - ((flags & MAP_ANON) && uap->fd != -1)) + ((flags & MAP_ANON) && uap->fd != -1) || (flags & MAP_KERNEL_ONLY)) return (EINVAL); if (flags & MAP_STACK) { @@ -1166,6 +1168,55 @@ } /* + * vm_mmap_cdev() + * + * MPSAFE + * + * Helper function for vm_mmap. Perform sanity check specific for mmap + * operations on cdevs. + */ +int +vm_mmap_cdev(struct thread *td, vm_size_t objsize, + vm_prot_t prot, vm_prot_t *maxprotp, int *flagsp, + struct cdev *cdev, vm_ooffset_t foff, vm_object_t *objp) +{ + vm_object_t obj; + int flags; + + flags = *flagsp; + + /* XXX: lack thredref on device */ + if (cdev->si_devsw->d_flags & D_MMAP_ANON) { + *maxprotp = VM_PROT_ALL; + *flagsp |= MAP_ANON; + return (0); + } + /* + * cdevs does not provide private mappings of any kind. + */ + if ((*maxprotp & VM_PROT_WRITE) == 0 && + (prot & PROT_WRITE) != 0) + return (EACCES); + if (flags & (MAP_PRIVATE|MAP_COPY)) + return (EINVAL); + /* + * Force device mappings to be shared. + */ + flags |= MAP_SHARED; +#ifdef MAC_XXX + error = mac_check_vnode_mmap(td->td_ucred, vp, prot); + if (error != 0) + return (error); +#endif + obj = vm_pager_allocate(OBJT_DEVICE, cdev, objsize, prot, foff); + if (obj == NULL) + return (EINVAL); + *objp = obj; + *flagsp = flags; + return (0); +} + +/* * vm_mmap() * * MPSAFE @@ -1223,11 +1274,14 @@ * Lookup/allocate object. */ if (handle != NULL) { - error = vm_mmap_vnode(td, size, prot, &maxprot, &flags, - handle, foff, &object); - if (error) { + if (flags & MAP_CDEV) + error = vm_mmap_cdev(td, size, prot, &maxprot, &flags, + handle, foff, &object); + else + error = vm_mmap_vnode(td, size, prot, &maxprot, &flags, + handle, foff, &object); + if (error) return (error); - } } if (flags & MAP_ANON) { object = NULL; -- John Baldwin <>< http://www.FreeBSD.org/~jhb/ "Power Users Use the Power to Serve" = http://www.FreeBSD.org