chromium/native_client_sdk/src/libraries/nacl_io/inode_pool.h

// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef LIBRARIES_NACL_IO_INODE_POOL_H_
#define LIBRARIES_NACL_IO_INODE_POOL_H_

#include <stdlib.h>
#include <vector>

#include "nacl_io/osstat.h"
#include "pthread.h"
#include "sdk_util/auto_lock.h"

namespace nacl_io {

class INodePool {
 public:
  INodePool() : num_nodes_(0), max_nodes_(0) {}

  ino_t Acquire() {
    AUTO_LOCK(lock_);
    const int INO_CNT = 8;

    // If we run out of INO numbers, then allocate 8 more
    if (inos_.size() == 0) {
      max_nodes_ += INO_CNT;
      // Add eight more to the stack in reverse order, offset by 1
      // since '0' refers to no INO.
      for (int a = 0; a < INO_CNT; a++) {
        inos_.push_back(max_nodes_ - a);
      }
    }

    // Return the INO at the top of the stack.
    int val = inos_.back();
    inos_.pop_back();
    num_nodes_++;
    return val;
  }

  void Release(ino_t ino) {
    AUTO_LOCK(lock_);
    inos_.push_back(ino);
    num_nodes_--;
  }

  size_t size() const { return num_nodes_; }
  size_t capacity() const { return max_nodes_; }

 private:
  size_t num_nodes_;
  size_t max_nodes_;
  std::vector<ino_t> inos_;
  sdk_util::SimpleLock lock_;
};

}  // namespace nacl_io

#endif  // LIBRARIES_NACL_IO_INODE_POOL_H_