diff --git a/var/spack/repos/builtin/packages/timemory/package.py b/var/spack/repos/builtin/packages/timemory/package.py
index 717de208df50ec24ecff081a221ceef0817a4efb..d11ac8a62ccd3b292bb2001d1467bab40f18e11c 100644
--- a/var/spack/repos/builtin/packages/timemory/package.py
+++ b/var/spack/repos/builtin/packages/timemory/package.py
@@ -16,16 +16,24 @@ class Timemory(CMakePackage):
     maintainers = ['jrmadsen']
 
     version('master', branch='master', submodules=True)
+    version('develop', branch='develop', submodules=True)
+    version('3.0.0', commit='b36b1673b2c6b7ff3126d8261bef0f8f176c7beb',
+            submodules=True)
 
     variant('python', default=True, description='Enable Python support')
     variant('mpi', default=False, description='Enable MPI support')
+    variant('tau', default=True, description='Enable TAU support')
     variant('papi', default=True, description='Enable PAPI support')
     variant('cuda', default=True, description='Enable CUDA support')
     variant('cupti', default=True, description='Enable CUPTI support')
+    variant('upcxx', default=False, description='Enable UPC++ support')
+    variant('gotcha', default=True, description='Enable GOTCHA support')
+    variant('likwid', default=True, description='Enable LIKWID support')
     variant('caliper', default=True, description='Enable Caliper support')
-    variant('gperftools', default=True, description='Enable gperftools support')
+    variant('gperftools', default=True,
+            description='Enable gperftools support')
 
-    depends_on('cmake@3.10:', type='build')
+    depends_on('cmake@3.11:', type='build')
 
     extends('python', when='+python')
     depends_on('python@3:', when='+python', type=('build', 'run'))
@@ -33,29 +41,40 @@ class Timemory(CMakePackage):
     depends_on('py-pillow', when='+python', type=('run'))
     depends_on('py-matplotlib', when='+python', type=('run'))
     depends_on('mpi', when='+mpi')
+    depends_on('tau', when='+tau')
     depends_on('papi', when='+papi')
     depends_on('cuda', when='+cuda')
+    depends_on('cuda', when='+cupti')
+    depends_on('upcxx', when='+upcxx')
+    depends_on('gotcha', when='+gotcha')
+    depends_on('likwid', when='+likwid')
     depends_on('caliper', when='+caliper')
     depends_on('gperftools', when='+gperftools')
 
+    conflicts('+cupti', when='~cuda', msg='CUPTI requires CUDA')
+
     def cmake_args(self):
         spec = self.spec
 
-        # Use spack install of Caliper instead of internal build
+        # Use spack install of Caliper and/or GOTCHA
+        # instead of internal submodule build
         args = [
+            '-DTIMEMORY_BUILD_GOTCHA=OFF',
             '-DTIMEMORY_BUILD_CALIPER=OFF',
             '-DTIMEMORY_BUILD_TOOLS=ON',
+            '-DTIMEMORY_BUILD_TESTING=OFF',
             '-DTIMEMORY_BUILD_EXTRA_OPTIMIZATIONS=ON',
-            '-DTIMEMORY_BUILD_GTEST=OFF',
             '-DCMAKE_INSTALL_RPATH_USE_LINK_PATH=ON',
         ]
 
         if '+python' in spec:
             args.append('-DPYTHON_EXECUTABLE={0}'.format(
                 spec['python'].command.path))
+            args.append('-DTIMEMORY_USE_PYTHON=ON')
             args.append('-DTIMEMORY_BUILD_PYTHON=ON')
             args.append('-DTIMEMORY_TLS_MODEL=global-dynamic')
         else:
+            args.append('-DTIMEMORY_USE_PYTHON=OFF')
             args.append('-DTIMEMORY_BUILD_PYTHON=OFF')
 
         if '+caliper' in spec:
@@ -63,6 +82,16 @@ def cmake_args(self):
         else:
             args.append('-DTIMEMORY_USE_CALIPER=OFF')
 
+        if '+tau' in spec:
+            args.append('-DTIMEMORY_USE_TAU=ON')
+        else:
+            args.append('-DTIMEMORY_USE_TAU=OFF')
+
+        if '+likwid' in spec:
+            args.append('-DTIMEMORY_USE_LIKWID=ON')
+        else:
+            args.append('-DTIMEMORY_USE_LIKWID=OFF')
+
         if '+papi' in spec:
             args.append('-DTIMEMORY_USE_PAPI=ON')
             args.append('-DPAPI_ROOT_DIR={0}'.format(spec['papi'].prefix))
@@ -75,6 +104,16 @@ def cmake_args(self):
         else:
             args.append('-DTIMEMORY_USE_MPI=OFF')
 
+        if '+gotcha' in spec:
+            args.append('-DTIMEMORY_USE_GOTCHA=ON')
+        else:
+            args.append('-DTIMEMORY_USE_GOTCHA=OFF')
+
+        if '+cuda' in spec:
+            args.append('-DTIMEMORY_USE_CUDA=ON')
+        else:
+            args.append('-DTIMEMORY_USE_CUDA=OFF')
+
         if '+cupti' in spec:
             args.append('-DTIMEMORY_USE_CUPTI=ON')
         else: