blob: 31c2d09c6b7eb8f20b08d40ef7b6a3ff5094d37e [file] [log] [blame]
Misha Brukman8050e9e2008-12-31 17:40:52 +00001/*===- llvm-stub.c - Stub executable to run llvm bitcode files ------------===//
Michael J. Spencera71b4ba2010-10-07 18:51:10 +00002//
Chris Lattner4c6d1242004-06-01 23:48:45 +00003// The LLVM Compiler Infrastructure
4//
Chris Lattnercf786592007-12-29 20:47:37 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Michael J. Spencera71b4ba2010-10-07 18:51:10 +00007//
Chris Lattner4c6d1242004-06-01 23:48:45 +00008//===----------------------------------------------------------------------===//
9//
10// This tool is used by the gccld program to enable transparent execution of
Gabor Greifdb5565a2007-07-06 20:28:40 +000011// bitcode files by the user. Specifically, gccld outputs two files when asked
Chris Lattner4c6d1242004-06-01 23:48:45 +000012// to compile a <program> file:
Gabor Greifdb5565a2007-07-06 20:28:40 +000013// 1. It outputs the LLVM bitcode file to <program>.bc
Chris Lattner4c6d1242004-06-01 23:48:45 +000014// 2. It outputs a stub executable that runs lli on <program>.bc
15//
16// This allows the end user to just say ./<program> and have the JIT executed
17// automatically. On unix, the stub executable emitted is actually a bourne
Misha Brukmanfff0ff82004-06-02 00:29:52 +000018// shell script that does the forwarding. Windows does not like #!/bin/sh
Chris Lattner4c6d1242004-06-01 23:48:45 +000019// programs in .exe files, so we make it an actual program, defined here.
20//
21//===----------------------------------------------------------------------===*/
22
23#include <stdio.h>
24#include <stdlib.h>
25#include <string.h>
Reid Spencer3000cbf2004-12-20 04:34:36 +000026
27#include "llvm/Config/config.h"
28
29#if defined(HAVE_UNISTD_H) && !defined(_MSC_VER)
30#include <unistd.h>
31#endif
32
33#ifdef _WIN32
34#include <process.h>
35#include <io.h>
36#endif
Chris Lattner4c6d1242004-06-01 23:48:45 +000037
38int main(int argc, char** argv) {
39 const char *Interp = getenv("LLVMINTERP");
40 const char **Args;
41 if (Interp == 0) Interp = "lli";
42
43 /* Set up the command line options to pass to the JIT. */
44 Args = (const char**)malloc(sizeof(char*) * (argc+2));
45 /* argv[0] is the JIT */
46 Args[0] = Interp;
Chris Lattnerf7e92b12004-06-02 00:04:54 +000047
Argyrios Kyrtzidise2bc1cb2008-06-15 12:07:01 +000048#ifdef LLVM_ON_WIN32
Duncan Sands9954c762008-06-19 08:47:31 +000049 {
50 int len = strlen(argv[0]);
51 if (len < 4 || strcmp(argv[0] + len - 4, ".exe") != 0) {
52 /* .exe suffix is stripped off of argv[0] if the executable was run on the
53 * command line without one. Put it back on.
54 */
55 argv[0] = strcat(strcpy((char*)malloc(len + 5), argv[0]), ".exe");
56 }
Argyrios Kyrtzidise2bc1cb2008-06-15 12:07:01 +000057 }
Chris Lattnerf7e92b12004-06-02 00:04:54 +000058#endif
59
Chris Lattner4c6d1242004-06-01 23:48:45 +000060 /* argv[1] is argv[0] + ".bc". */
61 Args[1] = strcat(strcpy((char*)malloc(strlen(argv[0])+4), argv[0]), ".bc");
62
63 /* The rest of the args are as before. */
Benjamin Kramer6b831982009-08-11 11:01:19 +000064 memcpy((char **)Args+2, argv+1, sizeof(char*)*argc);
Chris Lattner4c6d1242004-06-01 23:48:45 +000065
66 /* Run the JIT. */
Benjamin Kramercb2caf72010-10-16 15:43:02 +000067#ifndef _WIN32
68 execvp(Interp, (char **)Args); /* POSIX execvp takes a char *const[]. */
69#else
70 execvp(Interp, Args); /* windows execvp takes a const char *const *. */
71#endif
Chris Lattner4c6d1242004-06-01 23:48:45 +000072 /* if _execv returns, the JIT could not be started. */
73 fprintf(stderr, "Could not execute the LLVM JIT. Either add 'lli' to your"
74 " path, or set the\ninterpreter you want to use in the LLVMINTERP "
75 "environment variable.\n");
76 return 1;
77}