bug-hurd
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH 1/6] eth-filter: fix receiver lookups


From: Samuel Thibault
Subject: Re: [PATCH 1/6] eth-filter: fix receiver lookups
Date: Sat, 12 Apr 2014 09:18:25 +0200
User-agent: Mutt/1.5.21+34 (58baf7c9f32f) (2010-12-30)

Justus Winter, le Fri 11 Apr 2014 15:34:09 +0200, a écrit :
> Previously, the device definitions were filtered using sed to replace
> the device_t type with mach_port_send_t to make the device argument of
> device_open polymorphic.  Rather than doing that, which makes it
> impossible to use translation functions, the definition of device_open
> has been amended.

Ack.

> * eth-filter/Makefile: Remove the ourdevice hack that changes
> device_t to mach_port_send_t.
> * eth-filter/filter.c: Fix all device_t receiver lookups.
> * eth-filter/mig-decls.h: New file.
> * eth-filter/mig-mutate.h: Add mutators.
> ---
>  eth-filter/Makefile     |  7 ++-----
>  eth-filter/filter.c     | 50 
> +++++++++++++------------------------------------
>  eth-filter/mig-decls.h  | 45 ++++++++++++++++++++++++++++++++++++++++++++
>  eth-filter/mig-mutate.h |  7 +++++++
>  4 files changed, 67 insertions(+), 42 deletions(-)
>  create mode 100644 eth-filter/mig-decls.h
> 
> diff --git a/eth-filter/Makefile b/eth-filter/Makefile
> index 0b22222..deee1e5 100644
> --- a/eth-filter/Makefile
> +++ b/eth-filter/Makefile
> @@ -20,10 +20,10 @@ makemode := server
>  
>  SRCS = bpf_impl.c filter.c queue.c pcap_filter.c
>  LCLHDRS = bpf_impl.h queue.h util.h
> -DIST_FILES = ourdevice.defs notify.defs
> +DIST_FILES = device.defs notify.defs
>  HURDLIBS = ports trivfs fshelp ihash shouldbeinlibc
>  target = eth-filter
> -MIGSTUBS = ourdeviceServer.o notifyServer.o
> +MIGSTUBS = deviceServer.o notifyServer.o
>  MIGSFLAGS = -imacros $(srcdir)/mig-mutate.h
>  OBJS = $(SRCS:.c=.o) $(MIGSTUBS)
>  
> @@ -31,6 +31,3 @@ include ../Makeconf
>  
>  #CFLAGS += -I../pfinet/linux-src/include -I../pfinet/glue-include
>  LDFLAGS += -lpcap
> -
> -ourdevice.defs: device.defs
> -     $(CPP) $(CPPFLAGS) -x c $< | sed -e '/out[      ]*device[       ]*:[    
> ]*device_t/s/device_t/mach_port_send_t/' > $@
> diff --git a/eth-filter/filter.c b/eth-filter/filter.c
> index 04bf7b1..8c76c7b 100644
> --- a/eth-filter/filter.c
> +++ b/eth-filter/filter.c
> @@ -40,7 +40,7 @@
>  #include <hurd/ihash.h>
>  #include <hurd/fshelp.h>
>  
> -#include "ourdevice_S.h"
> +#include "device_S.h"
>  #include "notify_S.h"
>  #include "bpf_impl.h"
>  #include "util.h"
> @@ -287,21 +287,21 @@ do_mach_notify_dead_name (struct port_info *pi,
>  
>  /* Implementation of device interface */
>  kern_return_t 
> -ds_xxx_device_set_status (device_t device, dev_flavor_t flavor,
> +ds_xxx_device_set_status (struct proxy_user *device, dev_flavor_t flavor,
>                         dev_status_t status, size_t statu_cnt)
>  {
>    return D_INVALID_OPERATION;
>  }
>  
>  kern_return_t
> -ds_xxx_device_get_status (device_t device, dev_flavor_t flavor,
> +ds_xxx_device_get_status (struct proxy_user *device, dev_flavor_t flavor,
>                         dev_status_t status, size_t *statuscnt)
>  {
>    return D_INVALID_OPERATION;
>  }
>  
>  kern_return_t
> -ds_xxx_device_set_filter (device_t device, mach_port_t rec,
> +ds_xxx_device_set_filter (struct proxy_user *device, mach_port_t rec,
>                         int pri, filter_array_t filt, size_t len)
>  {
>    return D_INVALID_OPERATION;
> @@ -359,13 +359,13 @@ ds_device_open (mach_port_t master_port, mach_port_t 
> reply_port,
>  }
>  
>  kern_return_t
> -ds_device_close (device_t device)
> +ds_device_close (struct proxy_user *device)
>  {
>    return 0;
>  }
>  
>  kern_return_t
> -ds_device_write (device_t device, mach_port_t reply_port,
> +ds_device_write (struct proxy_user *user, mach_port_t reply_port,
>                mach_msg_type_name_t reply_type, dev_mode_t mode,
>                recnum_t recnum, io_buf_ptr_t data, size_t datalen,
>                int *bytes_written)
> @@ -374,17 +374,14 @@ ds_device_write (device_t device, mach_port_t 
> reply_port,
>    int has_filter = 0;
>    net_hash_entry_t entp, *hash_headp;
>    net_rcv_port_t infp, nextfp;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      {
>        vm_deallocate (mach_task_self (), (vm_address_t) data, datalen);
>        return D_INVALID_OPERATION;
>      }
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    /* The packet can be sent as long as it passes one filter,
>     * even thought there is usually only one filter in the list. */
> @@ -420,20 +417,17 @@ ds_device_write (device_t device, mach_port_t 
> reply_port,
>  }
>  
>  kern_return_t
> -ds_device_write_inband (device_t device, mach_port_t reply_port,
> +ds_device_write_inband (struct proxy_user *user, mach_port_t reply_port,
>                       mach_msg_type_name_t reply_type, dev_mode_t mode,
>                       recnum_t recnum, io_buf_ptr_inband_t data,
>                       size_t datalen, int *bytes_written)
>  {
>    kern_return_t ret;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      return D_INVALID_OPERATION;
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    ret = device_write_inband (proxy->device_port, mode, recnum, data,
>                            datalen, bytes_written);
> @@ -441,20 +435,17 @@ ds_device_write_inband (device_t device, mach_port_t 
> reply_port,
>  }
>  
>  kern_return_t
> -ds_device_read (device_t device, mach_port_t reply_port,
> +ds_device_read (struct proxy_user *user, mach_port_t reply_port,
>               mach_msg_type_name_t reply_type, dev_mode_t mode,
>               recnum_t recnum, int bytes_wanted,
>               io_buf_ptr_t *data, size_t *datalen)
>  {
>    kern_return_t ret;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      return D_INVALID_OPERATION;
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    ret = device_read (proxy->device_port, mode, recnum,
>                    bytes_wanted, data, datalen);
> @@ -462,20 +453,17 @@ ds_device_read (device_t device, mach_port_t reply_port,
>  }
>  
>  kern_return_t
> -ds_device_read_inband (device_t device, mach_port_t reply_port,
> +ds_device_read_inband (struct proxy_user *user, mach_port_t reply_port,
>                      mach_msg_type_name_t reply_type, dev_mode_t mode,
>                      recnum_t recnum, int bytes_wanted,
>                      io_buf_ptr_inband_t data, size_t *datalen)
>  {
>    kern_return_t ret;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      return D_INVALID_OPERATION;
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    ret = device_read_inband (proxy->device_port, mode, recnum, 
>                           bytes_wanted, data, datalen);
> @@ -483,18 +471,15 @@ ds_device_read_inband (device_t device, mach_port_t 
> reply_port,
>  }
>  
>  kern_return_t
> -ds_device_map (device_t device, vm_prot_t prot, vm_offset_t offset,
> +ds_device_map (struct proxy_user *user, vm_prot_t prot, vm_offset_t offset,
>              vm_size_t size, memory_object_t *pager, int unmap)
>  {
>    kern_return_t ret;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      return D_INVALID_OPERATION;
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    ret = device_map (proxy->device_port, prot, offset,
>                   size, pager, unmap);
> @@ -502,18 +487,15 @@ ds_device_map (device_t device, vm_prot_t prot, 
> vm_offset_t offset,
>  }
>  
>  kern_return_t
> -ds_device_set_status (device_t device, dev_flavor_t flavor,
> +ds_device_set_status (struct proxy_user *user, dev_flavor_t flavor,
>                     dev_status_t status, size_t statuslen)
>  {
>    kern_return_t ret;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      return D_INVALID_OPERATION;
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    ret = device_set_status (proxy->device_port, flavor,
>                          status, statuslen);
> @@ -521,38 +503,32 @@ ds_device_set_status (device_t device, dev_flavor_t 
> flavor,
>  }
>  
>  kern_return_t
> -ds_device_get_status (device_t device, dev_flavor_t flavor,
> +ds_device_get_status (struct proxy_user *user, dev_flavor_t flavor,
>                     dev_status_t status, size_t *statuslen)
>  {
>    kern_return_t ret;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      return D_INVALID_OPERATION;
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    ret = device_get_status (proxy->device_port, flavor, status, statuslen);
>    return ret;
>  }
>  
>  kern_return_t
> -ds_device_set_filter (device_t device, mach_port_t receive_port,
> +ds_device_set_filter (struct proxy_user *user, mach_port_t receive_port,
>                     int priority, filter_array_t filter, size_t filterlen)
>  {
>    mach_port_t tmp;
>    kern_return_t err;
>    mach_port_t device_receive_port;
> -  struct proxy_user *user;
>    struct proxy *proxy;
>  
> -  user = ports_lookup_port (port_bucket, device, user_portclass);
>    if (user == NULL)
>      return D_INVALID_OPERATION;
>    proxy = user->proxy;
> -  ports_port_deref (user);
>  
>    if (proxy->device == NULL)
>      {
> diff --git a/eth-filter/mig-decls.h b/eth-filter/mig-decls.h
> new file mode 100644
> index 0000000..0bb29a6
> --- /dev/null
> +++ b/eth-filter/mig-decls.h
> @@ -0,0 +1,45 @@
> +/*
> +   Copyright (C) 2014 Free Software Foundation, Inc.
> +   Written by Justus Winter.
> +
> +   This file is part of the GNU Hurd.
> +
> +   The GNU Hurd is free software; you can redistribute it and/or
> +   modify it under the terms of the GNU General Public License as
> +   published by the Free Software Foundation; either version 2, or (at
> +   your option) any later version.
> +
> +   The GNU Hurd is distributed in the hope that it will be useful, but
> +   WITHOUT ANY WARRANTY; without even the implied warranty of
> +   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
> +   General Public License for more details.
> +
> +   You should have received a copy of the GNU General Public License
> +   along with the GNU Hurd.  If not, see <http://www.gnu.org/licenses/>.  */
> +
> +#ifndef __ETH_FILTER_MIG_DECLS_H__
> +#define __ETH_FILTER_MIG_DECLS_H__
> +
> +#include <hurd/ports.h>
> +
> +typedef struct proxy_user *proxy_user_t;
> +
> +extern struct port_bucket *port_bucket;
> +extern struct port_class *user_portclass;
> +
> +/* Called by server stub functions.  */
> +
> +static inline struct proxy_user * __attribute__ ((unused))
> +begin_using_device_port (mach_port_t port)
> +{
> +  return ports_lookup_port (port_bucket, port, user_portclass);
> +}
> +
> +static inline void __attribute__ ((unused))
> +end_using_device (struct proxy_user *p)
> +{
> +  if (p)
> +    ports_port_deref (p);
> +}
> +
> +#endif /* __ETH_FILTER_MIG_DECLS_H__ */
> diff --git a/eth-filter/mig-mutate.h b/eth-filter/mig-mutate.h
> index f692236..388ce09 100644
> --- a/eth-filter/mig-mutate.h
> +++ b/eth-filter/mig-mutate.h
> @@ -23,3 +23,10 @@
>    end_using_port_info (port_info_t)
>  #define NOTIFY_IMPORTS                                               \
>    import "libports/mig-decls.h";
> +
> +#define DEVICE_INTRAN                                                \
> +  proxy_user_t begin_using_device_port (mach_port_t)
> +#define DEVICE_DESTRUCTOR                                    \
> +  end_using_device (proxy_user_t)
> +#define DEVICE_IMPORTS                                               \
> +  import "eth-filter/mig-decls.h";
> -- 
> 1.9.1
> 

-- 
Samuel
<Raize> can you guys see what I type?
<vecna> no, raize
<Raize> How do I set it up so you can see it?



reply via email to

[Prev in Thread] Current Thread [Next in Thread]