Deleted Added
full compact
devfs_vnops.c (104278) devfs_vnops.c (104533)
1/*
2 * Copyright (c) 1992, 1993
3 * The Regents of the University of California. All rights reserved.
4 * Copyright (c) 2000
5 * Poul-Henning Kamp. All rights reserved.
6 *
7 * This code is derived from software donated to Berkeley by
8 * Jan-Simon Pendry.

--- 17 unchanged lines hidden (view full) ---

26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 *
31 * @(#)kernfs_vnops.c 8.15 (Berkeley) 5/21/95
32 * From: FreeBSD: src/sys/miscfs/kernfs/kernfs_vnops.c 1.43
33 *
1/*
2 * Copyright (c) 1992, 1993
3 * The Regents of the University of California. All rights reserved.
4 * Copyright (c) 2000
5 * Poul-Henning Kamp. All rights reserved.
6 *
7 * This code is derived from software donated to Berkeley by
8 * Jan-Simon Pendry.

--- 17 unchanged lines hidden (view full) ---

26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 *
31 * @(#)kernfs_vnops.c 8.15 (Berkeley) 5/21/95
32 * From: FreeBSD: src/sys/miscfs/kernfs/kernfs_vnops.c 1.43
33 *
34 * $FreeBSD: head/sys/fs/devfs/devfs_vnops.c 104278 2002-10-01 10:08:08Z phk $
34 * $FreeBSD: head/sys/fs/devfs/devfs_vnops.c 104533 2002-10-05 18:40:10Z rwatson $
35 */
36
37/*
38 * TODO:
39 * remove empty directories
40 * mknod: hunt down DE_DELETED, compare name, reinstantiate.
41 * mkdir: want it ?
42 */

--- 820 unchanged lines hidden (view full) ---

863 de->de_gid = 0;
864 de->de_mode = 0755;
865 de->de_inode = dmp->dm_inode++;
866 de->de_dirent->d_type = DT_LNK;
867 i = strlen(ap->a_target) + 1;
868 MALLOC(de->de_symlink, char *, i, M_DEVFS, M_WAITOK);
869 bcopy(ap->a_target, de->de_symlink, i);
870 lockmgr(&dmp->dm_lock, LK_EXCLUSIVE, 0, curthread);
35 */
36
37/*
38 * TODO:
39 * remove empty directories
40 * mknod: hunt down DE_DELETED, compare name, reinstantiate.
41 * mkdir: want it ?
42 */

--- 820 unchanged lines hidden (view full) ---

863 de->de_gid = 0;
864 de->de_mode = 0755;
865 de->de_inode = dmp->dm_inode++;
866 de->de_dirent->d_type = DT_LNK;
867 i = strlen(ap->a_target) + 1;
868 MALLOC(de->de_symlink, char *, i, M_DEVFS, M_WAITOK);
869 bcopy(ap->a_target, de->de_symlink, i);
870 lockmgr(&dmp->dm_lock, LK_EXCLUSIVE, 0, curthread);
871#ifdef MAC
872 mac_create_devfs_symlink(ap->a_cnp->cn_cred, dd, de);
873#endif
871 TAILQ_INSERT_TAIL(&dd->de_dlist, de, de_list);
872 devfs_allocv(de, ap->a_dvp->v_mount, ap->a_vpp, 0);
874 TAILQ_INSERT_TAIL(&dd->de_dlist, de, de_list);
875 devfs_allocv(de, ap->a_dvp->v_mount, ap->a_vpp, 0);
873#ifdef MAC
874 mac_create_vnode(ap->a_cnp->cn_cred, ap->a_dvp, *ap->a_vpp);
875 mac_update_devfsdirent(de, *ap->a_vpp);
876#endif /* MAC */
877 lockmgr(&dmp->dm_lock, LK_RELEASE, 0, curthread);
878 return (0);
879}
880
881static struct vnodeopv_entry_desc devfs_vnodeop_entries[] = {
882 { &vop_default_desc, (vop_t *) vop_defaultop },
883 { &vop_access_desc, (vop_t *) devfs_access },
884 { &vop_getattr_desc, (vop_t *) devfs_getattr },

--- 55 unchanged lines hidden ---
876 lockmgr(&dmp->dm_lock, LK_RELEASE, 0, curthread);
877 return (0);
878}
879
880static struct vnodeopv_entry_desc devfs_vnodeop_entries[] = {
881 { &vop_default_desc, (vop_t *) vop_defaultop },
882 { &vop_access_desc, (vop_t *) devfs_access },
883 { &vop_getattr_desc, (vop_t *) devfs_getattr },

--- 55 unchanged lines hidden ---