On Wed, 17 Jul 2019 at 09:03, Vijay Kumar Banerjee <vijaykumar9...@gmail.com> wrote:
> --- > freebsd/sys/kern/kern_conf.c | 8 +++---- > freebsd/sys/sys/conf.h | 2 +- > rtemsbsd/include/machine/vm.h | 2 ++ > rtemsbsd/sys/fs/devfs/devfs_devs.c | 34 ++++++++++++++++++++++++++++++ > testsuite/cdev01/test_cdev.c | 17 ++++++++++++++- > testsuite/cdev01/test_cdev01.h | 3 ++- > testsuite/cdev01/test_main.c | 4 ++++ > 7 files changed, 63 insertions(+), 7 deletions(-) > > diff --git a/freebsd/sys/kern/kern_conf.c b/freebsd/sys/kern/kern_conf.c > index 92237d9d..560a450a 100644 > --- a/freebsd/sys/kern/kern_conf.c > +++ b/freebsd/sys/kern/kern_conf.c > @@ -328,8 +328,8 @@ static struct cdevsw dead_cdevsw = { > .d_write = dead_write, > .d_ioctl = dead_ioctl, > .d_poll = dead_poll, > -#ifndef __rtems__ > .d_mmap = dead_mmap, > +#ifndef __rtems__ > .d_strategy = dead_strategy, > #endif /* __rtems__ */ > .d_name = "dead", > @@ -522,7 +522,6 @@ giant_kqfilter(struct cdev *dev, struct knote *kn) > return (retval); > } > > -#ifndef __rtems__ > static int > giant_mmap(struct cdev *dev, vm_ooffset_t offset, vm_paddr_t *paddr, int > nprot, > vm_memattr_t *memattr) > @@ -541,6 +540,7 @@ giant_mmap(struct cdev *dev, vm_ooffset_t offset, > vm_paddr_t *paddr, int nprot, > return (retval); > } > > +#ifndef __rtems__ > static int > giant_mmap_single(struct cdev *dev, vm_ooffset_t *offset, vm_size_t size, > vm_object_t *object, int nprot) > @@ -667,8 +667,8 @@ prep_cdevsw(struct cdevsw *devsw, int flags) > devsw->d_write = dead_write; > devsw->d_ioctl = dead_ioctl; > devsw->d_poll = dead_poll; > -#ifndef __rtems__ > devsw->d_mmap = dead_mmap; > +#ifndef __rtems__ > devsw->d_mmap_single = dead_mmap_single; > devsw->d_strategy = dead_strategy; > devsw->d_dump = dead_dump; > @@ -702,8 +702,8 @@ prep_cdevsw(struct cdevsw *devsw, int flags) > FIXUP(d_write, no_write, giant_write); > FIXUP(d_ioctl, no_ioctl, giant_ioctl); > FIXUP(d_poll, no_poll, giant_poll); > -#ifndef __rtems__ > FIXUP(d_mmap, no_mmap, giant_mmap); > +#ifndef __rtems__ > FIXUP(d_strategy, no_strategy, giant_strategy); > #endif /* __rtems__ */ > FIXUP(d_kqfilter, no_kqfilter, giant_kqfilter); > diff --git a/freebsd/sys/sys/conf.h b/freebsd/sys/sys/conf.h > index 4ace162f..c0a66442 100644 > --- a/freebsd/sys/sys/conf.h > +++ b/freebsd/sys/sys/conf.h > @@ -209,8 +209,8 @@ struct cdevsw { > d_write_t *d_write; > d_ioctl_t *d_ioctl; > d_poll_t *d_poll; > -#ifndef __rtems__ > d_mmap_t *d_mmap; > +#ifndef __rtems__ > d_strategy_t *d_strategy; > dumper_t *d_dump; > #endif /* __rtems__ */ > diff --git a/rtemsbsd/include/machine/vm.h b/rtemsbsd/include/machine/vm.h > index e69de29b..351b7472 100644 > --- a/rtemsbsd/include/machine/vm.h > +++ b/rtemsbsd/include/machine/vm.h > @@ -0,0 +1,2 @@ > Hi, +#define VM_MEMATTR_DEFAULT 0 > +#define VM_MEMATTR_UNCACHEABLE 1 > Are you sure that these values are correct in general? BSD defines this only for ARM versions smaller 6. https://github.com/freebsd/freebsd/blob/1d6e4247415d264485ee94b59fdbc12e0c566fd0/sys/arm/include/vm.h > diff --git a/rtemsbsd/sys/fs/devfs/devfs_devs.c > b/rtemsbsd/sys/fs/devfs/devfs_devs.c > index 7c697b0a..9878936f 100644 > --- a/rtemsbsd/sys/fs/devfs/devfs_devs.c > +++ b/rtemsbsd/sys/fs/devfs/devfs_devs.c > @@ -387,6 +387,39 @@ devfs_imfs_kqfilter(rtems_libio_t *iop, struct knote > *kn) > return error; > } > > +static int > +devfs_imfs_mmap(rtems_libio_t *iop, void **addr, size_t len, int prot, > + off_t off) > +{ > + struct cdev *cdev = devfs_imfs_get_context_by_iop(iop); > + struct file *fp = rtems_bsd_iop_to_fp(iop); > + struct thread *td = rtems_bsd_get_curthread_or_null(); > + struct file *fpop; > + struct cdevsw *dsw; > + int error, ref; > + > + if (td != 0) { > + if (cdev == NULL) { > + error = ENXIO; > + } > + if (cdev->si_flags & SI_ALIAS) { > + cdev = cdev->si_parent; > + } > + dsw = dev_refthread(cdev, &ref); > + if (dsw == NULL) { > + error = ENXIO; > + } > + fpop = td->td_fpop; > + curthread->td_fpop = fp; > + error = dsw->d_mmap( cdev, off, (vm_paddr_t *) addr, prot, > VM_MEMATTR_DEFAULT); > + td->td_fpop = fpop; > + dev_relthread(cdev, ref); > + } else { > + error = ENOMEM; > + } > + return error; > +} > + > static const rtems_filesystem_file_handlers_r devfs_imfs_handlers = { > .open_h = devfs_imfs_open, > .close_h = devfs_imfs_close, > @@ -403,6 +436,7 @@ static const rtems_filesystem_file_handlers_r > devfs_imfs_handlers = { > .kqfilter_h = devfs_imfs_kqfilter, > .readv_h = devfs_imfs_readv, > .writev_h = devfs_imfs_writev, > + .mmap_h = devfs_imfs_mmap, > }; > > static const IMFS_node_control devfs_imfs_control = > IMFS_GENERIC_INITIALIZER( > diff --git a/testsuite/cdev01/test_cdev.c b/testsuite/cdev01/test_cdev.c > index 19fb1a5e..bff455cf 100644 > --- a/testsuite/cdev01/test_cdev.c > +++ b/testsuite/cdev01/test_cdev.c > @@ -32,6 +32,7 @@ > #include <machine/rtems-bsd-kernel-space.h> > #include <sys/types.h> > #include <sys/conf.h> > +#include <sys/mman.h> > > #include <rtems/seterr.h> > > @@ -46,6 +47,7 @@ static d_write_t testwrite; > static d_ioctl_t testioctl; > static d_poll_t testpoll; > static d_kqfilter_t testkqfilter; > +static d_mmap_t testmmap; > > static struct cdevsw test_cdevsw = { > .d_version = D_VERSION, > @@ -59,6 +61,7 @@ static struct cdevsw test_cdevsw = { > .d_ioctl = testioctl, > .d_poll = testpoll, > .d_kqfilter = testkqfilter, > + .d_mmap = testmmap, > }; > > static int > @@ -77,7 +80,7 @@ testclose(struct cdev *dev, int fflag, int devtype, > struct thread *td) > { > test_state *state = dev->si_drv1; > > - assert(*state == TEST_KQFILTER); > + assert(*state == TEST_MMAP); > *state = TEST_CLOSED; > > return 0; > @@ -148,6 +151,18 @@ testkqfilter(struct cdev *dev, struct knote *kn) > return TEST_KQ_ERRNO; > } > > +static int > +testmmap(struct cdev *dev, vm_ooffset_t offset, vm_paddr_t *paddr, > + int nprot, vm_memattr_t *memattr) > +{ > + test_state *state = dev->si_drv1; > + > + assert(*state == TEST_KQFILTER); > + *state = TEST_MMAP; > + > + return 0; > +} > + > void > test_make_dev(test_state *state, const char *name) > { > diff --git a/testsuite/cdev01/test_cdev01.h > b/testsuite/cdev01/test_cdev01.h > index a83001b5..58866a0c 100644 > --- a/testsuite/cdev01/test_cdev01.h > +++ b/testsuite/cdev01/test_cdev01.h > @@ -42,7 +42,8 @@ typedef enum { > TEST_WRITEV, > TEST_POLL, > TEST_KQFILTER, > - TEST_CLOSED > + TEST_MMAP, > + TEST_CLOSED, > } test_state; > > void test_make_dev(test_state *state, const char *name); > diff --git a/testsuite/cdev01/test_main.c b/testsuite/cdev01/test_main.c > index cbff9133..23aefa86 100644 > --- a/testsuite/cdev01/test_main.c > +++ b/testsuite/cdev01/test_main.c > @@ -35,6 +35,7 @@ > #include <sys/time.h> > #include <sys/uio.h> > #include <sys/ioctl.h> > +#include <sys/mman.h> > > #include <assert.h> > #include <errno.h> > @@ -125,6 +126,9 @@ static void test_cdev(const char *path) > assert(rv == -1); > assert(errno == TEST_KQ_ERRNO); > > + rv = mmap(NULL, 1, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); > + assert(rv == 0); > + > rv = close(fd); > assert(rv == 0); > > -- > 2.20.1 > > _______________________________________________ > devel mailing list > devel@rtems.org > http://lists.rtems.org/mailman/listinfo/devel >
_______________________________________________ devel mailing list devel@rtems.org http://lists.rtems.org/mailman/listinfo/devel