0N/A/*
2348N/A * Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved.
0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0N/A *
0N/A * This code is free software; you can redistribute it and/or modify it
0N/A * under the terms of the GNU General Public License version 2 only, as
0N/A * published by the Free Software Foundation.
0N/A *
0N/A * This code is distributed in the hope that it will be useful, but WITHOUT
0N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0N/A * version 2 for more details (a copy is included in the LICENSE file that
0N/A * accompanied this code).
0N/A *
0N/A * You should have received a copy of the GNU General Public License version
0N/A * 2 along with this work; if not, write to the Free Software Foundation,
0N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0N/A *
1472N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1472N/A * or visit www.oracle.com if you need additional information or have any
1472N/A * questions.
0N/A *
0N/A */
0N/A
1879N/A#ifndef SHARE_VM_GC_IMPLEMENTATION_PARALLELSCAVENGE_PSPERMGEN_HPP
1879N/A#define SHARE_VM_GC_IMPLEMENTATION_PARALLELSCAVENGE_PSPERMGEN_HPP
1879N/A
1879N/A#include "gc_implementation/parallelScavenge/psOldGen.hpp"
1879N/A
0N/Aclass AdaptivePaddedAverage;
0N/A
0N/Aclass PSPermGen : public PSOldGen {
0N/A friend class VMStructs;
0N/A protected:
0N/A AdaptivePaddedAverage* _avg_size; // Used for sizing
0N/A size_t _last_used; // Amount used at last GC, used for sizing
0N/A
0N/A public:
0N/A // Initialize the generation.
0N/A PSPermGen(ReservedSpace rs, size_t alignment, size_t initial_byte_size,
0N/A size_t minimum_byte_size, size_t maximum_byte_size,
0N/A const char* gen_name, int level);
0N/A
0N/A // Permanent Gen special allocation. Uses the OldGen allocation
0N/A // routines, which should not be directly called on this generation.
0N/A HeapWord* allocate_permanent(size_t word_size);
0N/A
0N/A // Size calculation.
0N/A void compute_new_size(size_t used_before_collection);
0N/A
0N/A // MarkSweep code
0N/A virtual void precompact();
0N/A
0N/A virtual const char* name() const { return "PSPermGen"; }
0N/A};
1879N/A
1879N/A#endif // SHARE_VM_GC_IMPLEMENTATION_PARALLELSCAVENGE_PSPERMGEN_HPP