Received: by 10.223.176.46 with SMTP id f43csp1572749wra; Wed, 24 Jan 2018 19:42:44 -0800 (PST) X-Google-Smtp-Source: AH8x227REgIr11mYOPL5uuixXqUoVKfp/zKJs5hJ2ky6s4upylpge7oHlZQ7NXF7Jhx0b9ao35zm X-Received: by 2002:a17:902:581a:: with SMTP id m26-v6mr9927820pli.158.1516851764860; Wed, 24 Jan 2018 19:42:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516851764; cv=none; d=google.com; s=arc-20160816; b=j6nAp8aH7oKi7VdP/DOU6s7NJ53GtNAYuYq7BNi7NnR9KLtfM0RS/VlbjUtgfF8UV4 HgXqw8u5AW1njGd3a4xV0I/H+zkLYd4Zj3Ktex6LUIM4mUdwS0NBDGOhSD09eZro2Rfh jnpr9TtBqJZ58EcIe70JTGO4a82qkXgosKRCKara9gSxkpFU6rvSA9wC9s0LSfPuC0ew c2mV9EyifpWJdyM1FXczY6Eq2nrWC4FbyqmfM3RswOwubaDfj8guraJWw0fQOZ3JWsB5 2LRZGO46ELl80IqECjOjc4jHK+MjOTd23X4koKkk+DLnFmSDQDP4qyTP7ZkTOD1yqe2I p0kg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=KfAVQ+cAhhOSZp15/ZfvVDzaNiD29DXlAAKQha/3uYo=; b=Au7Md9KVcr3iWNFJpjYjDXyjjYC4dVHVqFYF+gdfow3PvjIOosX3XVc6uE6FCA6ths 5RPwJxin3mmTN6fQWhuaNWseuuSMc2wU8yeecMbuDWLXg2VNUTDopgOxWgLU3Km+SX// Cd3CdCQeDSBLvC+QGI96eiWx0Ld2x4Qd0XF1aEnSapWsghkgC+lAdGaJLCFDmfOCDNdS SoinjFJyGnTI1AmRiBx0tJWYlsMKz9Ngl9vxZ8H8sjjWD5iHg4z1MMxai3xV46BP2ci8 gGh0WMiZAZo9M5f3psTKGBHksUs2XnIvZ3k4pBIBj3sQXn3xvUjcbgODprkR3cIVEzGT nFKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cisco.com header.s=iport header.b=Mio1Ccep; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=cisco.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u86si3883060pfa.314.2018.01.24.19.42.30; Wed, 24 Jan 2018 19:42:44 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@cisco.com header.s=iport header.b=Mio1Ccep; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=cisco.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933639AbeAYDk7 (ORCPT + 99 others); Wed, 24 Jan 2018 22:40:59 -0500 Received: from alln-iport-3.cisco.com ([173.37.142.90]:38659 "EHLO alln-iport-3.cisco.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933374AbeAYDha (ORCPT ); Wed, 24 Jan 2018 22:37:30 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=cisco.com; i=@cisco.com; l=5648; q=dns/txt; s=iport; t=1516851450; x=1518061050; h=from:to:cc:subject:date:message-id:in-reply-to: references; bh=kPtfKRZKS/cOHG4AIpt4bEc+kdJD6gX/yiPBjFXhWw4=; b=Mio1CcepFKBICFnIaM0a0JIUZi1tG9KGnvU71v8x4X1YkAzTwE/vee0Z qZvvxhsZGAjYzOgAS2jOdhKEkL45LLzDWGkbX585OqJF+fYgVTYrGad57 JabVNOJJvYZycRYhMce15y4hHbuW2v4wqqfuTlCsS7F06N6yflVD08/gH Y=; X-IronPort-AV: E=Sophos;i="5.46,409,1511827200"; d="scan'208";a="61438447" Received: from rcdn-core-6.cisco.com ([173.37.93.157]) by alln-iport-3.cisco.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 25 Jan 2018 03:27:59 +0000 Received: from sjc-ads-7132.cisco.com (sjc-ads-7132.cisco.com [10.30.217.207]) (authenticated bits=0) by rcdn-core-6.cisco.com (8.14.5/8.14.5) with ESMTP id w0P3Ruir007601 (version=TLSv1/SSLv3 cipher=AES128-SHA256 bits=128 verify=NO); Thu, 25 Jan 2018 03:27:58 GMT From: Taras Kondratiuk To: "H. Peter Anvin" , Al Viro , Arnd Bergmann , Rob Landley , Mimi Zohar , Jonathan Corbet , James McMechan Cc: initramfs@vger.kernel.org, Victor Kamensky , linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-security-module@vger.kernel.org, xe-linux-external@cisco.com Subject: [PATCH v2 02/15] initramfs: replace states with function pointers Date: Thu, 25 Jan 2018 03:27:42 +0000 Message-Id: <1516850875-25066-3-git-send-email-takondra@cisco.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1516850875-25066-1-git-send-email-takondra@cisco.com> References: <1516850875-25066-1-git-send-email-takondra@cisco.com> X-Auto-Response-Suppress: DR, OOF, AutoReply X-Authenticated-User: takondra@cisco.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently the FSM states are mapped directly to function pointers. Extra level of intirection is not needed and makes navigation over the code harder. One can't jump between states directly when browsing code (e.g. with cscope). Need to go through actions[] array each time. Replace states with their action function pointers. No behaviour change. Signed-off-by: Taras Kondratiuk --- init/initramfs.c | 73 +++++++++++++++++++++++++------------------------------- 1 file changed, 32 insertions(+), 41 deletions(-) diff --git a/init/initramfs.c b/init/initramfs.c index 7e99a0038942..49cd2681a26f 100644 --- a/init/initramfs.c +++ b/init/initramfs.c @@ -187,16 +187,17 @@ static void __init parse_header(char *s) /* FSM */ -static __initdata enum state { - Start, - Collect, - GotHeader, - SkipIt, - GotName, - CopyFile, - GotSymlink, - Reset -} state, next_state; +static int __init do_start(void); +static int __init do_collect(void); +static int __init do_header(void); +static int __init do_skip(void); +static int __init do_name(void); +static int __init do_copy(void); +static int __init do_symlink(void); +static int __init do_reset(void); + +typedef int (*fsm_state_t)(void); +static __initdata fsm_state_t state, next_state; static __initdata char *victim; static unsigned long byte_count __initdata; @@ -214,7 +215,7 @@ static __initdata char *collected; static long remains __initdata; static __initdata char *collect; -static void __init read_into(char *buf, unsigned size, enum state next) +static void __init read_into(char *buf, unsigned size, fsm_state_t next) { if (byte_count >= size) { collected = victim; @@ -224,7 +225,7 @@ static void __init read_into(char *buf, unsigned size, enum state next) collect = collected = buf; remains = size; next_state = next; - state = Collect; + state = do_collect; } } @@ -232,7 +233,7 @@ static __initdata char *header_buf, *symlink_buf, *name_buf; static int __init do_start(void) { - read_into(header_buf, 110, GotHeader); + read_into(header_buf, 110, do_header); return 0; } @@ -263,7 +264,7 @@ static int __init do_header(void) parse_header(collected); next_header = this_header + N_ALIGN(name_len) + body_len; next_header = (next_header + 3) & ~3; - state = SkipIt; + state = do_skip; if (name_len <= 0 || name_len > PATH_MAX) return 0; if (S_ISLNK(mode)) { @@ -271,12 +272,12 @@ static int __init do_header(void) return 0; collect = collected = symlink_buf; remains = N_ALIGN(name_len) + body_len; - next_state = GotSymlink; - state = Collect; + next_state = do_symlink; + state = do_collect; return 0; } if (S_ISREG(mode) || !body_len) - read_into(name_buf, N_ALIGN(name_len), GotName); + read_into(name_buf, N_ALIGN(name_len), do_name); return 0; } @@ -327,8 +328,8 @@ static __initdata int wfd; static int __init do_name(void) { - state = SkipIt; - next_state = Reset; + state = do_skip; + next_state = do_reset; if (strcmp(collected, "TRAILER!!!") == 0) { free_hash(); return 0; @@ -348,7 +349,7 @@ static int __init do_name(void) if (body_len) sys_ftruncate(wfd, body_len); vcollected = kstrdup(collected, GFP_KERNEL); - state = CopyFile; + state = do_copy; } } } else if (S_ISDIR(mode)) { @@ -377,7 +378,7 @@ static int __init do_copy(void) do_utime(vcollected, mtime); kfree(vcollected); eat(body_len); - state = SkipIt; + state = do_skip; return 0; } else { if (xwrite(wfd, victim, byte_count) != byte_count) @@ -395,29 +396,19 @@ static int __init do_symlink(void) sys_symlink(collected + N_ALIGN(name_len), collected); sys_lchown(collected, uid, gid); do_utime(collected, mtime); - state = SkipIt; - next_state = Reset; + state = do_skip; + next_state = do_reset; return 0; } -static __initdata int (*actions[])(void) = { - [Start] = do_start, - [Collect] = do_collect, - [GotHeader] = do_header, - [SkipIt] = do_skip, - [GotName] = do_name, - [CopyFile] = do_copy, - [GotSymlink] = do_symlink, - [Reset] = do_reset, -}; - static long __init write_buffer(char *buf, unsigned long len) { byte_count = len; victim = buf; - while (!actions[state]()) - ; + do + pr_debug("state: %pf\n", state); + while (!state()); return len - byte_count; } @@ -433,11 +424,11 @@ static long __init flush_buffer(void *bufv, unsigned long len) if (c == '0') { buf += written; len -= written; - state = Start; + state = do_start; } else if (c == 0) { buf += written; len -= written; - state = Reset; + state = do_reset; } else error("junk in compressed archive"); } @@ -462,13 +453,13 @@ static char * __init unpack_to_rootfs(char *buf, unsigned long len) if (!header_buf || !symlink_buf || !name_buf) panic("can't allocate buffers"); - state = Start; + state = do_start; this_header = 0; message = NULL; while (!message && len) { loff_t saved_offset = this_header; if (*buf == '0' && !(this_header & 3)) { - state = Start; + state = do_start; written = write_buffer(buf, len); buf += written; len -= written; @@ -497,7 +488,7 @@ static char * __init unpack_to_rootfs(char *buf, unsigned long len) } } else error("junk in compressed archive"); - if (state != Reset) + if (state != do_reset) error("junk in compressed archive"); this_header = saved_offset + my_inptr; buf += my_inptr; -- 2.10.3.dirty