Received: by 10.223.185.116 with SMTP id b49csp1111547wrg; Fri, 16 Feb 2018 12:40:54 -0800 (PST) X-Google-Smtp-Source: AH8x224sf9X7am+wnE47wNRIF67MSJmdfKjNTlMRNf1f/68Vx0Ad9/izG+R2WyC308GkFZyT+QDC X-Received: by 10.101.64.4 with SMTP id f4mr5932954pgp.171.1518813653910; Fri, 16 Feb 2018 12:40:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518813653; cv=none; d=google.com; s=arc-20160816; b=tenYGbpEMPOqbGaSlKgCKGVQ8xu6jqEB0XmLUM9pfhJNe2rPxlLpskghWcO9E5MeTG maADouWrmbsJenJR6dYootQ4IMrkGUv6FljBQoPVxUz+YOoIQOPpoue0ZquvTzBDF2Q9 ICCLS9gTRbsHCmFE+KMMz8Dxo/2ReL2Z/Cdwy7+0tWclcIPfmfzZsJsf1uO+CX5Si7pQ 5MK0fstJe5XK6ILdpCLTy3BWshytjwm5hxItOhZhJKnhOxcq3C6TXp6SzdhuKRqQxdG7 cVdHSHKJXeueqM05Vd9et+a8kKgRnXaRw8eq+J/5aRKaHjwJhQZCAuMt6TLfwaXfC7vd K6WQ== 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=nFmR+6OaY65ZKQZjk/H69JtQQHRr28GdbRF0ZebTksc5ya7QCjeqTGy65mtIJaqGQ4 C6BW7Aw6EDOiejsM4c+oC8p/cjk8U5+f18jom3XQOAbkGh/j+HyRydrTOgxSlrCZ3/Gb CLPwTAUTOo8gjCXoeVOHUjHNz/3aLD6ZeSOIGznLToeqsebSisfavgI4nuQnTtBcbHz/ YYhHVt9Y9erzwQgWZB3kULdDRg+ABdkmjFl81SohKN/Pl8wmLhLjPmJGucd09YmNi/q+ xrXRtAgEZRciMNgCQB4xInyIUYJtzHnjwu5cBzF78VrtyGTPHaWdpdXB0TP1OQYnjY1T 00fQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cisco.com header.s=iport header.b=h4SjvRAK; 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 e13-v6si1509791plo.242.2018.02.16.12.40.39; Fri, 16 Feb 2018 12:40:53 -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=h4SjvRAK; 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 S1751151AbeBPUjW (ORCPT + 99 others); Fri, 16 Feb 2018 15:39:22 -0500 Received: from rcdn-iport-3.cisco.com ([173.37.86.74]:52500 "EHLO rcdn-iport-3.cisco.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750782AbeBPUd6 (ORCPT ); Fri, 16 Feb 2018 15:33:58 -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=1518813238; x=1520022838; h=from:to:cc:subject:date:message-id:in-reply-to: references; bh=kPtfKRZKS/cOHG4AIpt4bEc+kdJD6gX/yiPBjFXhWw4=; b=h4SjvRAK8FJ9it5aT6hjs2si4jDKj1R3KIDpDG2ye/I8VEK4+IamUDUS 5rs8MJ5lmd6s9GPN3OXEzoMOaBMsjCVCQS3Q7VitIhhgBl3+GsybdJI30 QxgcKtzSzZ5/JGGyX/jc/HAOItyL261/N7CgkfoTGKT54CtG1dEfL3qVv s=; X-IronPort-AV: E=Sophos;i="5.46,520,1511827200"; d="scan'208";a="346479128" Received: from rcdn-core-6.cisco.com ([173.37.93.157]) by rcdn-iport-3.cisco.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 16 Feb 2018 20:33:57 +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 w1GKXsMR015412 (version=TLSv1/SSLv3 cipher=AES128-SHA256 bits=128 verify=NO); Fri, 16 Feb 2018 20:33:56 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 v3 02/15] initramfs: replace states with function pointers Date: Fri, 16 Feb 2018 20:33:38 +0000 Message-Id: <1518813234-5874-3-git-send-email-takondra@cisco.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1518813234-5874-1-git-send-email-takondra@cisco.com> References: <1518813234-5874-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