1
/* gras_stub_generator - creates the main() to use a GRAS program */
3
/* Copyright (c) 2003-2007 Martin Quinson, Arnaud Legrand, Malek Cherier. */
4
/* All rights reserved. */
6
/* This program is free software; you can redistribute it and/or modify it
7
* under the terms of the license (GNU LGPL) which comes with this package. */
9
/* specific to Borland Compiler */
15
#include "xbt/sysdep.h"
16
#include "xbt/function_types.h"
18
#include "surf/surfxml_parse.h"
19
#include "surf/surf.h"
20
#include "portable.h" /* Needed for the time of the SIMIX convertion */
21
#include "gras_stub_generator.h"
26
/* stupid stubs so that it compiles on windows */
27
void generate_sim(char *project)
31
void generate_rl(char *project)
35
void generate_makefile_local(char *project, char *deployment)
39
/* real implementation */
40
XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(stubgen);
43
#define WARN "/***********\n * DO NOT EDIT! THIS FILE HAS BEEN AUTOMATICALLY GENERATED FROM %s BY gras_stub_generator\n ***********/\n"
44
#define SIM_SOURCENAME "_%s_simulator.c"
45
#define SIM_OBJNAME "_%s_simulator.o"
46
#define SIM_BINARYNAME "%s_simulator"
47
#define SIM_SOURCENAME_LDADD "%s_simulator_LDADD"
48
#define SIM_SOURCENAME_SOURCES "%s_simulator_SOURCES"
49
#define RL_SOURCENAME "_%s_%s.c"
50
#define RL_OBJNAME "_%s_%s.o"
51
#define RL_BINARYNAME "%s_%s"
52
#define RL_SOURCENAME_LDADD "%s_%s_LDADD"
53
#define RL_SOURCENAME_SOURCES "%s_%s_SOURCES"
54
#define MAKEFILE_FILENAME_AM "%s.Makefile.am"
55
#define MAKEFILE_FILENAME_LOCAL "%s.mk"
56
#define MAKEFILE_FILENAME_REMOTE "%s.Makefile.remote"
57
#define DEPLOYMENT "%s.deploy.sh"
59
/**********************************************/
60
/**** Generate the file for the simulator *****/
61
/**********************************************/
63
const char *SIM_PREEMBULE =
64
"/* specific to Borland Compiler */\n"
65
"#ifdef __BORLANDC__\n"
68
"#include <stdlib.h>\n"
69
"#include <stdio.h>\n"
70
"#include \"msg/msg.h\"\n"
71
"#include <gras.h>\n" "\n" "char *gras_log=NULL;\n";
74
#define SIM_LAUNCH_FUNC \
75
"int launch_%s(int argc, char **argv) {\n" \
76
" char **myargv=argv;\n" \
77
" int myargc=argc;\n" \
82
" myargv=malloc((argc+1) * sizeof(char**));\n" \
83
" for (i=0; i<argc; i++)\n" \
84
" myargv[i] = argv[i];\n" \
85
" myargv[myargc++] = gras_log;\n" \
87
" retcode = %s(myargc,myargv);\n" \
88
" if (myargv != argv)\n" \
90
" return retcode;\n" \
93
const char *SIM_MAIN_POSTEMBULE = "\n"
95
" gras_launch_application(argv[2]);\n"
97
" /* Run the simulation */\n"
100
" /* cleanup the place */\n"
102
" if (gras_log)\n" " free(gras_log);\n" " return 0;\n" "}\n";
107
void generate_sim(char *project)
109
xbt_dict_cursor_t cursor = NULL;
112
char *filename = NULL;
115
/* Output file: <projet>_simulator.c */
116
filename = xbt_new(char, strlen(project) + strlen(SIM_SOURCENAME));
117
sprintf(filename, SIM_SOURCENAME, project);
119
FICOUT = fopen(filename, "w");
121
xbt_assert(FICOUT, "Unable to open %s for writing", filename);
123
fprintf(FICOUT, "%s\n", warning);
124
fprintf(FICOUT, "%s", SIM_PREEMBULE);
126
xbt_dict_foreach(process_function_set, cursor, key, data) {
127
fprintf(FICOUT, "int %s(int argc,char *argv[]);\n", key);
130
fprintf(FICOUT, "\n");
132
xbt_dict_foreach(process_function_set, cursor, key, data) {
133
fprintf(FICOUT, "int launch_%s(int argc,char *argv[]);\n", key);
136
fprintf(FICOUT, "\n%s\n", warning);
138
xbt_dict_foreach(process_function_set, cursor, key, data) {
139
fprintf(FICOUT, SIM_LAUNCH_FUNC, key, key);
141
fprintf(FICOUT, "\n%s\n", warning);
143
fprintf(FICOUT, "%s", "/* specific to Borland Compiler */\n"
144
"#ifdef __BORLANDDC__\n" "#pragma argsused\n" "#endif\n\n");
146
fprintf(FICOUT, "%s", "int main (int argc,char *argv[]) {\n"
148
" /* Simulation setup */\n"
149
" gras_global_init(&argc,argv);\n"
150
" if (argc != 3) {\n"
151
" fprintf(stderr, \"Usage: %s platform.xml deployment.xml [--log=...]\\n\",argv[0]);\n"
152
" exit(1);\n" " }\n" "\n");
154
" gras_create_environment(argv[1]);\n"
155
"\n" " /* Application deployment */\n");
156
xbt_dict_foreach(process_function_set, cursor, key, data) {
157
fprintf(FICOUT, " gras_function_register(\"%s\", launch_%s);\n", key,
160
fprintf(FICOUT, "%s", SIM_MAIN_POSTEMBULE);
165
/**********************************************/
166
/**** Generate the file for the real life *****/
167
/**********************************************/
168
void generate_rl(char *project)
170
xbt_dict_cursor_t cursor = NULL;
173
char *filename = NULL;
176
xbt_dict_foreach(process_function_set, cursor, key, data) {
179
strlen(project) + strlen(RL_SOURCENAME) + strlen(key));
181
sprintf(filename, RL_SOURCENAME, project, key);
183
FICOUT = fopen(filename, "w");
184
xbt_assert(FICOUT, "Unable to open %s for writing", filename);
186
fprintf(FICOUT, "\n%s\n", warning);
187
fprintf(FICOUT, "/* specific to Borland Compiler */\n"
188
"#ifdef __BORLANDC__\n"
191
"#include <stdio.h>\n"
192
"#include <signal.h>\n"
193
"#include <gras.h>\n"
195
"XBT_PUBLIC_DATA(const char *) _gras_procname;\n"
197
"int %s(int argc, char *argv[]);\n"
199
"/* specific to Borland Compiler */\n"
200
"#ifdef __BORLANDC__\n"
203
"int main(int argc, char *argv[]){\n"
206
" _gras_procname = \"%s\";\n"
207
" errcode=%s(argc,argv);\n"
208
" \n" " return errcode;\n" "}\n", key, key, key);
209
fprintf(FICOUT, "\n%s\n", warning);
215
void generate_makefile_am(char *project, char *deployment)
217
xbt_dict_cursor_t cursor = NULL;
220
char *filename = NULL;
223
filename = xbt_new(char, strlen(project) + strlen(MAKEFILE_FILENAME_AM));
224
sprintf(filename, MAKEFILE_FILENAME_AM, project);
226
FICOUT = fopen(filename, "w");
227
xbt_assert(FICOUT, "Unable to open %s for writing", filename);
229
fprintf(FICOUT, "# AUTOMAKE variable definition\n");
230
fprintf(FICOUT, "INCLUDES= @CFLAGS_SimGrid@\n\n");
231
fprintf(FICOUT, "PROGRAMS=");
232
fprintf(FICOUT, SIM_BINARYNAME, project);
234
xbt_dict_foreach(process_function_set, cursor, key, data) {
235
fprintf(FICOUT, " ");
236
fprintf(FICOUT, RL_BINARYNAME, project, key);
239
fprintf(FICOUT, "\n\n");
240
fprintf(FICOUT, SIM_SOURCENAME_SOURCES, project);
241
fprintf(FICOUT, "=\t");
242
fprintf(FICOUT, SIM_SOURCENAME, project);
243
fprintf(FICOUT, " %s.c\n", project);
244
fprintf(FICOUT, SIM_SOURCENAME_LDADD, project);
245
fprintf(FICOUT, "=\tpath/to/libsimgrid.a\n\n");
247
xbt_dict_foreach(process_function_set, cursor, key, data) {
248
fprintf(FICOUT, RL_SOURCENAME_SOURCES, project, key);
249
fprintf(FICOUT, "=\t");
250
fprintf(FICOUT, RL_SOURCENAME, project, key);
251
fprintf(FICOUT, " %s.c\n", project);
252
fprintf(FICOUT, RL_SOURCENAME_LDADD, project, key);
253
fprintf(FICOUT, "=\tpath/to/libgras.a\n\n");
257
"\n# cleanup temps (allowing the user to add extra clean files)\n");
258
fprintf(FICOUT, "CLEANFILES?= \n");
259
fprintf(FICOUT, "CLEANFILES+= ");
260
fprintf(FICOUT, SIM_SOURCENAME, project);
262
xbt_dict_foreach(process_function_set, cursor, key, data) {
263
fprintf(FICOUT, " ");
264
fprintf(FICOUT, RL_SOURCENAME, project, key);
266
fprintf(FICOUT, "\n");
268
fprintf(FICOUT, "\n# generate temps\n");
270
"\n# A rule to generate the source file each time the deployment file changes\n");
272
xbt_dict_foreach(process_function_set, cursor, key, data) {
273
fprintf(FICOUT, RL_SOURCENAME, project, key);
274
fprintf(FICOUT, " ");
276
fprintf(FICOUT, SIM_SOURCENAME, project);
277
fprintf(FICOUT, ": %s\n", deployment);
278
fprintf(FICOUT, "\tgras_stub_generator %s %s >/dev/null\n", project,
283
void generate_makefile_local(char *project, char *deployment)
285
xbt_dict_cursor_t cursor = NULL;
288
char *filename = NULL;
292
xbt_new(char, strlen(project) + strlen(MAKEFILE_FILENAME_LOCAL));
293
sprintf(filename, MAKEFILE_FILENAME_LOCAL, project);
295
FICOUT = fopen(filename, "w");
296
xbt_assert(FICOUT, "Unable to open %s for writing", filename);
302
"#### THIS FILE WAS GENERATED, DO NOT EDIT BEFORE RENAMING IT\n"
305
fprintf(FICOUT, "## Variable declarations\n"
306
"PROJECT_NAME=%s\n" "DISTDIR=gras-$(PROJECT_NAME)\n\n", project);
309
"# Set the GRAS_ROOT environment variable to the path under which you installed SimGrid\n"
310
"# Compilation will fail if you don't do so\n"
311
"GRAS_ROOT?= $(shell if [ -e /usr/local/lib/libgras.so ] ; then echo /usr/local ; else echo \"\\\"<<<< GRAS_ROOT undefined !!! >>>>\\\"\"; fi)\n\n"
312
"# You can fiddle the following to make it fit your taste\n"
313
"INCLUDES = -I$(GRAS_ROOT)/include\n"
314
"CFLAGS ?= -O3 -w -g -Wall\n"
315
"LIBS_SIM = -lm -L$(GRAS_ROOT)/lib/ -lsimgrid\n"
316
"LIBS_RL = -lm -L$(GRAS_ROOT)/lib/ -lgras\n" "LIBS = \n" "\n");
318
fprintf(FICOUT, "PRECIOUS_C_FILES ?= %s.c\n", project);
320
fprintf(FICOUT, "GENERATED_C_FILES = ");
321
fprintf(FICOUT, SIM_SOURCENAME " ", project);
322
xbt_dict_foreach(process_function_set, cursor, key, data) {
323
fprintf(FICOUT, RL_SOURCENAME " ", project, key);
325
fprintf(FICOUT, "\n");
328
"OBJ_FILES = $(patsubst %%.c,%%.o,$(PRECIOUS_C_FILES))\n");
330
fprintf(FICOUT, "BIN_FILES = ");
332
fprintf(FICOUT, SIM_BINARYNAME " ", project);
333
xbt_dict_foreach(process_function_set, cursor, key, data) {
334
fprintf(FICOUT, RL_BINARYNAME " ", project, key);
336
fprintf(FICOUT, "\n");
340
"## By default, build all the binaries\n"
341
"all: $(BIN_FILES)\n" "\n");
344
"\n## generate temps: regenerate the source file each time the deployment file changes\n");
345
xbt_dict_foreach(process_function_set, cursor, key, data) {
346
fprintf(FICOUT, RL_SOURCENAME, project, key);
347
fprintf(FICOUT, " ");
349
fprintf(FICOUT, SIM_SOURCENAME, project);
350
fprintf(FICOUT, ": %s\n", deployment);
351
fprintf(FICOUT, "\tgras_stub_generator %s %s >/dev/null\n", project,
354
fprintf(FICOUT, "\n## Generate the binaries\n");
355
fprintf(FICOUT, SIM_BINARYNAME ": " SIM_OBJNAME " $(OBJ_FILES)\n",
358
"\t$(CC) $(INCLUDES) $(DEFS) $(CFLAGS) $^ $(LIBS_SIM) $(LIBS) $(LDADD) -o $@ \n");
359
xbt_dict_foreach(process_function_set, cursor, key, data) {
360
fprintf(FICOUT, RL_BINARYNAME " : " RL_OBJNAME " $(OBJ_FILES)\n",
361
project, key, project, key);
363
"\t$(CC) $(INCLUDES) $(DEFS) $(CFLAGS) $^ $(LIBS_RL) $(LIBS) $(LDADD) -o $@ \n");
368
"\t$(CC) $(INCLUDES) $(DEFS) $(CFLAGS) $^ $(LIBS) $(LDADD) -o $@ \n"
371
"\t$(CC) $(INCLUDES) $(DEFS) $(CFLAGS) -c -o $@ $<\n" "\n");
374
"## Rules for tarballs and cleaning\n"
375
"DIST_FILES= $(EXTRA_DIST) $(GENERATED_C_FILES) $(PRECIOUS_C_FILES) "
376
MAKEFILE_FILENAME_LOCAL " " /*MAKEFILE_FILENAME_REMOTE */ "\n"
377
"distdir: $(DIST_FILES)\n" "\trm -rf $(DISTDIR)\n"
378
"\tmkdir -p $(DISTDIR)\n" "\tcp $^ $(DISTDIR)\n" "\n"
379
"dist: clean distdir\n"
380
"\ttar c $(DISTDIR) | gzip -c9 > $(DISTDIR).tar.gz\n" "\n",
381
project /*, project */ );
385
"\trm -f $(CLEANFILES) $(BIN_FILES) $(OBJ_FILES) *~ %s.o "
386
SIM_OBJNAME, project, project);
387
xbt_dict_foreach(process_function_set, cursor, key, data) {
388
fprintf(FICOUT, " " RL_OBJNAME, project, key);
392
"\trm -rf $(DISTDIR)\n"
393
"\n" ".SUFFIXES:\n" ".PHONY : clean\n" "\n");
395
fprintf(FICOUT, "############ REMOTE COMPILING #########\n");
398
xbt_dict_foreach(machine_set,cursor,key,data) {
399
fprintf(FICOUT, "%s ",key);
401
fprintf(FICOUT,"\n");
404
"INSTALL_PATH ?='$$HOME/tmp/src' ### Has to be an absolute path !!! \n"
405
"GRAS_ROOT ?='$(INSTALL_PATH)' ### Has to be an absolute path !!! \n"
407
"SIMGRID_URL ?=http://gcl.ucsd.edu/simgrid/dl/\n"
408
"SIMGRID_VERSION ?=2.92\n"
409
"GRAS_PROJECT ?= %s\n"
410
"GRAS_PROJECT_URL ?= http://www-id.imag.fr/Laboratoire/Membres/Legrand_Arnaud/gras_test/\n"
413
"\t@echo;echo \"----[ Compile the package on remote hosts ]----\"\n"
414
"\t@test -e $(SRCDIR)/buildlogs/ || mkdir -p $(SRCDIR)/buildlogs/\n"
415
"\t for site in $(MACHINES) ; do \\\n"
416
"\t machine=`echo $$site |sed 's/^\\([^%%]*\\)%%.*$$/\\1/'`;\\\n"
417
"\t machine2=`echo $$site |sed 's/^\\([^%%]*\\)%%\\(.*\\)$$/\\2/'`;\\\n"
418
"\t cmd_mkdir=\"\\\"sh -c 'env INSTALL_PATH=$(INSTALL_PATH) GRAS_ROOT=$(GRAS_ROOT) \\\n"
419
"\t SIMGRID_URL=$(SIMGRID_URL) SIMGRID_VERSION=$(SIMGRID_VERSION) GRAS_PROJECT=$(GRAS_PROJECT) \\\n"
420
"\t GRAS_PROJECT_URL=$(GRAS_PROJECT_URL) mkdir -p $(INSTALL_PATH) 2>&1'\\\"\";\\\n"
421
"\t cmd_make=\"\\\"sh -c 'env INSTALL_PATH=$(INSTALL_PATH) GRAS_ROOT=$(GRAS_ROOT) \\\n"
422
"\t SIMGRID_URL=$(SIMGRID_URL) SIMGRID_VERSION=$(SIMGRID_VERSION) GRAS_PROJECT=$(GRAS_PROJECT) \\\n"
423
"\t GRAS_PROJECT_URL=$(GRAS_PROJECT_URL) make -C $(INSTALL_PATH) -f "MAKEFILE_FILENAME_REMOTE" $(ACTION) 2>&1'\\\"\";\\\n"
424
"\t if echo $$site | grep '%%' >/dev/null ; then \\\n"
425
"\t echo \"----[ Compile on $$machine2 (behind $$machine) ]----\";\\\n"
427
"\t machine=$$site;\\\n"
428
"\t echo \"----[ Compile on $$machine ]----\";\\\n"
430
"\t if echo $$site | grep '%%' >/dev/null ; then \\\n"
431
"\t if ssh $$machine \"ssh -A $$machine2 $$cmd_mkdir\" 2>&1 > $(SRCDIR)/buildlogs/$$site.log;\\\n"
432
"\t then true; else failed=1;echo \"Failed (check $(SRCDIR)/buildlogs/$$site.log)\"; fi;\\\n"
434
"\t if ssh $$machine \"eval $$cmd_mkdir\" 2>&1 > $(SRCDIR)/buildlogs/$$site.log ;\\\n"
435
"\t then true; else failed=1;echo \"Failed (check $(SRCDIR)/buildlogs/$$site.log)\"; fi; \\\n"
437
"\t echo \"-- Copy the data over\"; \\\n"
438
"\t scp "MAKEFILE_FILENAME_REMOTE" $$site:$(INSTALL_PATH) ;\\\n"
439
"\t echo \"-- Compiling... (the output gets into $(SRCDIR)/buildlogs/$$site.log)\"; \\\n"
440
"\t if echo $$site | grep '%%' >/dev/null ; then \\\n"
441
"\t if ssh $$machine \"ssh -A $$machine2 $$cmd_make\" 2>&1 >> $(SRCDIR)/buildlogs/$$site.log;\\\n"
442
"\t then echo \"Sucessful\"; else failed=1;echo \"Failed (check $(SRCDIR)/buildlogs/$$site.log)\"; fi;echo; \\\n"
444
"\t if ssh $$machine \"eval $$cmd_make\" 2>&1 >> $(SRCDIR)/buildlogs/$$site.log ;\\\n"
445
"\t then echo \"Sucessful\"; else failed=1;echo \"Failed (check $(SRCDIR)/buildlogs/$$site.log)\"; fi;echo; \\\n"
447
"\t done;\n",project,project,project);
452
static void print(void *p)