Summary: Now that we have userspace persisted cache, we don't need flashcache anymore. Closes https://github.com/facebook/rocksdb/pull/1588 Differential Revision: D4245114 Pulled By: igorcanadi fbshipit-source-id: e2c1c72main
							parent
							
								
									b77007df8b
								
							
						
					
					
						commit
						3f407b065c
					
				| @ -1,25 +0,0 @@ | |||||||
| // Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.
 |  | ||||||
| // This source code is licensed under the BSD-style license found in the
 |  | ||||||
| // LICENSE file in the root directory of this source tree. An additional grant
 |  | ||||||
| // of patent rights can be found in the PATENTS file in the same directory.
 |  | ||||||
| 
 |  | ||||||
| #pragma once |  | ||||||
| 
 |  | ||||||
| #include <string> |  | ||||||
| #include "rocksdb/env.h" |  | ||||||
| 
 |  | ||||||
| namespace rocksdb { |  | ||||||
| 
 |  | ||||||
| // This API is experimental. We will mark it stable once we run it in production
 |  | ||||||
| // for a while.
 |  | ||||||
| // NewFlashcacheAwareEnv() creates and Env that blacklists all background
 |  | ||||||
| // threads (used for flush and compaction) from using flashcache to cache their
 |  | ||||||
| // reads. Reads from compaction thread don't need to be cached because they are
 |  | ||||||
| // going to be soon made obsolete (due to nature of compaction)
 |  | ||||||
| // Usually you would pass Env::Default() as base.
 |  | ||||||
| // cachedev_fd is a file descriptor of the flashcache device. Caller has to
 |  | ||||||
| // open flashcache device before calling this API.
 |  | ||||||
| extern std::unique_ptr<Env> NewFlashcacheAwareEnv( |  | ||||||
|     Env* base, const int cachedev_fd); |  | ||||||
| 
 |  | ||||||
| }  // namespace rocksdb
 |  | ||||||
| @ -1,55 +0,0 @@ | |||||||
| /****************************************************************************
 |  | ||||||
|  *  flashcache_ioctl.h |  | ||||||
|  *  FlashCache: Device mapper target for block-level disk caching |  | ||||||
|  * |  | ||||||
|  *  Copyright 2010 Facebook, Inc. |  | ||||||
|  *  Author: Mohan Srinivasan (mohan@facebook.com) |  | ||||||
|  * |  | ||||||
|  *  Based on DM-Cache: |  | ||||||
|  *   Copyright (C) International Business Machines Corp., 2006 |  | ||||||
|  *   Author: Ming Zhao (mingzhao@ufl.edu) |  | ||||||
|  * |  | ||||||
|  *  This program is free software; you can redistribute it and/or modify |  | ||||||
|  *  it under the terms of the GNU General Public License as published by |  | ||||||
|  *  the Free Software Foundation; under version 2 of the License. |  | ||||||
|  * |  | ||||||
|  *  This program is distributed in the hope that it will be useful, |  | ||||||
|  *  but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  *  GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 |  | ||||||
|  ****************************************************************************/ |  | ||||||
| 
 |  | ||||||
| #ifdef OS_LINUX |  | ||||||
| #ifndef FLASHCACHE_IOCTL_H |  | ||||||
| #define FLASHCACHE_IOCTL_H |  | ||||||
| 
 |  | ||||||
| #include <linux/types.h> |  | ||||||
| 
 |  | ||||||
| #define FLASHCACHE_IOCTL 0xfe |  | ||||||
| 
 |  | ||||||
