From: Isaku Yamahata Date: Thu, 2 Jul 2009 10:32:08 +0000 (+0900) Subject: ioport: consolidate duplicated logic in register_ioport_{read, write}(). X-Git-Tag: TizenStudio_2.0_p2.3.2~208^2~11496 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=23e0affdd293d0f6625a097911800b48b5428727;p=sdk%2Femulator%2Fqemu.git ioport: consolidate duplicated logic in register_ioport_{read, write}(). Signed-off-by: Isaku Yamahata Signed-off-by: Anthony Liguori --- diff --git a/ioport.c b/ioport.c index 04bffc4..01cfaf7 100644 --- a/ioport.c +++ b/ioport.c @@ -121,19 +121,27 @@ static void default_ioport_writel(void *opaque, uint32_t address, uint32_t data) #endif } +static int ioport_bsize(int size, int *bsize) +{ + if (size == 1) { + *bsize = 0; + } else if (size == 2) { + *bsize = 1; + } else if (size == 4) { + *bsize = 2; + } else { + return -1; + } + return 0; +} + /* size is the word size in byte */ int register_ioport_read(int start, int length, int size, IOPortReadFunc *func, void *opaque) { int i, bsize; - if (size == 1) { - bsize = 0; - } else if (size == 2) { - bsize = 1; - } else if (size == 4) { - bsize = 2; - } else { + if (ioport_bsize(size, &bsize)) { hw_error("register_ioport_read: invalid size"); return -1; } @@ -152,13 +160,7 @@ int register_ioport_write(int start, int length, int size, { int i, bsize; - if (size == 1) { - bsize = 0; - } else if (size == 2) { - bsize = 1; - } else if (size == 4) { - bsize = 2; - } else { + if (ioport_bsize(size, &bsize)) { hw_error("register_ioport_write: invalid size"); return -1; }