aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNamhyung Kim <namhyung.kim@lge.com>2012-04-08 22:54:30 -0400
committerNamhyung Kim <namhyung@kernel.org>2012-07-04 00:40:31 -0400
commitdeba3fb26fd1ed3235b00dccced9784a7f76ec3c (patch)
tree03708b0edc3f380e316cb130d822d377032e9d69
parent0fc45ef5202a34b5862ca246740e6ab50bc3e3e1 (diff)
tools lib traceevent: Introduce extend_token()
The __read_token() function has some duplicated code to handle internal buffer overflow. Factor them out to new extend_token(). According to the man pages of realloc/free(3), they can handle NULL pointer input so that it can be ended up to compact the code. Also handle error path correctly. Signed-off-by: Namhyung Kim <namhyung.kim@lge.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Arnaldo Carvalho de Melo <acme@infradead.org> Cc: Borislav Petkov <bp@alien8.de> Cc: David Ahern <dsahern@gmail.com> Link: http://lkml.kernel.org/r/1333940074-19052-4-git-send-email-namhyung.kim@lge.com [rostedt@goodmis.org: added some extra whitespace] Signed-off-by: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Namhyung Kim <namhyung@kernel.org>
-rw-r--r--tools/lib/traceevent/event-parse.c50
1 files changed, 24 insertions, 26 deletions
diff --git a/tools/lib/traceevent/event-parse.c b/tools/lib/traceevent/event-parse.c
index 7815b8d2eabd..768fab5fbcb7 100644
--- a/tools/lib/traceevent/event-parse.c
+++ b/tools/lib/traceevent/event-parse.c
@@ -781,6 +781,25 @@ int pevent_peek_char(void)
781 return __peek_char(); 781 return __peek_char();
782} 782}
783 783
784static int extend_token(char **tok, char *buf, int size)
785{
786 char *newtok = realloc(*tok, size);
787
788 if (!newtok) {
789 free(*tok);
790 *tok = NULL;
791 return -1;
792 }
793
794 if (!*tok)
795 strcpy(newtok, buf);
796 else
797 strcat(newtok, buf);
798 *tok = newtok;
799
800 return 0;
801}
802
784static enum event_type force_token(const char *str, char **tok); 803static enum event_type force_token(const char *str, char **tok);
785 804
786static enum event_type __read_token(char **tok) 805static enum event_type __read_token(char **tok)
@@ -865,17 +884,10 @@ static enum event_type __read_token(char **tok)
865 do { 884 do {
866 if (i == (BUFSIZ - 1)) { 885 if (i == (BUFSIZ - 1)) {
867 buf[i] = 0; 886 buf[i] = 0;
868 if (*tok) { 887 tok_size += BUFSIZ;
869 *tok = realloc(*tok, tok_size + BUFSIZ);
870 if (!*tok)
871 return EVENT_NONE;
872 strcat(*tok, buf);
873 } else
874 *tok = strdup(buf);
875 888
876 if (!*tok) 889 if (extend_token(tok, buf, tok_size) < 0)
877 return EVENT_NONE; 890 return EVENT_NONE;
878 tok_size += BUFSIZ;
879 i = 0; 891 i = 0;
880 } 892 }
881 last_ch = ch; 893 last_ch = ch;
@@ -914,17 +926,10 @@ static enum event_type __read_token(char **tok)
914 while (get_type(__peek_char()) == type) { 926 while (get_type(__peek_char()) == type) {
915 if (i == (BUFSIZ - 1)) { 927 if (i == (BUFSIZ - 1)) {
916 buf[i] = 0; 928 buf[i] = 0;
917 if (*tok) { 929 tok_size += BUFSIZ;
918 *tok = realloc(*tok, tok_size + BUFSIZ);
919 if (!*tok)
920 return EVENT_NONE;
921 strcat(*tok, buf);
922 } else
923 *tok = strdup(buf);
924 930
925 if (!*tok) 931 if (extend_token(tok, buf, tok_size) < 0)
926 return EVENT_NONE; 932 return EVENT_NONE;
927 tok_size += BUFSIZ;
928 i = 0; 933 i = 0;
929 } 934 }
930 ch = __read_char(); 935 ch = __read_char();
@@ -933,14 +938,7 @@ static enum event_type __read_token(char **tok)
933 938
934 out: 939 out:
935 buf[i] = 0; 940 buf[i] = 0;
936 if (*tok) { 941 if (extend_token(tok, buf, tok_size + i + 1) < 0)
937 *tok = realloc(*tok, tok_size + i);
938 if (!*tok)
939 return EVENT_NONE;
940 strcat(*tok, buf);
941 } else
942 *tok = strdup(buf);
943 if (!*tok)
944 return EVENT_NONE; 942 return EVENT_NONE;
945 943
946 if (type == EVENT_ITEM) { 944 if (type == EVENT_ITEM) {