| enum { |  | ||||||
| 	FLASHCACHEADDNCPID_CMD=200, |  | ||||||
| 	FLASHCACHEDELNCPID_CMD, |  | ||||||
| 	FLASHCACHEDELNCALL_CMD, |  | ||||||
| 	FLASHCACHEADDWHITELIST_CMD, |  | ||||||
| 	FLASHCACHEDELWHITELIST_CMD, |  | ||||||
| 	FLASHCACHEDELWHITELISTALL_CMD, |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| #define FLASHCACHEADDNCPID	_IOW(FLASHCACHE_IOCTL, FLASHCACHEADDNCPID_CMD, pid_t) |  | ||||||
| #define FLASHCACHEDELNCPID	_IOW(FLASHCACHE_IOCTL, FLASHCACHEDELNCPID_CMD, pid_t) |  | ||||||
| #define FLASHCACHEDELNCALL	_IOW(FLASHCACHE_IOCTL, FLASHCACHEDELNCALL_CMD, pid_t) |  | ||||||
| 
 |  | ||||||
| #define FLASHCACHEADDBLACKLIST		FLASHCACHEADDNCPID |  | ||||||
| #define FLASHCACHEDELBLACKLIST		FLASHCACHEDELNCPID |  | ||||||
| #define FLASHCACHEDELALLBLACKLIST	FLASHCACHEDELNCALL |  | ||||||
| 
 |  | ||||||
| #define FLASHCACHEADDWHITELIST		_IOW(FLASHCACHE_IOCTL, FLASHCACHEADDWHITELIST_CMD, pid_t) |  | ||||||
| #define FLASHCACHEDELWHITELIST		_IOW(FLASHCACHE_IOCTL, FLASHCACHEDELWHITELIST_CMD, pid_t) |  | ||||||
| #define FLASHCACHEDELALLWHITELIST	_IOW(FLASHCACHE_IOCTL, FLASHCACHEDELWHITELISTALL_CMD, pid_t) |  | ||||||
| 
 |  | ||||||
| #endif /* FLASHCACHE_IOCTL_H */ |  | ||||||
| #endif /* OS_LINUX */ |  | ||||||
| @ -1,136 +0,0 @@ | |||||||
| // Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.
 |  | ||||||
| // This source code is licensed under the BSD-style license found in the
 |  | ||||||
| // LICENSE file in the root directory of this source tree. An additional grant
 |  | ||||||
| // of patent rights can be found in the PATENTS file in the same directory.
 |  | ||||||
| 
 |  | ||||||
| #include "utilities/flashcache/flashcache.h" |  | ||||||
| 
 |  | ||||||
| #include "rocksdb/utilities/flashcache.h" |  | ||||||
| 
 |  | ||||||
| #ifdef OS_LINUX |  | ||||||
| #include <fcntl.h> |  | ||||||
| #include <sys/ioctl.h> |  | ||||||
| #include <sys/stat.h> |  | ||||||
| #include <sys/syscall.h> |  | ||||||
| #include <unistd.h> |  | ||||||
| 
 |  | ||||||
| #include "third-party/flashcache/flashcache_ioctl.h" |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| namespace rocksdb { |  | ||||||
| 
 |  | ||||||
| #if !defined(ROCKSDB_LITE) && defined(OS_LINUX) |  | ||||||
| // Most of the code that handles flashcache is copied from websql's branch of
 |  | ||||||
| // mysql-5.6
 |  | ||||||
| class FlashcacheAwareEnv : public EnvWrapper { |  | ||||||
|  public: |  | ||||||
|   FlashcacheAwareEnv(Env* base, int cachedev_fd) |  | ||||||
|       : EnvWrapper(base), cachedev_fd_(cachedev_fd) { |  | ||||||
|     pid_t pid = getpid(); |  | ||||||
|     /* cleanup previous whitelistings */ |  | ||||||
|     if (ioctl(cachedev_fd_, FLASHCACHEDELALLWHITELIST, &pid) < 0) { |  | ||||||
|       cachedev_fd_ = -1; |  | ||||||
|       fprintf(stderr, "ioctl del-all-whitelist for flashcache failed\n"); |  | ||||||
|       return; |  | ||||||
|     } |  | ||||||
|     if (ioctl(cachedev_fd_, FLASHCACHEADDWHITELIST, &pid) < 0) { |  | ||||||
|       fprintf(stderr, "ioctl add-whitelist for flashcache failed\n"); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   ~FlashcacheAwareEnv() { |  | ||||||
|     // cachedev_fd_ is -1 if it's unitialized
 |  | ||||||
|     if (cachedev_fd_ != -1) { |  | ||||||
|       pid_t pid = getpid(); |  | ||||||
|       if (ioctl(cachedev_fd_, FLASHCACHEDELWHITELIST, &pid) < 0) { |  | ||||||
|         fprintf(stderr, "ioctl del-whitelist for flashcache failed\n"); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   static int BlacklistCurrentThread(int cachedev_fd) { |  | ||||||
|     pid_t pid = static_cast<pid_t>(syscall(SYS_gettid)); |  | ||||||
|     return ioctl(cachedev_fd, FLASHCACHEADDNCPID, &pid); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   static int WhitelistCurrentThread(int cachedev_fd) { |  | ||||||
|     pid_t pid = static_cast<pid_t>(syscall(SYS_gettid)); |  | ||||||
|     return ioctl(cachedev_fd, FLASHCACHEDELNCPID, &pid); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   int GetFlashCacheFileDescriptor() { return cachedev_fd_; } |  | ||||||
| 
 |  | ||||||
|   struct Arg { |  | ||||||
|     Arg(void (*f)(void* arg), void* a, int _cachedev_fd) |  | ||||||
|         : original_function_(f), original_arg_(a), cachedev_fd(_cachedev_fd) {} |  | ||||||
| 
 |  | ||||||
|     void (*original_function_)(void* arg); |  | ||||||
|     void* original_arg_; |  | ||||||
|     int cachedev_fd; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   static void BgThreadWrapper(void* a) { |  | ||||||
|     Arg* arg = reinterpret_cast<Arg*>(a); |  | ||||||
|     if (arg->cachedev_fd != -1) { |  | ||||||
|       if (BlacklistCurrentThread(arg->cachedev_fd) < 0) { |  | ||||||
|         fprintf(stderr, "ioctl add-nc-pid for flashcache failed\n"); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     arg->original_function_(arg->original_arg_); |  | ||||||
|     if (arg->cachedev_fd != -1) { |  | ||||||
|       if (WhitelistCurrentThread(arg->cachedev_fd) < 0) { |  | ||||||
|         fprintf(stderr, "ioctl del-nc-pid for flashcache failed\n"); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     delete arg; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   int UnSchedule(void* arg, Priority pri) override { |  | ||||||
|     // no unschedule for you
 |  | ||||||
|     return 0; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   void Schedule(void (*f)(void* arg), void* a, Priority pri, |  | ||||||
|                 void* tag = nullptr, void (*u)(void* arg) = 0) override { |  | ||||||
|     EnvWrapper::Schedule(&BgThreadWrapper, new Arg(f, a, cachedev_fd_), pri, |  | ||||||
|                          tag); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|  private: |  | ||||||
|   int cachedev_fd_; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| std::unique_ptr<Env> NewFlashcacheAwareEnv(Env* base, |  | ||||||
|                                            const int cachedev_fd) { |  | ||||||
|   std::unique_ptr<Env> ret(new FlashcacheAwareEnv(base, cachedev_fd)); |  | ||||||
|   return ret; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| int FlashcacheBlacklistCurrentThread(Env* flashcache_aware_env) { |  | ||||||
|   int fd = dynamic_cast<FlashcacheAwareEnv*>(flashcache_aware_env) |  | ||||||
|                ->GetFlashCacheFileDescriptor(); |  | ||||||
|   if (fd == -1) { |  | ||||||
|     return -1; |  | ||||||
|   } |  | ||||||
|   return FlashcacheAwareEnv::BlacklistCurrentThread(fd); |  | ||||||
| } |  | ||||||
| int FlashcacheWhitelistCurrentThread(Env* flashcache_aware_env) { |  | ||||||
|   int fd = dynamic_cast<FlashcacheAwareEnv*>(flashcache_aware_env) |  | ||||||
|                ->GetFlashCacheFileDescriptor(); |  | ||||||
|   if (fd == -1) { |  | ||||||
|     return -1; |  | ||||||
|   } |  | ||||||
|   return FlashcacheAwareEnv::WhitelistCurrentThread(fd); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #else   // !defined(ROCKSDB_LITE) && defined(OS_LINUX)
 |  | ||||||
| std::unique_ptr<Env> NewFlashcacheAwareEnv(Env* base, |  | ||||||
|                                            const int cachedev_fd) { |  | ||||||
|   return nullptr; |  | ||||||
| } |  | ||||||
| int FlashcacheBlacklistCurrentThread(Env* flashcache_aware_env) { return -1; } |  | ||||||
| int FlashcacheWhitelistCurrentThread(Env* flashcache_aware_env) { return -1; } |  | ||||||
| 
 |  | ||||||
| #endif  // !defined(ROCKSDB_LITE) && defined(OS_LINUX)
 |  | ||||||
| 
 |  | ||||||
| }  // namespace rocksdb
 |  | ||||||
| @ -1,18 +0,0 @@ | |||||||
| // Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.
 |  | ||||||
| // This source code is licensed under the BSD-style license found in the
 |  | ||||||
| // LICENSE file in the root directory of this source tree. An additional grant
 |  | ||||||
| // of patent rights can be found in the PATENTS file in the same directory.
 |  | ||||||
| 
 |  | ||||||
| #pragma once |  | ||||||
| 
 |  | ||||||
| #include <string> |  | ||||||
| #include "rocksdb/env.h" |  | ||||||
| 
 |  | ||||||
| namespace rocksdb { |  | ||||||
| 
 |  | ||||||
| // This is internal API that will make hacking on flashcache easier. Not sure if
 |  | ||||||
| // we need to expose this to public users, probably not
 |  | ||||||
| extern int FlashcacheBlacklistCurrentThread(Env* flashcache_aware_env); |  | ||||||
| extern int FlashcacheWhitelistCurrentThread(Env* flashcache_aware_env); |  | ||||||
| 
 |  | ||||||
| }  // namespace rocksdb
 |  | ||||||
					Loading…
					
					
				
		Reference in new issue
	
	 Igor Canadi
						Igor Canadi