From 57bda698c61cfc46c8e84cab90c590378d0d513c Mon Sep 17 00:00:00 2001 From: zhixunt Date: Tue, 26 Dec 2017 22:36:14 -0500 Subject: [PATCH] Trying to add OpenGL runtime to emscripten'ed web runtime. --- Makefile | 24 +++++++++++++++++++++++- web/web_runtime.cc | 3 +++ 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 4a6ac7f3c8f30..991e1bceeab90 100644 --- a/Makefile +++ b/Makefile @@ -25,7 +25,7 @@ UNAME_S := $(shell uname -s) # The flags LLVM_CFLAGS= -fno-rtti -DDMLC_ENABLE_RTTI=0 -DDMLC_USE_FOPEN64=0 LDFLAGS = -pthread -lm -ldl -INCLUDE_FLAGS = -Iinclude -I$(DLPACK_PATH)/include -I$(DMLC_CORE_PATH)/include -IHalideIR/src -Itopi/include +INCLUDE_FLAGS = -Iinclude -I$(DLPACK_PATH)/include -I$(DMLC_CORE_PATH)/include -IHalideIR/src -Itopi/include -Iglad/include CFLAGS = -std=c++11 -Wall -O2 $(INCLUDE_FLAGS) -fPIC FRAMEWORKS = OBJCFLAGS = -fno-objc-arc @@ -52,6 +52,8 @@ METAL_SRC = $(wildcard src/runtime/metal/*.mm) CUDA_SRC = $(wildcard src/runtime/cuda/*.cc) ROCM_SRC = $(wildcard src/runtime/rocm/*.cc) OPENCL_SRC = $(wildcard src/runtime/opencl/*.cc) +OPENGL_SRC = $(wildcard src/runtime/opengl/*.cc) +GLAD_SRC = glad/src/glad.c RPC_SRC = $(wildcard src/runtime/rpc/*.cc) GRAPH_SRC = $(wildcard src/runtime/graph/*.cc) RUNTIME_SRC = $(wildcard src/runtime/*.cc) @@ -63,6 +65,8 @@ METAL_OBJ = $(patsubst src/%.mm, build/%.o, $(METAL_SRC)) CUDA_OBJ = $(patsubst src/%.cc, build/%.o, $(CUDA_SRC)) ROCM_OBJ = $(patsubst src/%.cc, build/%.o, $(ROCM_SRC)) OPENCL_OBJ = $(patsubst src/%.cc, build/%.o, $(OPENCL_SRC)) +OPENGL_OBJ = $(patsubst src/%.cc, build/%.o, $(OPENGL_SRC)) +GLAD_OBJ = $(patsubst glad/src/%.c, build/%.o, $(GLAD_SRC)) RPC_OBJ = $(patsubst src/%.cc, build/%.o, $(RPC_SRC)) GRAPH_OBJ = $(patsubst src/%.cc, build/%.o, $(GRAPH_SRC)) CC_OBJ = $(patsubst src/%.cc, build/%.o, $(CC_SRC)) $(LLVM_OBJ) @@ -113,6 +117,19 @@ else CFLAGS += -DTVM_OPENCL_RUNTIME=0 endif +ifeq ($(USE_OPENGL), 1) + CFLAGS += -DTVM_OPENGL_RUNTIME=1 + ifeq ($(UNAME_S), Darwin) + FRAMEWORKS += -framework OpenGL + else + LDFLAGS += -lGL -lglfw + endif + RUNTIME_DEP += $(OPENGL_OBJ) + RUNTIME_DEP += $(GLAD_OBJ) +else + CFLAGS += -DTVM_OPENGL_RUNTIME=0 +endif + ifeq ($(USE_METAL), 1) CFLAGS += -DTVM_METAL_RUNTIME=1 LDFLAGS += -lobjc @@ -194,6 +211,11 @@ build/runtime/metal/%.o: src/runtime/metal/%.mm $(CXX) $(OBJCFLAGS) $(CFLAGS) -MM -MT build/runtime/metal/$*.o $< >build/runtime/metal/$*.d $(CXX) $(OBJCFLAGS) -c $(CFLAGS) -c $< -o $@ +build/glad.o: glad/src/glad.c + @mkdir -p $(@D) + $(CXX) $(CFLAGS) -MM -MT build/glad.o $< >build/glad.d + $(CXX) -c $(CFLAGS) -c glad/src/glad.c -o build/glad.o + build/%.o: src/%.cc @mkdir -p $(@D) $(CXX) $(CFLAGS) -MM -MT build/$*.o $< >build/$*.d diff --git a/web/web_runtime.cc b/web/web_runtime.cc index 56538733025b2..b080bb750bbe6 100644 --- a/web/web_runtime.cc +++ b/web/web_runtime.cc @@ -18,6 +18,9 @@ #include "../src/runtime/rpc/rpc_event_impl.cc" #include "../src/runtime/rpc/rpc_server_env.cc" #include "../src/runtime/graph/graph_runtime.cc" +#include "../src/runtime/opengl/opengl_device_api.cc" +#include "../src/runtime/opengl/opengl_module.cc" +#include "../glad/src/glad.c" namespace tvm { namespace contrib {