]> Zhao Yanbai Git Server - minix.git/commitdiff
VFS: complete the devmajor_t/devminor_t switch 85/2785/1
authorDavid van Moolenbroek <david@minix3.org>
Tue, 26 Aug 2014 16:39:02 +0000 (16:39 +0000)
committerDavid van Moolenbroek <david@minix3.org>
Thu, 28 Aug 2014 16:29:56 +0000 (16:29 +0000)
Change-Id: I9f809283f19d577cf7e02705fdbb2310ae2b6cba

minix/servers/vfs/dmap.c
minix/servers/vfs/filedes.c
minix/servers/vfs/mount.c
minix/servers/vfs/open.c
minix/servers/vfs/proto.h
minix/servers/vfs/select.c

index d9b3cfea10425ec3e4a109999bbf6c4c79580f2a..01bcce099f96f9cafa4ac67a94397d953227950c 100644 (file)
@@ -110,7 +110,8 @@ int do_mapdriver(void)
  * etc), and its label. This label is registered with DS, and allows us to
  * retrieve the driver's endpoint.
  */
-  int r, major, slot;
+  int r, slot;
+  devmajor_t major;
   endpoint_t endpoint;
   vir_bytes label_vir;
   size_t label_len;
@@ -165,7 +166,8 @@ int do_mapdriver(void)
 void dmap_unmap_by_endpt(endpoint_t proc_e)
 {
 /* Lookup driver in dmap table by endpoint and unmap it */
-  int major, r;
+  devmajor_t major;
+  int r;
 
   for (major = 0; major < NR_DEVICES; major++) {
        if (dmap_driver_match(proc_e, major)) {
@@ -233,7 +235,7 @@ void init_dmap(void)
 /*===========================================================================*
  *                             dmap_driver_match                            *
  *===========================================================================*/
-int dmap_driver_match(endpoint_t proc, int major)
+int dmap_driver_match(endpoint_t proc, devmajor_t major)
 {
   if (major < 0 || major >= NR_DEVICES) return(0);
   if (dmap[major].dmap_driver != NONE && dmap[major].dmap_driver == proc)
@@ -246,7 +248,7 @@ int dmap_driver_match(endpoint_t proc, int major)
  *                             dmap_by_major                                *
  *===========================================================================*/
 struct dmap *
-get_dmap_by_major(int major)
+get_dmap_by_major(devmajor_t major)
 {
        if (major < 0 || major >= NR_DEVICES) return(NULL);
        if (dmap[major].dmap_driver == NONE) return(NULL);
@@ -261,8 +263,7 @@ void dmap_endpt_up(endpoint_t proc_e, int is_blk)
 /* A device driver with endpoint proc_e has been restarted. Go tell everyone
  * that might be blocking on it that this device is 'up'.
  */
-
-  int major;
+  devmajor_t major;
   struct dmap *dp;
   struct worker_thread *worker;
 
@@ -303,8 +304,8 @@ struct dmap *get_dmap(endpoint_t proc_e)
 {
 /* See if 'proc_e' endpoint belongs to a valid dmap entry. If so, return a
  * pointer */
+  devmajor_t major;
 
-  int major;
   for (major = 0; major < NR_DEVICES; major++)
        if (dmap_driver_match(proc_e, major))
                return(&dmap[major]);
index 9e74ac637bfa5edcc4ea7200707d2b85a59611db..a810feb2f47354ad4def624c92450723cba90707 100644 (file)
@@ -209,7 +209,7 @@ void invalidate_filp(struct filp *rfilp)
 /*===========================================================================*
  *                     invalidate_filp_by_char_major                        *
  *===========================================================================*/
-void invalidate_filp_by_char_major(int major)
+void invalidate_filp_by_char_major(devmajor_t major)
 {
   struct filp *f;
 
index 350dfc95c70325fd905de0eddc62f73b415754bc..17ef918dc775806d9ad3eacc8ede5e50e8ed13a2 100644 (file)
@@ -50,7 +50,8 @@ static void update_bspec(dev_t dev, endpoint_t fs_e, int send_drv_e)
  */
   struct vnode *vp;
   struct dmap *dp;
-  int r, major;
+  devmajor_t major;
+  int r;
 
   for (vp = &vnode[0]; vp < &vnode[NR_VNODES]; ++vp)
        if (vp->v_ref_count > 0 && S_ISBLK(vp->v_mode) && vp->v_sdev == dev) {
index cbe82893d5ca9a28f93f438b1a2a7e597e2067ac..740b89964cd23c544b5a47c8ffd3076e75de79a0 100644 (file)
@@ -84,7 +84,8 @@ int do_creat(void)
 int common_open(char path[PATH_MAX], int oflags, mode_t omode)
 {
 /* Common code from do_creat and do_open. */
-  int b, r, exist = TRUE, major_dev;
+  int b, r, exist = TRUE;
+  devmajor_t major_dev;
   dev_t dev;
   mode_t bits;
   struct filp *filp, *filp2;
index 8e1ec8e29c5d6a9421631ecdd2c26be167edb2ac..ad0449dc9d233a89e99bb045d152e1e7025f34a9 100644 (file)
@@ -40,7 +40,7 @@ void cdev_reply(void);
 int bdev_open(dev_t dev, int access);
 int bdev_close(dev_t dev);
 void bdev_reply(void);
-void bdev_up(int major);
+void bdev_up(devmajor_t major);
 int do_ioctl(void);
 
 /* dmap.c */
@@ -48,10 +48,10 @@ void lock_dmap(struct dmap *dp);
 void unlock_dmap(struct dmap *dp);
 int do_mapdriver(void);
 void init_dmap(void);
-int dmap_driver_match(endpoint_t proc, int major);
+int dmap_driver_match(endpoint_t proc, devmajor_t major);
 void dmap_endpt_up(endpoint_t proc_nr, int is_blk);
 struct dmap *get_dmap(endpoint_t proc_e);
-struct dmap *get_dmap_by_major(int major);
+struct dmap *get_dmap_by_major(devmajor_t major);
 void dmap_unmap_by_endpt(endpoint_t proc_nr);
 int map_service(struct rprocpub *rpub);
 
@@ -76,7 +76,7 @@ void unlock_filp(struct filp *filp);
 void unlock_filps(struct filp *filp1, struct filp *filp2);
 void invalidate_filp(struct filp *);
 void invalidate_filp_by_endpt(endpoint_t proc_e);
-void invalidate_filp_by_char_major(int major);
+void invalidate_filp_by_char_major(devmajor_t major);
 void close_filp(struct filp *fp);
 int do_copyfd(void);
 
@@ -328,8 +328,8 @@ int do_select(void);
 void init_select(void);
 void select_callback(struct filp *, int ops);
 void select_forget(void);
-void select_reply1(endpoint_t driver_e, int minor, int status);
-void select_reply2(endpoint_t driver_e, int minor, int status);
+void select_reply1(endpoint_t driver_e, devminor_t minor, int status);
+void select_reply2(endpoint_t driver_e, devminor_t minor, int status);
 void select_timeout_check(minix_timer_t *);
 void select_unsuspend_by_endpt(endpoint_t proc);
 
index 65495620e6f85cb68fd30f5d502cc93f4465956d..66ff4ffadd3050ce2a692ceed421bc6617c990a8 100644 (file)
@@ -362,7 +362,8 @@ static int select_request_char(struct filp *f, int *ops, int block)
  * result processing to be deferred. This function MUST NOT block its calling
  * thread. The given filp may or may not be locked.
  */
-  int r, rops, major;
+  devmajor_t major;
+  int r, rops;
   struct dmap *dp;
 
   major = major(f->filp_vno->v_sdev);
@@ -596,7 +597,7 @@ static void select_cancel_filp(struct filp *f)
 /* Reduce the number of select users of this filp. This function MUST NOT block
  * its calling thread.
  */
-  dev_t major;
+  devmajor_t major;
 
   assert(f);
   assert(f->filp_selectors > 0);
@@ -729,8 +730,8 @@ void select_timeout_check(minix_timer_t *timer)
 void select_unsuspend_by_endpt(endpoint_t proc_e)
 {
 /* Revive blocked processes when a driver has disappeared */
-
-  int fd, s, major;
+  devmajor_t major;
+  int fd, s;
   struct selectentry *se;
   struct filp *f;
 
@@ -765,15 +766,12 @@ void select_unsuspend_by_endpt(endpoint_t proc_e)
 /*===========================================================================*
  *                             select_reply1                                *
  *===========================================================================*/
-void select_reply1(driver_e, minor, status)
-endpoint_t driver_e;
-int minor;
-int status;
+void select_reply1(endpoint_t driver_e, devminor_t minor, int status)
 {
 /* Handle the initial reply to CDEV_SELECT request. This function MUST NOT
  * block its calling thread.
  */
-  int major;
+  devmajor_t major;
   dev_t dev;
   struct filp *f;
   struct dmap *dp;
@@ -863,16 +861,14 @@ int status;
 /*===========================================================================*
  *                             select_reply2                                *
  *===========================================================================*/
-void select_reply2(driver_e, minor, status)
-endpoint_t driver_e;
-int minor;
-int status;
+void select_reply2(endpoint_t driver_e, devminor_t minor, int status)
 {
 /* Handle secondary reply to DEV_SELECT request. A secondary reply occurs when
  * the select request is 'blocking' until an operation becomes ready. This
  * function MUST NOT block its calling thread.
  */
-  int major, slot, found, fd;
+  int slot, found, fd;
+  devmajor_t major;
   dev_t dev;
   struct filp *f;
   struct dmap *dp;