mutexes.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. #ifndef LIBHDFS_MUTEXES_H
  19. #define LIBHDFS_MUTEXES_H
  20. /*
  21. * Defines abstraction over platform-specific mutexes. libhdfs has no formal
  22. * initialization function that users would call from a single-threaded context
  23. * to initialize the library. This creates a challenge for bootstrapping the
  24. * mutexes. To address this, all required mutexes are pre-defined here with
  25. * external storage. Platform-specific implementations must guarantee that the
  26. * mutexes are initialized via static initialization.
  27. */
  28. #include "platform.h"
  29. /** Mutex protecting the class reference hash table. */
  30. extern mutex hdfsHashMutex;
  31. /** Mutex protecting singleton JVM instance. */
  32. extern mutex jvmMutex;
  33. /**
  34. * Locks a mutex.
  35. *
  36. * @param m mutex
  37. * @return 0 if successful, non-zero otherwise
  38. */
  39. int mutexLock(mutex *m);
  40. /**
  41. * Unlocks a mutex.
  42. *
  43. * @param m mutex
  44. * @return 0 if successful, non-zero otherwise
  45. */
  46. int mutexUnlock(mutex *m);
  47. #endif