From fa3b99342326219f90a25f7c75f3c1559022a205 Mon Sep 17 00:00:00 2001 From: John Cuthbertson Date: Wed, 10 Apr 2013 10:57:34 -0700 Subject: [PATCH 01/50] 8010780: G1: Eden occupancy/capacity output wrong after a full GC Move the calculation and recording of eden capacity to the start of a GC and print a detailed heap transition for full GCs. Reviewed-by: tschatzl, jmasa --- .../gc_implementation/g1/g1CollectedHeap.cpp | 398 +++++++++--------- .../g1/g1CollectorPolicy.cpp | 33 +- .../g1/g1CollectorPolicy.hpp | 30 +- 3 files changed, 237 insertions(+), 224 deletions(-) diff --git a/hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp b/hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp index 610942585e7..4d1dd34ca04 100644 --- a/hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp +++ b/hotspot/src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1322,234 +1322,240 @@ bool G1CollectedHeap::do_collection(bool explicit_gc, gclog_or_tty->date_stamp(G1Log::fine() && PrintGCDateStamps); TraceCPUTime tcpu(G1Log::finer(), true, gclog_or_tty); - TraceTime t(GCCauseString("Full GC", gc_cause()), G1Log::fine(), true, gclog_or_tty); - TraceCollectorStats tcs(g1mm()->full_collection_counters()); - TraceMemoryManagerStats tms(true /* fullGC */, gc_cause()); - - double start = os::elapsedTime(); - g1_policy()->record_full_collection_start(); - - // Note: When we have a more flexible GC logging framework that - // allows us to add optional attributes to a GC log record we - // could consider timing and reporting how long we wait in the - // following two methods. - wait_while_free_regions_coming(); - // If we start the compaction before the CM threads finish - // scanning the root regions we might trip them over as we'll - // be moving objects / updating references. So let's wait until - // they are done. By telling them to abort, they should complete - // early. - _cm->root_regions()->abort(); - _cm->root_regions()->wait_until_scan_finished(); - append_secondary_free_list_if_not_empty_with_lock(); - - gc_prologue(true); - increment_total_collections(true /* full gc */); - increment_old_marking_cycles_started(); - - size_t g1h_prev_used = used(); - assert(used() == recalculate_used(), "Should be equal"); - - verify_before_gc(); - - pre_full_gc_dump(); - - COMPILER2_PRESENT(DerivedPointerTable::clear()); - - // Disable discovery and empty the discovered lists - // for the CM ref processor. - ref_processor_cm()->disable_discovery(); - ref_processor_cm()->abandon_partial_discovery(); - ref_processor_cm()->verify_no_references_recorded(); - - // Abandon current iterations of concurrent marking and concurrent - // refinement, if any are in progress. We have to do this before - // wait_until_scan_finished() below. - concurrent_mark()->abort(); - - // Make sure we'll choose a new allocation region afterwards. - release_mutator_alloc_region(); - abandon_gc_alloc_regions(); - g1_rem_set()->cleanupHRRS(); - - // We should call this after we retire any currently active alloc - // regions so that all the ALLOC / RETIRE events are generated - // before the start GC event. - _hr_printer.start_gc(true /* full */, (size_t) total_collections()); - - // We may have added regions to the current incremental collection - // set between the last GC or pause and now. We need to clear the - // incremental collection set and then start rebuilding it afresh - // after this full GC. - abandon_collection_set(g1_policy()->inc_cset_head()); - g1_policy()->clear_incremental_cset(); - g1_policy()->stop_incremental_cset_building(); - - tear_down_region_sets(false /* free_list_only */); - g1_policy()->set_gcs_are_young(true); - - // See the comments in g1CollectedHeap.hpp and - // G1CollectedHeap::ref_processing_init() about - // how reference processing currently works in G1. - - // Temporarily make discovery by the STW ref processor single threaded (non-MT). - ReferenceProcessorMTDiscoveryMutator stw_rp_disc_ser(ref_processor_stw(), false); - - // Temporarily clear the STW ref processor's _is_alive_non_header field. - ReferenceProcessorIsAliveMutator stw_rp_is_alive_null(ref_processor_stw(), NULL); - - ref_processor_stw()->enable_discovery(true /*verify_disabled*/, true /*verify_no_refs*/); - ref_processor_stw()->setup_policy(do_clear_all_soft_refs); - - // Do collection work { - HandleMark hm; // Discard invalid handles created during gc - G1MarkSweep::invoke_at_safepoint(ref_processor_stw(), do_clear_all_soft_refs); - } + TraceTime t(GCCauseString("Full GC", gc_cause()), G1Log::fine(), true, gclog_or_tty); + TraceCollectorStats tcs(g1mm()->full_collection_counters()); + TraceMemoryManagerStats tms(true /* fullGC */, gc_cause()); - assert(free_regions() == 0, "we should not have added any free regions"); - rebuild_region_sets(false /* free_list_only */); + double start = os::elapsedTime(); + g1_policy()->record_full_collection_start(); - // Enqueue any discovered reference objects that have - // not been removed from the discovered lists. - ref_processor_stw()->enqueue_discovered_references(); + // Note: When we have a more flexible GC logging framework that + // allows us to add optional attributes to a GC log record we + // could consider timing and reporting how long we wait in the + // following two methods. + wait_while_free_regions_coming(); + // If we start the compaction before the CM threads finish + // scanning the root regions we might trip them over as we'll + // be moving objects / updating references. So let's wait until + // they are done. By telling them to abort, they should complete + // early. + _cm->root_regions()->abort(); + _cm->root_regions()->wait_until_scan_finished(); + append_secondary_free_list_if_not_empty_with_lock(); - COMPILER2_PRESENT(DerivedPointerTable::update_pointers()); + gc_prologue(true); + increment_total_collections(true /* full gc */); + increment_old_marking_cycles_started(); - MemoryService::track_memory_usage(); + assert(used() == recalculate_used(), "Should be equal"); - verify_after_gc(); + verify_before_gc(); - assert(!ref_processor_stw()->discovery_enabled(), "Postcondition"); - ref_processor_stw()->verify_no_references_recorded(); + pre_full_gc_dump(); - // Delete metaspaces for unloaded class loaders and clean up loader_data graph - ClassLoaderDataGraph::purge(); + COMPILER2_PRESENT(DerivedPointerTable::clear()); - // Note: since we've just done a full GC, concurrent - // marking is no longer active. Therefore we need not - // re-enable reference discovery for the CM ref processor. - // That will be done at the start of the next marking cycle. - assert(!ref_processor_cm()->discovery_enabled(), "Postcondition"); - ref_processor_cm()->verify_no_references_recorded(); + // Disable discovery and empty the discovered lists + // for the CM ref processor. + ref_processor_cm()->disable_discovery(); + ref_processor_cm()->abandon_partial_discovery(); + ref_processor_cm()->verify_no_references_recorded(); - reset_gc_time_stamp(); - // Since everything potentially moved, we will clear all remembered - // sets, and clear all cards. Later we will rebuild remebered - // sets. We will also reset the GC time stamps of the regions. - clear_rsets_post_compaction(); - check_gc_time_stamps(); + // Abandon current iterations of concurrent marking and concurrent + // refinement, if any are in progress. We have to do this before + // wait_until_scan_finished() below. + concurrent_mark()->abort(); - // Resize the heap if necessary. - resize_if_necessary_after_full_collection(explicit_gc ? 0 : word_size); + // Make sure we'll choose a new allocation region afterwards. + release_mutator_alloc_region(); + abandon_gc_alloc_regions(); + g1_rem_set()->cleanupHRRS(); - if (_hr_printer.is_active()) { - // We should do this after we potentially resize the heap so - // that all the COMMIT / UNCOMMIT events are generated before - // the end GC event. + // We should call this after we retire any currently active alloc + // regions so that all the ALLOC / RETIRE events are generated + // before the start GC event. + _hr_printer.start_gc(true /* full */, (size_t) total_collections()); - print_hrs_post_compaction(); - _hr_printer.end_gc(true /* full */, (size_t) total_collections()); - } + // We may have added regions to the current incremental collection + // set between the last GC or pause and now. We need to clear the + // incremental collection set and then start rebuilding it afresh + // after this full GC. + abandon_collection_set(g1_policy()->inc_cset_head()); + g1_policy()->clear_incremental_cset(); + g1_policy()->stop_incremental_cset_building(); - if (_cg1r->use_cache()) { - _cg1r->clear_and_record_card_counts(); - _cg1r->clear_hot_cache(); - } + tear_down_region_sets(false /* free_list_only */); + g1_policy()->set_gcs_are_young(true); - // Rebuild remembered sets of all regions. - if (G1CollectedHeap::use_parallel_gc_threads()) { - uint n_workers = - AdaptiveSizePolicy::calc_active_workers(workers()->total_workers(), - workers()->active_workers(), - Threads::number_of_non_daemon_threads()); - assert(UseDynamicNumberOfGCThreads || - n_workers == workers()->total_workers(), - "If not dynamic should be using all the workers"); - workers()->set_active_workers(n_workers); - // Set parallel threads in the heap (_n_par_threads) only - // before a parallel phase and always reset it to 0 after - // the phase so that the number of parallel threads does - // no get carried forward to a serial phase where there - // may be code that is "possibly_parallel". - set_par_threads(n_workers); + // See the comments in g1CollectedHeap.hpp and + // G1CollectedHeap::ref_processing_init() about + // how reference processing currently works in G1. - ParRebuildRSTask rebuild_rs_task(this); - assert(check_heap_region_claim_values( - HeapRegion::InitialClaimValue), "sanity check"); - assert(UseDynamicNumberOfGCThreads || - workers()->active_workers() == workers()->total_workers(), - "Unless dynamic should use total workers"); - // Use the most recent number of active workers - assert(workers()->active_workers() > 0, - "Active workers not properly set"); - set_par_threads(workers()->active_workers()); - workers()->run_task(&rebuild_rs_task); - set_par_threads(0); - assert(check_heap_region_claim_values( - HeapRegion::RebuildRSClaimValue), "sanity check"); - reset_heap_region_claim_values(); - } else { - RebuildRSOutOfRegionClosure rebuild_rs(this); - heap_region_iterate(&rebuild_rs); - } + // Temporarily make discovery by the STW ref processor single threaded (non-MT). + ReferenceProcessorMTDiscoveryMutator stw_rp_disc_ser(ref_processor_stw(), false); - if (G1Log::fine()) { - print_size_transition(gclog_or_tty, g1h_prev_used, used(), capacity()); - } + // Temporarily clear the STW ref processor's _is_alive_non_header field. + ReferenceProcessorIsAliveMutator stw_rp_is_alive_null(ref_processor_stw(), NULL); - if (true) { // FIXME - MetaspaceGC::compute_new_size(); - } + ref_processor_stw()->enable_discovery(true /*verify_disabled*/, true /*verify_no_refs*/); + ref_processor_stw()->setup_policy(do_clear_all_soft_refs); - // Start a new incremental collection set for the next pause - assert(g1_policy()->collection_set() == NULL, "must be"); - g1_policy()->start_incremental_cset_building(); + // Do collection work + { + HandleMark hm; // Discard invalid handles created during gc + G1MarkSweep::invoke_at_safepoint(ref_processor_stw(), do_clear_all_soft_refs); + } - // Clear the _cset_fast_test bitmap in anticipation of adding - // regions to the incremental collection set for the next - // evacuation pause. - clear_cset_fast_test(); + assert(free_regions() == 0, "we should not have added any free regions"); + rebuild_region_sets(false /* free_list_only */); - init_mutator_alloc_region(); + // Enqueue any discovered reference objects that have + // not been removed from the discovered lists. + ref_processor_stw()->enqueue_discovered_references(); - double end = os::elapsedTime(); - g1_policy()->record_full_collection_end(); + COMPILER2_PRESENT(DerivedPointerTable::update_pointers()); + + MemoryService::track_memory_usage(); + + verify_after_gc(); + + assert(!ref_processor_stw()->discovery_enabled(), "Postcondition"); + ref_processor_stw()->verify_no_references_recorded(); + + // Delete metaspaces for unloaded class loaders and clean up loader_data graph + ClassLoaderDataGraph::purge(); + + // Note: since we've just done a full GC, concurrent + // marking is no longer active. Therefore we need not + // re-enable reference discovery for the CM ref processor. + // That will be done at the start of the next marking cycle. + assert(!ref_processor_cm()->discovery_enabled(), "Postcondition"); + ref_processor_cm()->verify_no_references_recorded(); + + reset_gc_time_stamp(); + // Since everything potentially moved, we will clear all remembered + // sets, and clear all cards. Later we will rebuild remebered + // sets. We will also reset the GC time stamps of the regions. + clear_rsets_post_compaction(); + check_gc_time_stamps(); + + // Resize the heap if necessary. + resize_if_necessary_after_full_collection(explicit_gc ? 0 : word_size); + + if (_hr_printer.is_active()) { + // We should do this after we potentially resize the heap so + // that all the COMMIT / UNCOMMIT events are generated before + // the end GC event. + + print_hrs_post_compaction(); + _hr_printer.end_gc(true /* full */, (size_t) total_collections()); + } + + if (_cg1r->use_cache()) { + _cg1r->clear_and_record_card_counts(); + _cg1r->clear_hot_cache(); + } + + // Rebuild remembered sets of all regions. + if (G1CollectedHeap::use_parallel_gc_threads()) { + uint n_workers = + AdaptiveSizePolicy::calc_active_workers(workers()->total_workers(), + workers()->active_workers(), + Threads::number_of_non_daemon_threads()); + assert(UseDynamicNumberOfGCThreads || + n_workers == workers()->total_workers(), + "If not dynamic should be using all the workers"); + workers()->set_active_workers(n_workers); + // Set parallel threads in the heap (_n_par_threads) only + // before a parallel phase and always reset it to 0 after + // the phase so that the number of parallel threads does + // no get carried forward to a serial phase where there + // may be code that is "possibly_parallel". + set_par_threads(n_workers); + + ParRebuildRSTask rebuild_rs_task(this); + assert(check_heap_region_claim_values( + HeapRegion::InitialClaimValue), "sanity check"); + assert(UseDynamicNumberOfGCThreads || + workers()->active_workers() == workers()->total_workers(), + "Unless dynamic should use total workers"); + // Use the most recent number of active workers + assert(workers()->active_workers() > 0, + "Active workers not properly set"); + set_par_threads(workers()->active_workers()); + workers()->run_task(&rebuild_rs_task); + set_par_threads(0); + assert(check_heap_region_claim_values( + HeapRegion::RebuildRSClaimValue), "sanity check"); + reset_heap_region_claim_values(); + } else { + RebuildRSOutOfRegionClosure rebuild_rs(this); + heap_region_iterate(&rebuild_rs); + } + + if (true) { // FIXME + MetaspaceGC::compute_new_size(); + } #ifdef TRACESPINNING - ParallelTaskTerminator::print_termination_counts(); + ParallelTaskTerminator::print_termination_counts(); #endif - gc_epilogue(true); + // Discard all rset updates + JavaThread::dirty_card_queue_set().abandon_logs(); + assert(!G1DeferredRSUpdate + || (G1DeferredRSUpdate && + (dirty_card_queue_set().completed_buffers_num() == 0)), "Should not be any"); - // Discard all rset updates - JavaThread::dirty_card_queue_set().abandon_logs(); - assert(!G1DeferredRSUpdate - || (G1DeferredRSUpdate && (dirty_card_queue_set().completed_buffers_num() == 0)), "Should not be any"); + _young_list->reset_sampled_info(); + // At this point there should be no regions in the + // entire heap tagged as young. + assert(check_young_list_empty(true /* check_heap */), + "young list should be empty at this point"); - _young_list->reset_sampled_info(); - // At this point there should be no regions in the - // entire heap tagged as young. - assert( check_young_list_empty(true /* check_heap */), - "young list should be empty at this point"); + // Update the number of full collections that have been completed. + increment_old_marking_cycles_completed(false /* concurrent */); - // Update the number of full collections that have been completed. - increment_old_marking_cycles_completed(false /* concurrent */); + _hrs.verify_optional(); + verify_region_sets_optional(); - _hrs.verify_optional(); - verify_region_sets_optional(); + // Start a new incremental collection set for the next pause + assert(g1_policy()->collection_set() == NULL, "must be"); + g1_policy()->start_incremental_cset_building(); + + // Clear the _cset_fast_test bitmap in anticipation of adding + // regions to the incremental collection set for the next + // evacuation pause. + clear_cset_fast_test(); + + init_mutator_alloc_region(); + + double end = os::elapsedTime(); + g1_policy()->record_full_collection_end(); + + if (G1Log::fine()) { + g1_policy()->print_heap_transition(); + } + + // We must call G1MonitoringSupport::update_sizes() in the same scoping level + // as an active TraceMemoryManagerStats object (i.e. before the destructor for the + // TraceMemoryManagerStats is called) so that the G1 memory pools are updated + // before any GC notifications are raised. + g1mm()->update_sizes(); + + gc_epilogue(true); + } + + if (G1Log::finer()) { + g1_policy()->print_detailed_heap_transition(); + } print_heap_after_gc(); - // We must call G1MonitoringSupport::update_sizes() in the same scoping level - // as an active TraceMemoryManagerStats object (i.e. before the destructor for the - // TraceMemoryManagerStats is called) so that the G1 memory pools are updated - // before any GC notifications are raised. - g1mm()->update_sizes(); + post_full_gc_dump(); } - post_full_gc_dump(); - return true; } @@ -3829,7 +3835,6 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) { // The elapsed time induced by the start time below deliberately elides // the possible verification above. double sample_start_time_sec = os::elapsedTime(); - size_t start_used_bytes = used(); #if YOUNG_LIST_VERBOSE gclog_or_tty->print_cr("\nBefore recording pause start.\nYoung_list:"); @@ -3837,8 +3842,7 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) { g1_policy()->print_collection_set(g1_policy()->inc_cset_head(), gclog_or_tty); #endif // YOUNG_LIST_VERBOSE - g1_policy()->record_collection_pause_start(sample_start_time_sec, - start_used_bytes); + g1_policy()->record_collection_pause_start(sample_start_time_sec); double scan_wait_start = os::elapsedTime(); // We have to wait until the CM threads finish scanning the diff --git a/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.cpp b/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.cpp index 87acfec56f9..34d8a3688be 100644 --- a/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.cpp +++ b/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -406,7 +406,6 @@ void G1CollectorPolicy::init() { } _free_regions_at_end_of_collection = _g1->free_regions(); update_young_list_target_length(); - _prev_eden_capacity = _young_list_target_length * HeapRegion::GrainBytes; // We may immediately start allocating regions and placing them on the // collection set list. Initialize the per-collection set info @@ -746,6 +745,7 @@ G1CollectorPolicy::verify_young_ages(HeapRegion* head, void G1CollectorPolicy::record_full_collection_start() { _full_collection_start_sec = os::elapsedTime(); + record_heap_size_info_at_start(); // Release the future to-space so that it is available for compaction into. _g1->set_full_collection(); } @@ -788,8 +788,7 @@ void G1CollectorPolicy::record_stop_world_start() { _stop_world_start = os::elapsedTime(); } -void G1CollectorPolicy::record_collection_pause_start(double start_time_sec, - size_t start_used) { +void G1CollectorPolicy::record_collection_pause_start(double start_time_sec) { // We only need to do this here as the policy will only be applied // to the GC we're about to start. so, no point is calculating this // every time we calculate / recalculate the target young length. @@ -803,19 +802,14 @@ void G1CollectorPolicy::record_collection_pause_start(double start_time_sec, _trace_gen0_time_data.record_start_collection(s_w_t_ms); _stop_world_start = 0.0; + record_heap_size_info_at_start(); + phase_times()->record_cur_collection_start_sec(start_time_sec); - _cur_collection_pause_used_at_start_bytes = start_used; - _cur_collection_pause_used_regions_at_start = _g1->used_regions(); _pending_cards = _g1->pending_card_num(); _collection_set_bytes_used_before = 0; _bytes_copied_during_gc = 0; - YoungList* young_list = _g1->young_list(); - _eden_bytes_before_gc = young_list->eden_used_bytes(); - _survivor_bytes_before_gc = young_list->survivor_used_bytes(); - _capacity_before_gc = _g1->capacity(); - _last_gc_was_young = false; // do that for any other surv rate groups @@ -1153,6 +1147,21 @@ void G1CollectorPolicy::record_collection_pause_end(double pause_time_ms) { byte_size_in_proper_unit((double)(bytes)), \ proper_unit_for_byte_size((bytes)) +void G1CollectorPolicy::record_heap_size_info_at_start() { + YoungList* young_list = _g1->young_list(); + _eden_bytes_before_gc = young_list->eden_used_bytes(); + _survivor_bytes_before_gc = young_list->survivor_used_bytes(); + _capacity_before_gc = _g1->capacity(); + + _cur_collection_pause_used_at_start_bytes = _g1->used(); + _cur_collection_pause_used_regions_at_start = _g1->used_regions(); + + size_t eden_capacity_before_gc = + (_young_list_target_length * HeapRegion::GrainBytes) - _survivor_bytes_before_gc; + + _prev_eden_capacity = eden_capacity_before_gc; +} + void G1CollectorPolicy::print_heap_transition() { _g1->print_size_transition(gclog_or_tty, _cur_collection_pause_used_at_start_bytes, _g1->used(), _g1->capacity()); @@ -1183,8 +1192,6 @@ void G1CollectorPolicy::print_detailed_heap_transition() { EXT_SIZE_PARAMS(_capacity_before_gc), EXT_SIZE_PARAMS(used), EXT_SIZE_PARAMS(capacity)); - - _prev_eden_capacity = eden_capacity; } void G1CollectorPolicy::adjust_concurrent_refinement(double update_rs_time, diff --git a/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp b/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp index 0c04167c8a4..08867850394 100644 --- a/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp +++ b/hotspot/src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -671,34 +671,36 @@ public: bool need_to_start_conc_mark(const char* source, size_t alloc_word_size = 0); - // Update the heuristic info to record a collection pause of the given - // start time, where the given number of bytes were used at the start. - // This may involve changing the desired size of a collection set. + // Record the start and end of an evacuation pause. + void record_collection_pause_start(double start_time_sec); + void record_collection_pause_end(double pause_time_ms); - void record_stop_world_start(); - - void record_collection_pause_start(double start_time_sec, size_t start_used); + // Record the start and end of a full collection. + void record_full_collection_start(); + void record_full_collection_end(); // Must currently be called while the world is stopped. - void record_concurrent_mark_init_end(double - mark_init_elapsed_time_ms); + void record_concurrent_mark_init_end(double mark_init_elapsed_time_ms); + // Record start and end of remark. void record_concurrent_mark_remark_start(); void record_concurrent_mark_remark_end(); + // Record start, end, and completion of cleanup. void record_concurrent_mark_cleanup_start(); void record_concurrent_mark_cleanup_end(int no_of_gc_threads); void record_concurrent_mark_cleanup_completed(); - void record_concurrent_pause(); + // Records the information about the heap size for reporting in + // print_detailed_heap_transition + void record_heap_size_info_at_start(); - void record_collection_pause_end(double pause_time); + // Print heap sizing transition (with less and more detail). void print_heap_transition(); void print_detailed_heap_transition(); - // Record the fact that a full collection occurred. - void record_full_collection_start(); - void record_full_collection_end(); + void record_stop_world_start(); + void record_concurrent_pause(); // Record how much space we copied during a GC. This is typically // called when a GC alloc region is being retired. From 7f78a7f47504d1c570b8865ba20149d88ab2684d Mon Sep 17 00:00:00 2001 From: Jon Masamitsu Date: Mon, 1 Apr 2013 10:50:30 -0700 Subject: [PATCH 02/50] 8011173: NPG: Replace the ChunkList implementation with class FreeList Reviewed-by: mgerdin, tschatzl, johnc, coleenp --- hotspot/src/share/vm/memory/metaspace.cpp | 137 +++++++--------------- 1 file changed, 40 insertions(+), 97 deletions(-) diff --git a/hotspot/src/share/vm/memory/metaspace.cpp b/hotspot/src/share/vm/memory/metaspace.cpp index 533d982a9d7..1f623bf6032 100644 --- a/hotspot/src/share/vm/memory/metaspace.cpp +++ b/hotspot/src/share/vm/memory/metaspace.cpp @@ -103,27 +103,7 @@ bool MetaspaceGC::_should_concurrent_collect = false; // a chunk is placed on the free list of blocks (BlockFreelist) and // reused from there. -// Pointer to list of Metachunks. -class ChunkList VALUE_OBJ_CLASS_SPEC { - // List of free chunks - Metachunk* _head; - - public: - // Constructor - ChunkList() : _head(NULL) {} - - // Accessors - Metachunk* head() { return _head; } - void set_head(Metachunk* v) { _head = v; } - - // Link at head of the list - void add_at_head(Metachunk* head, Metachunk* tail); - void add_at_head(Metachunk* head); - - size_t sum_list_size(); - size_t sum_list_count(); - size_t sum_list_capacity(); -}; +typedef class FreeList ChunkList; // Manages the global free lists of chunks. // Has three lists of free chunks, and a total size and @@ -185,6 +165,10 @@ class ChunkManager VALUE_OBJ_CLASS_SPEC { // for special, small, medium, and humongous chunks. static ChunkIndex list_index(size_t size); + // Add the simple linked list of chunks to the freelist of chunks + // of type index. + void return_chunks(ChunkIndex index, Metachunk* chunks); + // Total of the space in the free chunks list size_t free_chunks_total(); size_t free_chunks_total_in_bytes(); @@ -899,6 +883,9 @@ VirtualSpaceList::VirtualSpaceList(size_t word_size ) : Mutex::_no_safepoint_check_flag); bool initialization_succeeded = grow_vs(word_size); + _chunk_manager.free_chunks(SpecializedIndex)->set_size(SpecializedChunk); + _chunk_manager.free_chunks(SmallIndex)->set_size(SmallChunk); + _chunk_manager.free_chunks(MediumIndex)->set_size(MediumChunk); assert(initialization_succeeded, " VirtualSpaceList initialization should not fail"); } @@ -913,6 +900,9 @@ VirtualSpaceList::VirtualSpaceList(ReservedSpace rs) : Mutex::_no_safepoint_check_flag); VirtualSpaceNode* class_entry = new VirtualSpaceNode(rs); bool succeeded = class_entry->initialize(); + _chunk_manager.free_chunks(SpecializedIndex)->set_size(SpecializedChunk); + _chunk_manager.free_chunks(SmallIndex)->set_size(ClassSmallChunk); + _chunk_manager.free_chunks(MediumIndex)->set_size(ClassMediumChunk); assert(succeeded, " VirtualSpaceList initialization should not fail"); link_vs(class_entry, rs.size()/BytesPerWord); } @@ -1380,76 +1370,6 @@ bool Metadebug::test_metadata_failure() { } #endif -// ChunkList methods - -size_t ChunkList::sum_list_size() { - size_t result = 0; - Metachunk* cur = head(); - while (cur != NULL) { - result += cur->word_size(); - cur = cur->next(); - } - return result; -} - -size_t ChunkList::sum_list_count() { - size_t result = 0; - Metachunk* cur = head(); - while (cur != NULL) { - result++; - cur = cur->next(); - } - return result; -} - -size_t ChunkList::sum_list_capacity() { - size_t result = 0; - Metachunk* cur = head(); - while (cur != NULL) { - result += cur->capacity_word_size(); - cur = cur->next(); - } - return result; -} - -void ChunkList::add_at_head(Metachunk* head, Metachunk* tail) { - assert_lock_strong(SpaceManager::expand_lock()); - assert(head == tail || tail->next() == NULL, - "Not the tail or the head has already been added to a list"); - - if (TraceMetadataChunkAllocation && Verbose) { - gclog_or_tty->print("ChunkList::add_at_head(head, tail): "); - Metachunk* cur = head; - while (cur != NULL) { - gclog_or_tty->print(PTR_FORMAT " (" SIZE_FORMAT ") ", cur, cur->word_size()); - cur = cur->next(); - } - gclog_or_tty->print_cr(""); - } - - if (tail != NULL) { - tail->set_next(_head); - } - set_head(head); -} - -void ChunkList::add_at_head(Metachunk* list) { - if (list == NULL) { - // Nothing to add - return; - } - assert_lock_strong(SpaceManager::expand_lock()); - Metachunk* head = list; - Metachunk* tail = list; - Metachunk* cur = head->next(); - // Search for the tail since it is not passed. - while (cur != NULL) { - tail = cur; - cur = cur->next(); - } - add_at_head(head, tail); -} - // ChunkManager methods // Verification of _free_chunks_total and _free_chunks_count does not @@ -1553,7 +1473,7 @@ size_t ChunkManager::sum_free_chunks() { continue; } - result = result + list->sum_list_capacity(); + result = result + list->count() * list->size(); } result = result + humongous_dictionary()->total_size(); return result; @@ -1567,7 +1487,7 @@ size_t ChunkManager::sum_free_chunks_count() { if (list == NULL) { continue; } - count = count + list->sum_list_count(); + count = count + list->count(); } count = count + humongous_dictionary()->total_free_blocks(); return count; @@ -1622,7 +1542,7 @@ Metachunk* ChunkManager::free_chunks_get(size_t word_size) { } // Remove the chunk as the head of the list. - free_list->set_head(chunk->next()); + free_list->remove_chunk(chunk); // Chunk is being removed from the chunks free list. dec_free_chunks_total(chunk->capacity_word_size()); @@ -1679,7 +1599,7 @@ Metachunk* ChunkManager::chunk_freelist_allocate(size_t word_size) { size_t list_count; if (list_index(word_size) < HumongousIndex) { ChunkList* list = find_free_chunks_list(word_size); - list_count = list->sum_list_count(); + list_count = list->count(); } else { list_count = humongous_dictionary()->total_count(); } @@ -1958,6 +1878,29 @@ void SpaceManager::initialize() { } } +void ChunkManager::return_chunks(ChunkIndex index, Metachunk* chunks) { + if (chunks == NULL) { + return; + } + ChunkList* list = free_chunks(index); + assert(list->size() == chunks->word_size(), "Mismatch in chunk sizes"); + assert_lock_strong(SpaceManager::expand_lock()); + Metachunk* cur = chunks; + + // This return chunks one at a time. If a new + // class List can be created that is a base class + // of FreeList then something like FreeList::prepend() + // can be used in place of this loop + while (cur != NULL) { + // Capture the next link before it is changed + // by the call to return_chunk_at_head(); + Metachunk* next = cur->next(); + cur->set_is_free(true); + list->return_chunk_at_head(cur); + cur = next; + } +} + SpaceManager::~SpaceManager() { // This call this->_lock which can't be done while holding expand_lock() const size_t in_use_before = sum_capacity_in_chunks_in_use(); @@ -1995,11 +1938,11 @@ SpaceManager::~SpaceManager() { chunk_size_name(i)); } Metachunk* chunks = chunks_in_use(i); - chunk_manager->free_chunks(i)->add_at_head(chunks); + chunk_manager->return_chunks(i, chunks); set_chunks_in_use(i, NULL); if (TraceMetadataChunkAllocation && Verbose) { gclog_or_tty->print_cr("updated freelist count %d %s", - chunk_manager->free_chunks(i)->sum_list_count(), + chunk_manager->free_chunks(i)->count(), chunk_size_name(i)); } assert(i != HumongousIndex, "Humongous chunks are handled explicitly later"); From 56370657b97f9d8ec5805ce15f26048adeb38323 Mon Sep 17 00:00:00 2001 From: Jiangli Zhou Date: Tue, 9 Apr 2013 17:17:41 -0400 Subject: [PATCH 03/50] 8010862: The Method counter fields used for profiling can be allocated lazily Allocate the method's profiling related metadata until they are needed. Reviewed-by: coleenp, roland --- .../classes/sun/jvm/hotspot/oops/Method.java | 34 ++--- .../sun/jvm/hotspot/oops/MethodCounters.java | 86 ++++++++++++ .../src/cpu/sparc/vm/cppInterpreter_sparc.cpp | 24 ++-- .../src/cpu/sparc/vm/interp_masm_sparc.cpp | 48 ++++--- .../src/cpu/sparc/vm/interp_masm_sparc.hpp | 7 +- .../sparc/vm/templateInterpreter_sparc.cpp | 36 +++-- .../src/cpu/sparc/vm/templateTable_sparc.cpp | 27 ++-- hotspot/src/cpu/x86/vm/cppInterpreter_x86.cpp | 29 ++-- hotspot/src/cpu/x86/vm/interp_masm_x86_32.cpp | 16 ++- hotspot/src/cpu/x86/vm/interp_masm_x86_32.hpp | 3 +- hotspot/src/cpu/x86/vm/interp_masm_x86_64.cpp | 16 ++- hotspot/src/cpu/x86/vm/interp_masm_x86_64.hpp | 3 +- .../cpu/x86/vm/templateInterpreter_x86_32.cpp | 49 ++++--- .../cpu/x86/vm/templateInterpreter_x86_64.cpp | 55 ++++---- .../src/cpu/x86/vm/templateTable_x86_32.cpp | 30 +++- .../src/cpu/x86/vm/templateTable_x86_64.cpp | 28 +++- hotspot/src/share/vm/c1/c1_LIRGenerator.cpp | 19 +-- hotspot/src/share/vm/ci/ciMethod.cpp | 21 ++- hotspot/src/share/vm/ci/ciMethod.hpp | 3 +- hotspot/src/share/vm/ci/ciReplay.cpp | 9 +- .../vm/interpreter/interpreterRuntime.cpp | 13 +- .../vm/interpreter/interpreterRuntime.hpp | 3 +- .../vm/interpreter/invocationCounter.cpp | 12 +- hotspot/src/share/vm/oops/method.cpp | 60 ++++---- hotspot/src/share/vm/oops/method.hpp | 132 +++++++++++++----- hotspot/src/share/vm/oops/methodCounters.cpp | 37 +++++ hotspot/src/share/vm/oops/methodCounters.hpp | 124 ++++++++++++++++ hotspot/src/share/vm/oops/methodData.cpp | 19 +-- hotspot/src/share/vm/opto/parseHelper.cpp | 18 +-- .../vm/runtime/advancedThresholdPolicy.cpp | 13 +- .../share/vm/runtime/compilationPolicy.cpp | 64 ++++++--- hotspot/src/share/vm/runtime/fprofiler.cpp | 5 +- .../vm/runtime/simpleThresholdPolicy.cpp | 8 +- hotspot/src/share/vm/runtime/vmStructs.cpp | 17 ++- 34 files changed, 773 insertions(+), 295 deletions(-) create mode 100644 hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/MethodCounters.java create mode 100644 hotspot/src/share/vm/oops/methodCounters.cpp create mode 100644 hotspot/src/share/vm/oops/methodCounters.hpp diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/Method.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/Method.java index 31dc39c5431..c61d58dc429 100644 --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/Method.java +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/Method.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -49,19 +49,13 @@ public class Method extends Metadata { Type type = db.lookupType("Method"); constMethod = type.getAddressField("_constMethod"); methodData = type.getAddressField("_method_data"); + methodCounters = type.getAddressField("_method_counters"); methodSize = new CIntField(type.getCIntegerField("_method_size"), 0); accessFlags = new CIntField(type.getCIntegerField("_access_flags"), 0); code = type.getAddressField("_code"); vtableIndex = new CIntField(type.getCIntegerField("_vtable_index"), 0); - if (!VM.getVM().isCore()) { - invocationCounter = new CIntField(type.getCIntegerField("_invocation_counter"), 0); - backedgeCounter = new CIntField(type.getCIntegerField("_backedge_counter"), 0); - } bytecodeOffset = type.getSize(); - interpreterThrowoutCountField = new CIntField(type.getCIntegerField("_interpreter_throwout_count"), 0); - interpreterInvocationCountField = new CIntField(type.getCIntegerField("_interpreter_invocation_count"), 0); - /* interpreterEntry = type.getAddressField("_interpreter_entry"); fromCompiledCodeEntryPoint = type.getAddressField("_from_compiled_code_entry_point"); @@ -80,18 +74,14 @@ public class Method extends Metadata { // Fields private static AddressField constMethod; private static AddressField methodData; + private static AddressField methodCounters; private static CIntField methodSize; private static CIntField accessFlags; private static CIntField vtableIndex; - private static CIntField invocationCounter; - private static CIntField backedgeCounter; private static long bytecodeOffset; private static AddressField code; - private static CIntField interpreterThrowoutCountField; - private static CIntField interpreterInvocationCountField; - // constant method names - , // Initialized lazily to avoid initialization ordering dependencies between Method and SymbolTable private static Symbol objectInitializerName; @@ -127,6 +117,10 @@ public class Method extends Metadata { Address addr = methodData.getValue(getAddress()); return (MethodData) VMObjectFactory.newObject(MethodData.class, addr); } + public MethodCounters getMethodCounters() { + Address addr = methodCounters.getValue(getAddress()); + return (MethodCounters) VMObjectFactory.newObject(MethodCounters.class, addr); + } /** WARNING: this is in words, not useful in this system; use getObjectSize() instead */ public long getMethodSize() { return methodSize.getValue(this); } public long getMaxStack() { return getConstMethod().getMaxStack(); } @@ -139,16 +133,10 @@ public class Method extends Metadata { public long getCodeSize() { return getConstMethod().getCodeSize(); } public long getVtableIndex() { return vtableIndex.getValue(this); } public long getInvocationCounter() { - if (Assert.ASSERTS_ENABLED) { - Assert.that(!VM.getVM().isCore(), "must not be used in core build"); - } - return invocationCounter.getValue(this); + return getMethodCounters().getInvocationCounter(); } public long getBackedgeCounter() { - if (Assert.ASSERTS_ENABLED) { - Assert.that(!VM.getVM().isCore(), "must not be used in core build"); - } - return backedgeCounter.getValue(this); + return getMethodCounters().getBackedgeCounter(); } // get associated compiled native method, if available, else return null. @@ -369,10 +357,10 @@ public class Method extends Metadata { } public int interpreterThrowoutCount() { - return (int) interpreterThrowoutCountField.getValue(this); + return getMethodCounters().interpreterThrowoutCount(); } public int interpreterInvocationCount() { - return (int) interpreterInvocationCountField.getValue(this); + return getMethodCounters().interpreterInvocationCount(); } } diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/MethodCounters.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/MethodCounters.java new file mode 100644 index 00000000000..854aa818c89 --- /dev/null +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/oops/MethodCounters.java @@ -0,0 +1,86 @@ +/* + * Copyright (c) 2013, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +package sun.jvm.hotspot.oops; + +import java.io.*; +import java.util.*; +import sun.jvm.hotspot.debugger.*; +import sun.jvm.hotspot.runtime.*; +import sun.jvm.hotspot.types.*; +import sun.jvm.hotspot.utilities.*; + +public class MethodCounters extends Metadata { + public MethodCounters(Address addr) { + super(addr); + } + + static { + VM.registerVMInitializedObserver(new Observer() { + public void update(Observable o, Object data) { + initialize(VM.getVM().getTypeDataBase()); + } + }); + } + + private static synchronized void initialize(TypeDataBase db) throws WrongTypeException { + Type type = db.lookupType("MethodCounters"); + + interpreterInvocationCountField = new CIntField(type.getCIntegerField("_interpreter_invocation_count"), 0); + interpreterThrowoutCountField = new CIntField(type.getCIntegerField("_interpreter_throwout_count"), 0); + if (!VM.getVM().isCore()) { + invocationCounter = new CIntField(type.getCIntegerField("_invocation_counter"), 0); + backedgeCounter = new CIntField(type.getCIntegerField("_backedge_counter"), 0); + } + } + + private static CIntField interpreterInvocationCountField; + private static CIntField interpreterThrowoutCountField; + private static CIntField invocationCounter; + private static CIntField backedgeCounter; + + public int interpreterInvocationCount() { + return (int) interpreterInvocationCountField.getValue(this); + } + + public int interpreterThrowoutCount() { + return (int) interpreterThrowoutCountField.getValue(this); + } + public long getInvocationCounter() { + if (Assert.ASSERTS_ENABLED) { + Assert.that(!VM.getVM().isCore(), "must not be used in core build"); + } + return invocationCounter.getValue(this); + } + public long getBackedgeCounter() { + if (Assert.ASSERTS_ENABLED) { + Assert.that(!VM.getVM().isCore(), "must not be used in core build"); + } + return backedgeCounter.getValue(this); + } + + public void printValueOn(PrintStream tty) { + } +} + diff --git a/hotspot/src/cpu/sparc/vm/cppInterpreter_sparc.cpp b/hotspot/src/cpu/sparc/vm/cppInterpreter_sparc.cpp index b1451fb0bae..8a71d0923ab 100644 --- a/hotspot/src/cpu/sparc/vm/cppInterpreter_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/cppInterpreter_sparc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -404,14 +404,20 @@ address CppInterpreter::deopt_entry(TosState state, int length) { // ??: invocation counter // void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile_method, Label* profile_method_continue) { + Label done; + const Register Rcounters = G3_scratch; + + __ ld_ptr(STATE(_method), G5_method); + __ get_method_counters(G5_method, Rcounters, done); + // Update standard invocation counters - __ increment_invocation_counter(O0, G3_scratch); - if (ProfileInterpreter) { // %%% Merge this into MethodData* - __ ld_ptr(STATE(_method), G3_scratch); - Address interpreter_invocation_counter(G3_scratch, 0, in_bytes(Method::interpreter_invocation_counter_offset())); - __ ld(interpreter_invocation_counter, G3_scratch); - __ inc(G3_scratch); - __ st(G3_scratch, interpreter_invocation_counter); + __ increment_invocation_counter(Rcounters, O0, G4_scratch); + if (ProfileInterpreter) { + Address interpreter_invocation_counter(Rcounters, 0, + in_bytes(MethodCounters::interpreter_invocation_counter_offset())); + __ ld(interpreter_invocation_counter, G4_scratch); + __ inc(G4_scratch); + __ st(G4_scratch, interpreter_invocation_counter); } Address invocation_limit(G3_scratch, (address)&InvocationCounter::InterpreterInvocationLimit); @@ -420,7 +426,7 @@ void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile __ cmp(O0, G3_scratch); __ br(Assembler::greaterEqualUnsigned, false, Assembler::pn, *overflow); __ delayed()->nop(); - + __ bind(done); } address InterpreterGenerator::generate_empty_entry(void) { diff --git a/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp b/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp index 6060f003b68..c543e364198 100644 --- a/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,6 +30,7 @@ #include "oops/markOop.hpp" #include "oops/methodData.hpp" #include "oops/method.hpp" +#include "oops/methodCounters.hpp" #include "prims/jvmtiExport.hpp" #include "prims/jvmtiRedefineClassesTrace.hpp" #include "prims/jvmtiThreadState.hpp" @@ -2086,19 +2087,28 @@ void InterpreterMacroAssembler::compute_stack_base( Register Rdest ) { #endif /* CC_INTERP */ -void InterpreterMacroAssembler::increment_invocation_counter( Register Rtmp, Register Rtmp2 ) { +void InterpreterMacroAssembler::get_method_counters(Register method, + Register Rcounters, + Label& skip) { + Label has_counters; + Address method_counters(method, in_bytes(Method::method_counters_offset())); + ld_ptr(method_counters, Rcounters); + br_notnull_short(Rcounters, Assembler::pt, has_counters); + call_VM(noreg, CAST_FROM_FN_PTR(address, + InterpreterRuntime::build_method_counters), method); + ld_ptr(method_counters, Rcounters); + br_null_short(Rcounters, Assembler::pn, skip); // No MethodCounters, OutOfMemory + bind(has_counters); +} + +void InterpreterMacroAssembler::increment_invocation_counter( Register Rcounters, Register Rtmp, Register Rtmp2 ) { assert(UseCompiler, "incrementing must be useful"); -#ifdef CC_INTERP - Address inv_counter(G5_method, Method::invocation_counter_offset() + + assert_different_registers(Rcounters, Rtmp, Rtmp2); + + Address inv_counter(Rcounters, MethodCounters::invocation_counter_offset() + InvocationCounter::counter_offset()); - Address be_counter (G5_method, Method::backedge_counter_offset() + + Address be_counter (Rcounters, MethodCounters::backedge_counter_offset() + InvocationCounter::counter_offset()); -#else - Address inv_counter(Lmethod, Method::invocation_counter_offset() + - InvocationCounter::counter_offset()); - Address be_counter (Lmethod, Method::backedge_counter_offset() + - InvocationCounter::counter_offset()); -#endif /* CC_INTERP */ int delta = InvocationCounter::count_increment; // Load each counter in a register @@ -2122,19 +2132,15 @@ void InterpreterMacroAssembler::increment_invocation_counter( Register Rtmp, Reg // Note that this macro must leave the backedge_count + invocation_count in Rtmp! } -void InterpreterMacroAssembler::increment_backedge_counter( Register Rtmp, Register Rtmp2 ) { +void InterpreterMacroAssembler::increment_backedge_counter( Register Rcounters, Register Rtmp, Register Rtmp2 ) { assert(UseCompiler, "incrementing must be useful"); -#ifdef CC_INTERP - Address be_counter (G5_method, Method::backedge_counter_offset() + + assert_different_registers(Rcounters, Rtmp, Rtmp2); + + Address be_counter (Rcounters, MethodCounters::backedge_counter_offset() + InvocationCounter::counter_offset()); - Address inv_counter(G5_method, Method::invocation_counter_offset() + + Address inv_counter(Rcounters, MethodCounters::invocation_counter_offset() + InvocationCounter::counter_offset()); -#else - Address be_counter (Lmethod, Method::backedge_counter_offset() + - InvocationCounter::counter_offset()); - Address inv_counter(Lmethod, Method::invocation_counter_offset() + - InvocationCounter::counter_offset()); -#endif /* CC_INTERP */ + int delta = InvocationCounter::count_increment; // Load each counter in a register ld( be_counter, Rtmp ); diff --git a/hotspot/src/cpu/sparc/vm/interp_masm_sparc.hpp b/hotspot/src/cpu/sparc/vm/interp_masm_sparc.hpp index bf84848aa61..1a7901526ad 100644 --- a/hotspot/src/cpu/sparc/vm/interp_masm_sparc.hpp +++ b/hotspot/src/cpu/sparc/vm/interp_masm_sparc.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -263,8 +263,9 @@ class InterpreterMacroAssembler: public MacroAssembler { void compute_stack_base( Register Rdest ); #endif /* CC_INTERP */ - void increment_invocation_counter( Register Rtmp, Register Rtmp2 ); - void increment_backedge_counter( Register Rtmp, Register Rtmp2 ); + void get_method_counters(Register method, Register Rcounters, Label& skip); + void increment_invocation_counter( Register Rcounters, Register Rtmp, Register Rtmp2 ); + void increment_backedge_counter( Register Rcounters, Register Rtmp, Register Rtmp2 ); #ifndef CC_INTERP void test_backedge_count_for_osr( Register backedge_count, Register branch_bcp, Register Rtmp ); diff --git a/hotspot/src/cpu/sparc/vm/templateInterpreter_sparc.cpp b/hotspot/src/cpu/sparc/vm/templateInterpreter_sparc.cpp index 4a6372ae0de..d8281cadaec 100644 --- a/hotspot/src/cpu/sparc/vm/templateInterpreter_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/templateInterpreter_sparc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -292,11 +292,15 @@ address TemplateInterpreterGenerator::generate_continuation_for(TosState state) // ??: invocation counter // void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile_method, Label* profile_method_continue) { - // Note: In tiered we increment either counters in Method* or in MDO depending if we're profiling or not. + // Note: In tiered we increment either counters in MethodCounters* or in + // MDO depending if we're profiling or not. + const Register Rcounters = G3_scratch; + Label done; + if (TieredCompilation) { const int increment = InvocationCounter::count_increment; const int mask = ((1 << Tier0InvokeNotifyFreqLog) - 1) << InvocationCounter::count_shift; - Label no_mdo, done; + Label no_mdo; if (ProfileInterpreter) { // If no method data exists, go to profile_continue. __ ld_ptr(Lmethod, Method::method_data_offset(), G4_scratch); @@ -311,23 +315,26 @@ void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile __ ba_short(done); } - // Increment counter in Method* + // Increment counter in MethodCounters* __ bind(no_mdo); - Address invocation_counter(Lmethod, - in_bytes(Method::invocation_counter_offset()) + - in_bytes(InvocationCounter::counter_offset())); + Address invocation_counter(Rcounters, + in_bytes(MethodCounters::invocation_counter_offset()) + + in_bytes(InvocationCounter::counter_offset())); + __ get_method_counters(Lmethod, Rcounters, done); __ increment_mask_and_jump(invocation_counter, increment, mask, - G3_scratch, Lscratch, + G4_scratch, Lscratch, Assembler::zero, overflow); __ bind(done); } else { // Update standard invocation counters - __ increment_invocation_counter(O0, G3_scratch); - if (ProfileInterpreter) { // %%% Merge this into MethodData* - Address interpreter_invocation_counter(Lmethod,in_bytes(Method::interpreter_invocation_counter_offset())); - __ ld(interpreter_invocation_counter, G3_scratch); - __ inc(G3_scratch); - __ st(G3_scratch, interpreter_invocation_counter); + __ get_method_counters(Lmethod, Rcounters, done); + __ increment_invocation_counter(Rcounters, O0, G4_scratch); + if (ProfileInterpreter) { + Address interpreter_invocation_counter(Rcounters, + in_bytes(MethodCounters::interpreter_invocation_counter_offset())); + __ ld(interpreter_invocation_counter, G4_scratch); + __ inc(G4_scratch); + __ st(G4_scratch, interpreter_invocation_counter); } if (ProfileInterpreter && profile_method != NULL) { @@ -345,6 +352,7 @@ void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile __ cmp(O0, G3_scratch); __ br(Assembler::greaterEqualUnsigned, false, Assembler::pn, *overflow); // Far distance __ delayed()->nop(); + __ bind(done); } } diff --git a/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp b/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp index 01d593fb034..91fc1deee51 100644 --- a/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp @@ -1604,9 +1604,8 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { // Normal (non-jsr) branch handling // Save the current Lbcp - const Register O0_cur_bcp = O0; - __ mov( Lbcp, O0_cur_bcp ); - + const Register l_cur_bcp = Lscratch; + __ mov( Lbcp, l_cur_bcp ); bool increment_invocation_counter_for_backward_branches = UseCompiler && UseLoopCounter; if ( increment_invocation_counter_for_backward_branches ) { @@ -1616,6 +1615,9 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { // Bump bytecode pointer by displacement (take the branch) __ delayed()->add( O1_disp, Lbcp, Lbcp ); // add to bc addr + const Register Rcounters = G3_scratch; + __ get_method_counters(Lmethod, Rcounters, Lforward); + if (TieredCompilation) { Label Lno_mdo, Loverflow; int increment = InvocationCounter::count_increment; @@ -1628,21 +1630,22 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { // Increment backedge counter in the MDO Address mdo_backedge_counter(G4_scratch, in_bytes(MethodData::backedge_counter_offset()) + in_bytes(InvocationCounter::counter_offset())); - __ increment_mask_and_jump(mdo_backedge_counter, increment, mask, G3_scratch, Lscratch, + __ increment_mask_and_jump(mdo_backedge_counter, increment, mask, G3_scratch, O0, Assembler::notZero, &Lforward); __ ba_short(Loverflow); } - // If there's no MDO, increment counter in Method* + // If there's no MDO, increment counter in MethodCounters* __ bind(Lno_mdo); - Address backedge_counter(Lmethod, in_bytes(Method::backedge_counter_offset()) + - in_bytes(InvocationCounter::counter_offset())); - __ increment_mask_and_jump(backedge_counter, increment, mask, G3_scratch, Lscratch, + Address backedge_counter(Rcounters, + in_bytes(MethodCounters::backedge_counter_offset()) + + in_bytes(InvocationCounter::counter_offset())); + __ increment_mask_and_jump(backedge_counter, increment, mask, G4_scratch, O0, Assembler::notZero, &Lforward); __ bind(Loverflow); // notify point for loop, pass branch bytecode - __ call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::frequency_counter_overflow), O0_cur_bcp); + __ call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::frequency_counter_overflow), l_cur_bcp); // Was an OSR adapter generated? // O0 = osr nmethod @@ -1679,15 +1682,15 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { } else { // Update Backedge branch separately from invocations const Register G4_invoke_ctr = G4; - __ increment_backedge_counter(G4_invoke_ctr, G1_scratch); + __ increment_backedge_counter(Rcounters, G4_invoke_ctr, G1_scratch); if (ProfileInterpreter) { __ test_invocation_counter_for_mdp(G4_invoke_ctr, G3_scratch, Lforward); if (UseOnStackReplacement) { - __ test_backedge_count_for_osr(O2_bumped_count, O0_cur_bcp, G3_scratch); + __ test_backedge_count_for_osr(O2_bumped_count, l_cur_bcp, G3_scratch); } } else { if (UseOnStackReplacement) { - __ test_backedge_count_for_osr(G4_invoke_ctr, O0_cur_bcp, G3_scratch); + __ test_backedge_count_for_osr(G4_invoke_ctr, l_cur_bcp, G3_scratch); } } } diff --git a/hotspot/src/cpu/x86/vm/cppInterpreter_x86.cpp b/hotspot/src/cpu/x86/vm/cppInterpreter_x86.cpp index 24e6694082e..08db8e074d0 100644 --- a/hotspot/src/cpu/x86/vm/cppInterpreter_x86.cpp +++ b/hotspot/src/cpu/x86/vm/cppInterpreter_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -570,20 +570,28 @@ void CppInterpreterGenerator::generate_compute_interpreter_state(const Register // rcx: invocation counter // void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile_method, Label* profile_method_continue) { + Label done; + const Address invocation_counter(rax, + MethodCounters::invocation_counter_offset() + + InvocationCounter::counter_offset()); + const Address backedge_counter (rax, + MethodCounter::backedge_counter_offset() + + InvocationCounter::counter_offset()); - const Address invocation_counter(rbx, Method::invocation_counter_offset() + InvocationCounter::counter_offset()); - const Address backedge_counter (rbx, Method::backedge_counter_offset() + InvocationCounter::counter_offset()); + __ get_method_counters(rbx, rax, done); - if (ProfileInterpreter) { // %%% Merge this into MethodData* - __ incrementl(Address(rbx,Method::interpreter_invocation_counter_offset())); + if (ProfileInterpreter) { + __ incrementl(Address(rax, + MethodCounters::interpreter_invocation_counter_offset())); } // Update standard invocation counters - __ movl(rax, backedge_counter); // load backedge counter - + __ movl(rcx, invocation_counter); __ increment(rcx, InvocationCounter::count_increment); + __ movl(invocation_counter, rcx); // save invocation count + + __ movl(rax, backedge_counter); // load backedge counter __ andl(rax, InvocationCounter::count_mask_value); // mask out the status bits - __ movl(invocation_counter, rcx); // save invocation count __ addl(rcx, rax); // add both counters // profile_method is non-null only for interpreted method so @@ -593,7 +601,7 @@ void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile __ cmp32(rcx, ExternalAddress((address)&InvocationCounter::InterpreterInvocationLimit)); __ jcc(Assembler::aboveEqual, *overflow); - + __ bind(done); } void InterpreterGenerator::generate_counter_overflow(Label* do_continue) { @@ -977,7 +985,6 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) { address entry_point = __ pc(); const Address constMethod (rbx, Method::const_offset()); - const Address invocation_counter(rbx, Method::invocation_counter_offset() + InvocationCounter::counter_offset()); const Address access_flags (rbx, Method::access_flags_offset()); const Address size_of_parameters(rcx, ConstMethod::size_of_parameters_offset()); @@ -1029,8 +1036,6 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) { } #endif - if (inc_counter) __ movl(rcx, invocation_counter); // (pre-)fetch invocation count - const Register unlock_thread = LP64_ONLY(r15_thread) NOT_LP64(rax); NOT_LP64(__ movptr(unlock_thread, STATE(_thread));) // get thread // Since at this point in the method invocation the exception handler diff --git a/hotspot/src/cpu/x86/vm/interp_masm_x86_32.cpp b/hotspot/src/cpu/x86/vm/interp_masm_x86_32.cpp index 78d97a975b6..0e7f483a649 100644 --- a/hotspot/src/cpu/x86/vm/interp_masm_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/interp_masm_x86_32.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -266,6 +266,20 @@ void InterpreterMacroAssembler::get_cache_entry_pointer_at_bcp(Register cache, R addptr(cache, tmp); // construct pointer to cache entry } +void InterpreterMacroAssembler::get_method_counters(Register method, + Register mcs, Label& skip) { + Label has_counters; + movptr(mcs, Address(method, Method::method_counters_offset())); + testptr(mcs, mcs); + jcc(Assembler::notZero, has_counters); + call_VM(noreg, CAST_FROM_FN_PTR(address, + InterpreterRuntime::build_method_counters), method); + movptr(mcs, Address(method,Method::method_counters_offset())); + testptr(mcs, mcs); + jcc(Assembler::zero, skip); // No MethodCounters allocated, OutOfMemory + bind(has_counters); +} + // Load object from cpool->resolved_references(index) void InterpreterMacroAssembler::load_resolved_reference_at_index( Register result, Register index) { diff --git a/hotspot/src/cpu/x86/vm/interp_masm_x86_32.hpp b/hotspot/src/cpu/x86/vm/interp_masm_x86_32.hpp index 6dada56de0d..49a41f61d54 100644 --- a/hotspot/src/cpu/x86/vm/interp_masm_x86_32.hpp +++ b/hotspot/src/cpu/x86/vm/interp_masm_x86_32.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -89,6 +89,7 @@ class InterpreterMacroAssembler: public MacroAssembler { void get_cache_and_index_and_bytecode_at_bcp(Register cache, Register index, Register bytecode, int byte_no, int bcp_offset, size_t index_size = sizeof(u2)); void get_cache_entry_pointer_at_bcp(Register cache, Register tmp, int bcp_offset, size_t index_size = sizeof(u2)); void get_cache_index_at_bcp(Register index, int bcp_offset, size_t index_size = sizeof(u2)); + void get_method_counters(Register method, Register mcs, Label& skip); // load cpool->resolved_references(index); void load_resolved_reference_at_index(Register result, Register index); diff --git a/hotspot/src/cpu/x86/vm/interp_masm_x86_64.cpp b/hotspot/src/cpu/x86/vm/interp_masm_x86_64.cpp index 890826310a8..88d57d046a5 100644 --- a/hotspot/src/cpu/x86/vm/interp_masm_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/interp_masm_x86_64.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -271,6 +271,20 @@ void InterpreterMacroAssembler::get_cache_entry_pointer_at_bcp(Register cache, addptr(cache, tmp); // construct pointer to cache entry } +void InterpreterMacroAssembler::get_method_counters(Register method, + Register mcs, Label& skip) { + Label has_counters; + movptr(mcs, Address(method, Method::method_counters_offset())); + testptr(mcs, mcs); + jcc(Assembler::notZero, has_counters); + call_VM(noreg, CAST_FROM_FN_PTR(address, + InterpreterRuntime::build_method_counters), method); + movptr(mcs, Address(method,Method::method_counters_offset())); + testptr(mcs, mcs); + jcc(Assembler::zero, skip); // No MethodCounters allocated, OutOfMemory + bind(has_counters); +} + // Load object from cpool->resolved_references(index) void InterpreterMacroAssembler::load_resolved_reference_at_index( Register result, Register index) { diff --git a/hotspot/src/cpu/x86/vm/interp_masm_x86_64.hpp b/hotspot/src/cpu/x86/vm/interp_masm_x86_64.hpp index 66a001366ff..8bfc44fe4bc 100644 --- a/hotspot/src/cpu/x86/vm/interp_masm_x86_64.hpp +++ b/hotspot/src/cpu/x86/vm/interp_masm_x86_64.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -111,6 +111,7 @@ class InterpreterMacroAssembler: public MacroAssembler { void get_cache_and_index_and_bytecode_at_bcp(Register cache, Register index, Register bytecode, int byte_no, int bcp_offset, size_t index_size = sizeof(u2)); void get_cache_entry_pointer_at_bcp(Register cache, Register tmp, int bcp_offset, size_t index_size = sizeof(u2)); void get_cache_index_at_bcp(Register index, int bcp_offset, size_t index_size = sizeof(u2)); + void get_method_counters(Register method, Register mcs, Label& skip); // load cpool->resolved_references(index); void load_resolved_reference_at_index(Register result, Register index); diff --git a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp index fb13a44045a..f8a55c1640b 100644 --- a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -344,13 +344,13 @@ address TemplateInterpreterGenerator::generate_safept_entry_for(TosState state, // rcx: invocation counter // void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile_method, Label* profile_method_continue) { - const Address invocation_counter(rbx, in_bytes(Method::invocation_counter_offset()) + - in_bytes(InvocationCounter::counter_offset())); - // Note: In tiered we increment either counters in Method* or in MDO depending if we're profiling or not. + Label done; + // Note: In tiered we increment either counters in MethodCounters* or in MDO + // depending if we're profiling or not. if (TieredCompilation) { int increment = InvocationCounter::count_increment; int mask = ((1 << Tier0InvokeNotifyFreqLog) - 1) << InvocationCounter::count_shift; - Label no_mdo, done; + Label no_mdo; if (ProfileInterpreter) { // Are we profiling? __ movptr(rax, Address(rbx, Method::method_data_offset())); @@ -363,23 +363,38 @@ void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile __ jmpb(done); } __ bind(no_mdo); - // Increment counter in Method* (we don't need to load it, it's in rcx). - __ increment_mask_and_jump(invocation_counter, increment, mask, rcx, true, Assembler::zero, overflow); + // Increment counter in MethodCounters + const Address invocation_counter(rax, + MethodCounters::invocation_counter_offset() + + InvocationCounter::counter_offset()); + + __ get_method_counters(rbx, rax, done); + __ increment_mask_and_jump(invocation_counter, increment, mask, + rcx, false, Assembler::zero, overflow); __ bind(done); } else { - const Address backedge_counter (rbx, Method::backedge_counter_offset() + - InvocationCounter::counter_offset()); + const Address backedge_counter (rax, + MethodCounters::backedge_counter_offset() + + InvocationCounter::counter_offset()); + const Address invocation_counter(rax, + MethodCounters::invocation_counter_offset() + + InvocationCounter::counter_offset()); - if (ProfileInterpreter) { // %%% Merge this into MethodData* - __ incrementl(Address(rbx,Method::interpreter_invocation_counter_offset())); + __ get_method_counters(rbx, rax, done); + + if (ProfileInterpreter) { + __ incrementl(Address(rax, + MethodCounters::interpreter_invocation_counter_offset())); } - // Update standard invocation counters - __ movl(rax, backedge_counter); // load backedge counter + // Update standard invocation counters + __ movl(rcx, invocation_counter); __ incrementl(rcx, InvocationCounter::count_increment); + __ movl(invocation_counter, rcx); // save invocation count + + __ movl(rax, backedge_counter); // load backedge counter __ andl(rax, InvocationCounter::count_mask_value); // mask out the status bits - __ movl(invocation_counter, rcx); // save invocation count __ addl(rcx, rax); // add both counters // profile_method is non-null only for interpreted method so @@ -399,6 +414,7 @@ void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile __ cmp32(rcx, ExternalAddress((address)&InvocationCounter::InterpreterInvocationLimit)); __ jcc(Assembler::aboveEqual, *overflow); + __ bind(done); } } @@ -868,7 +884,6 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) { address entry_point = __ pc(); const Address constMethod (rbx, Method::const_offset()); - const Address invocation_counter(rbx, Method::invocation_counter_offset() + InvocationCounter::counter_offset()); const Address access_flags (rbx, Method::access_flags_offset()); const Address size_of_parameters(rcx, ConstMethod::size_of_parameters_offset()); @@ -897,9 +912,7 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) { // NULL oop temp (mirror or jni oop result) __ push((int32_t)NULL_WORD); - if (inc_counter) __ movl(rcx, invocation_counter); // (pre-)fetch invocation count // initialize fixed part of activation frame - generate_fixed_frame(true); // make sure method is native & not abstract @@ -1286,7 +1299,6 @@ address InterpreterGenerator::generate_normal_entry(bool synchronized) { address entry_point = __ pc(); const Address constMethod (rbx, Method::const_offset()); - const Address invocation_counter(rbx, Method::invocation_counter_offset() + InvocationCounter::counter_offset()); const Address access_flags (rbx, Method::access_flags_offset()); const Address size_of_parameters(rdx, ConstMethod::size_of_parameters_offset()); const Address size_of_locals (rdx, ConstMethod::size_of_locals_offset()); @@ -1326,7 +1338,6 @@ address InterpreterGenerator::generate_normal_entry(bool synchronized) { __ bind(exit); } - if (inc_counter) __ movl(rcx, invocation_counter); // (pre-)fetch invocation count // initialize fixed part of activation frame generate_fixed_frame(false); diff --git a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp index 6b3f7b6ba26..27e16264438 100644 --- a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -300,13 +300,12 @@ void InterpreterGenerator::generate_counter_incr( Label* overflow, Label* profile_method, Label* profile_method_continue) { - const Address invocation_counter(rbx, in_bytes(Method::invocation_counter_offset()) + - in_bytes(InvocationCounter::counter_offset())); + Label done; // Note: In tiered we increment either counters in Method* or in MDO depending if we're profiling or not. if (TieredCompilation) { int increment = InvocationCounter::count_increment; int mask = ((1 << Tier0InvokeNotifyFreqLog) - 1) << InvocationCounter::count_shift; - Label no_mdo, done; + Label no_mdo; if (ProfileInterpreter) { // Are we profiling? __ movptr(rax, Address(rbx, Method::method_data_offset())); @@ -319,25 +318,36 @@ void InterpreterGenerator::generate_counter_incr( __ jmpb(done); } __ bind(no_mdo); - // Increment counter in Method* (we don't need to load it, it's in ecx). - __ increment_mask_and_jump(invocation_counter, increment, mask, rcx, true, Assembler::zero, overflow); + // Increment counter in MethodCounters + const Address invocation_counter(rax, + MethodCounters::invocation_counter_offset() + + InvocationCounter::counter_offset()); + __ get_method_counters(rbx, rax, done); + __ increment_mask_and_jump(invocation_counter, increment, mask, rcx, + false, Assembler::zero, overflow); __ bind(done); } else { - const Address backedge_counter(rbx, - Method::backedge_counter_offset() + - InvocationCounter::counter_offset()); + const Address backedge_counter(rax, + MethodCounters::backedge_counter_offset() + + InvocationCounter::counter_offset()); + const Address invocation_counter(rax, + MethodCounters::invocation_counter_offset() + + InvocationCounter::counter_offset()); - if (ProfileInterpreter) { // %%% Merge this into MethodData* - __ incrementl(Address(rbx, - Method::interpreter_invocation_counter_offset())); + __ get_method_counters(rbx, rax, done); + + if (ProfileInterpreter) { + __ incrementl(Address(rax, + MethodCounters::interpreter_invocation_counter_offset())); } // Update standard invocation counters - __ movl(rax, backedge_counter); // load backedge counter - + __ movl(rcx, invocation_counter); __ incrementl(rcx, InvocationCounter::count_increment); + __ movl(invocation_counter, rcx); // save invocation count + + __ movl(rax, backedge_counter); // load backedge counter __ andl(rax, InvocationCounter::count_mask_value); // mask out the status bits - __ movl(invocation_counter, rcx); // save invocation count __ addl(rcx, rax); // add both counters // profile_method is non-null only for interpreted method so @@ -354,6 +364,7 @@ void InterpreterGenerator::generate_counter_incr( __ cmp32(rcx, ExternalAddress((address)&InvocationCounter::InterpreterInvocationLimit)); __ jcc(Assembler::aboveEqual, *overflow); + __ bind(done); } } @@ -843,9 +854,6 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) { address entry_point = __ pc(); const Address constMethod (rbx, Method::const_offset()); - const Address invocation_counter(rbx, Method:: - invocation_counter_offset() + - InvocationCounter::counter_offset()); const Address access_flags (rbx, Method::access_flags_offset()); const Address size_of_parameters(rcx, ConstMethod:: size_of_parameters_offset()); @@ -876,10 +884,6 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) { // (static native method holder mirror/jni oop result) __ push((int) NULL_WORD); - if (inc_counter) { - __ movl(rcx, invocation_counter); // (pre-)fetch invocation count - } - // initialize fixed part of activation frame generate_fixed_frame(true); @@ -1296,9 +1300,6 @@ address InterpreterGenerator::generate_normal_entry(bool synchronized) { address entry_point = __ pc(); const Address constMethod(rbx, Method::const_offset()); - const Address invocation_counter(rbx, - Method::invocation_counter_offset() + - InvocationCounter::counter_offset()); const Address access_flags(rbx, Method::access_flags_offset()); const Address size_of_parameters(rdx, ConstMethod::size_of_parameters_offset()); @@ -1343,10 +1344,6 @@ address InterpreterGenerator::generate_normal_entry(bool synchronized) { __ bind(exit); } - // (pre-)fetch invocation count - if (inc_counter) { - __ movl(rcx, invocation_counter); - } // initialize fixed part of activation frame generate_fixed_frame(false); diff --git a/hotspot/src/cpu/x86/vm/templateTable_x86_32.cpp b/hotspot/src/cpu/x86/vm/templateTable_x86_32.cpp index 371517c0537..6c6cc4f9474 100644 --- a/hotspot/src/cpu/x86/vm/templateTable_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/templateTable_x86_32.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1546,9 +1546,10 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { __ get_method(rcx); // ECX holds method __ profile_taken_branch(rax,rbx); // EAX holds updated MDP, EBX holds bumped taken count - const ByteSize be_offset = Method::backedge_counter_offset() + InvocationCounter::counter_offset(); - const ByteSize inv_offset = Method::invocation_counter_offset() + InvocationCounter::counter_offset(); - const int method_offset = frame::interpreter_frame_method_offset * wordSize; + const ByteSize be_offset = MethodCounters::backedge_counter_offset() + + InvocationCounter::counter_offset(); + const ByteSize inv_offset = MethodCounters::invocation_counter_offset() + + InvocationCounter::counter_offset(); // Load up EDX with the branch displacement __ movl(rdx, at_bcp(1)); @@ -1596,6 +1597,22 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { __ testl(rdx, rdx); // check if forward or backward branch __ jcc(Assembler::positive, dispatch); // count only if backward branch + // check if MethodCounters exists + Label has_counters; + __ movptr(rax, Address(rcx, Method::method_counters_offset())); + __ testptr(rax, rax); + __ jcc(Assembler::notZero, has_counters); + __ push(rdx); + __ push(rcx); + __ call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::build_method_counters), + rcx); + __ pop(rcx); + __ pop(rdx); + __ movptr(rax, Address(rcx, Method::method_counters_offset())); + __ testptr(rax, rax); + __ jcc(Assembler::zero, dispatch); + __ bind(has_counters); + if (TieredCompilation) { Label no_mdo; int increment = InvocationCounter::count_increment; @@ -1613,16 +1630,19 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { __ jmp(dispatch); } __ bind(no_mdo); - // Increment backedge counter in Method* + // Increment backedge counter in MethodCounters* + __ movptr(rcx, Address(rcx, Method::method_counters_offset())); __ increment_mask_and_jump(Address(rcx, be_offset), increment, mask, rax, false, Assembler::zero, &backedge_counter_overflow); } else { // increment counter + __ movptr(rcx, Address(rcx, Method::method_counters_offset())); __ movl(rax, Address(rcx, be_offset)); // load backedge counter __ incrementl(rax, InvocationCounter::count_increment); // increment counter __ movl(Address(rcx, be_offset), rax); // store counter __ movl(rax, Address(rcx, inv_offset)); // load invocation counter + __ andl(rax, InvocationCounter::count_mask_value); // and the status bits __ addl(rax, Address(rcx, be_offset)); // add both counters diff --git a/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp b/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp index d1e22d25990..4a9bc83163e 100644 --- a/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1564,11 +1564,10 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { __ profile_taken_branch(rax, rbx); // rax holds updated MDP, rbx // holds bumped taken count - const ByteSize be_offset = Method::backedge_counter_offset() + + const ByteSize be_offset = MethodCounters::backedge_counter_offset() + InvocationCounter::counter_offset(); - const ByteSize inv_offset = Method::invocation_counter_offset() + + const ByteSize inv_offset = MethodCounters::invocation_counter_offset() + InvocationCounter::counter_offset(); - const int method_offset = frame::interpreter_frame_method_offset * wordSize; // Load up edx with the branch displacement __ movl(rdx, at_bcp(1)); @@ -1618,6 +1617,22 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { // r14: locals pointer __ testl(rdx, rdx); // check if forward or backward branch __ jcc(Assembler::positive, dispatch); // count only if backward branch + + // check if MethodCounters exists + Label has_counters; + __ movptr(rax, Address(rcx, Method::method_counters_offset())); + __ testptr(rax, rax); + __ jcc(Assembler::notZero, has_counters); + __ push(rdx); + __ push(rcx); + __ call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::build_method_counters), + rcx); + __ pop(rcx); + __ pop(rdx); + __ movptr(rax, Address(rcx, Method::method_counters_offset())); + __ jcc(Assembler::zero, dispatch); + __ bind(has_counters); + if (TieredCompilation) { Label no_mdo; int increment = InvocationCounter::count_increment; @@ -1635,16 +1650,19 @@ void TemplateTable::branch(bool is_jsr, bool is_wide) { __ jmp(dispatch); } __ bind(no_mdo); - // Increment backedge counter in Method* + // Increment backedge counter in MethodCounters* + __ movptr(rcx, Address(rcx, Method::method_counters_offset())); __ increment_mask_and_jump(Address(rcx, be_offset), increment, mask, rax, false, Assembler::zero, &backedge_counter_overflow); } else { // increment counter + __ movptr(rcx, Address(rcx, Method::method_counters_offset())); __ movl(rax, Address(rcx, be_offset)); // load backedge counter __ incrementl(rax, InvocationCounter::count_increment); // increment counter __ movl(Address(rcx, be_offset), rax); // store counter __ movl(rax, Address(rcx, inv_offset)); // load invocation counter + __ andl(rax, InvocationCounter::count_mask_value); // and the status bits __ addl(rax, Address(rcx, be_offset)); // add both counters diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp index 84402a9ef0d..493b7230c80 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -3063,21 +3063,20 @@ void LIRGenerator::increment_event_counter_impl(CodeEmitInfo* info, assert(level > CompLevel_simple, "Shouldn't be here"); int offset = -1; - LIR_Opr counter_holder = new_register(T_METADATA); - LIR_Opr meth; + LIR_Opr counter_holder; if (level == CompLevel_limited_profile) { - offset = in_bytes(backedge ? Method::backedge_counter_offset() : - Method::invocation_counter_offset()); - __ metadata2reg(method->constant_encoding(), counter_holder); - meth = counter_holder; + address counters_adr = method->ensure_method_counters(); + counter_holder = new_pointer_register(); + __ move(LIR_OprFact::intptrConst(counters_adr), counter_holder); + offset = in_bytes(backedge ? MethodCounters::backedge_counter_offset() : + MethodCounters::invocation_counter_offset()); } else if (level == CompLevel_full_profile) { + counter_holder = new_register(T_METADATA); offset = in_bytes(backedge ? MethodData::backedge_counter_offset() : MethodData::invocation_counter_offset()); ciMethodData* md = method->method_data_or_null(); assert(md != NULL, "Sanity"); __ metadata2reg(md->constant_encoding(), counter_holder); - meth = new_register(T_METADATA); - __ metadata2reg(method->constant_encoding(), meth); } else { ShouldNotReachHere(); } @@ -3088,6 +3087,8 @@ void LIRGenerator::increment_event_counter_impl(CodeEmitInfo* info, __ store(result, counter); if (notify) { LIR_Opr mask = load_immediate(frequency << InvocationCounter::count_shift, T_INT); + LIR_Opr meth = new_register(T_METADATA); + __ metadata2reg(method->constant_encoding(), meth); __ logical_and(result, mask, result); __ cmp(lir_cond_equal, result, LIR_OprFact::intConst(0)); // The bci for info can point to cmp for if's we want the if bci diff --git a/hotspot/src/share/vm/ci/ciMethod.cpp b/hotspot/src/share/vm/ci/ciMethod.cpp index 646de740f8f..780f4ad868f 100644 --- a/hotspot/src/share/vm/ci/ciMethod.cpp +++ b/hotspot/src/share/vm/ci/ciMethod.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -904,6 +904,20 @@ ciMethodData* ciMethod::method_data_or_null() { return md; } +// ------------------------------------------------------------------ +// ciMethod::ensure_method_counters +// +address ciMethod::ensure_method_counters() { + check_is_loaded(); + VM_ENTRY_MARK; + methodHandle mh(THREAD, get_Method()); + MethodCounters *counter = mh->method_counters(); + if (counter == NULL) { + counter = Method::build_method_counters(mh(), CHECK_AND_CLEAR_NULL); + } + return (address)counter; +} + // ------------------------------------------------------------------ // ciMethod::should_exclude // @@ -1191,13 +1205,14 @@ void ciMethod::dump_replay_data(outputStream* st) { ASSERT_IN_VM; ResourceMark rm; Method* method = get_Method(); + MethodCounters* mcs = method->method_counters(); Klass* holder = method->method_holder(); st->print_cr("ciMethod %s %s %s %d %d %d %d %d", holder->name()->as_quoted_ascii(), method->name()->as_quoted_ascii(), method->signature()->as_quoted_ascii(), - method->invocation_counter()->raw_counter(), - method->backedge_counter()->raw_counter(), + mcs == NULL ? 0 : mcs->invocation_counter()->raw_counter(), + mcs == NULL ? 0 : mcs->backedge_counter()->raw_counter(), interpreter_invocation_count(), interpreter_throwout_count(), _instructions_size); diff --git a/hotspot/src/share/vm/ci/ciMethod.hpp b/hotspot/src/share/vm/ci/ciMethod.hpp index cbef39b3cdc..f206f1991a0 100644 --- a/hotspot/src/share/vm/ci/ciMethod.hpp +++ b/hotspot/src/share/vm/ci/ciMethod.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -262,6 +262,7 @@ class ciMethod : public ciMetadata { bool is_klass_loaded(int refinfo_index, bool must_be_resolved) const; bool check_call(int refinfo_index, bool is_static) const; bool ensure_method_data(); // make sure it exists in the VM also + address ensure_method_counters(); int instructions_size(); int scale_count(int count, float prof_factor = 1.); // make MDO count commensurate with IIC diff --git a/hotspot/src/share/vm/ci/ciReplay.cpp b/hotspot/src/share/vm/ci/ciReplay.cpp index 030d93db7c3..0d68b8cc891 100644 --- a/hotspot/src/share/vm/ci/ciReplay.cpp +++ b/hotspot/src/share/vm/ci/ciReplay.cpp @@ -920,12 +920,17 @@ void ciReplay::initialize(ciMethod* m) { method->print_name(tty); tty->cr(); } else { + EXCEPTION_CONTEXT; + MethodCounters* mcs = method->method_counters(); // m->_instructions_size = rec->instructions_size; m->_instructions_size = -1; m->_interpreter_invocation_count = rec->interpreter_invocation_count; m->_interpreter_throwout_count = rec->interpreter_throwout_count; - method->invocation_counter()->_counter = rec->invocation_counter; - method->backedge_counter()->_counter = rec->backedge_counter; + if (mcs == NULL) { + mcs = Method::build_method_counters(method, CHECK_AND_CLEAR); + } + mcs->invocation_counter()->_counter = rec->invocation_counter; + mcs->backedge_counter()->_counter = rec->backedge_counter; } } diff --git a/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp b/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp index de6b3d12812..64bd057e22b 100644 --- a/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp +++ b/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -454,7 +454,7 @@ IRT_ENTRY(address, InterpreterRuntime::exception_handler_for_exception(JavaThrea continuation = Interpreter::remove_activation_entry(); #endif // Count this for compilation purposes - h_method->interpreter_throwout_increment(); + h_method->interpreter_throwout_increment(THREAD); } else { // handler in this method => change bci/bcp to handler bci/bcp and continue there handler_pc = h_method->code_base() + handler_bci; @@ -908,6 +908,15 @@ IRT_ENTRY(void, InterpreterRuntime::update_mdp_for_ret(JavaThread* thread, int r fr.interpreter_frame_set_mdp(new_mdp); IRT_END +IRT_ENTRY(MethodCounters*, InterpreterRuntime::build_method_counters(JavaThread* thread, Method* m)) + MethodCounters* mcs = Method::build_method_counters(m, thread); + if (HAS_PENDING_EXCEPTION) { + assert((PENDING_EXCEPTION->is_a(SystemDictionary::OutOfMemoryError_klass())), "we expect only an OOM error here"); + CLEAR_PENDING_EXCEPTION; + } + return mcs; +IRT_END + IRT_ENTRY(void, InterpreterRuntime::at_safepoint(JavaThread* thread)) // We used to need an explict preserve_arguments here for invoke bytecodes. However, diff --git a/hotspot/src/share/vm/interpreter/interpreterRuntime.hpp b/hotspot/src/share/vm/interpreter/interpreterRuntime.hpp index 3aa2c8348e2..d46c43e94e0 100644 --- a/hotspot/src/share/vm/interpreter/interpreterRuntime.hpp +++ b/hotspot/src/share/vm/interpreter/interpreterRuntime.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -169,6 +169,7 @@ class InterpreterRuntime: AllStatic { #ifdef ASSERT static void verify_mdp(Method* method, address bcp, address mdp); #endif // ASSERT + static MethodCounters* build_method_counters(JavaThread* thread, Method* m); }; diff --git a/hotspot/src/share/vm/interpreter/invocationCounter.cpp b/hotspot/src/share/vm/interpreter/invocationCounter.cpp index 747516369ce..6a113d0ffc6 100644 --- a/hotspot/src/share/vm/interpreter/invocationCounter.cpp +++ b/hotspot/src/share/vm/interpreter/invocationCounter.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -104,15 +104,19 @@ const char* InvocationCounter::state_as_short_string(State state) { static address do_nothing(methodHandle method, TRAPS) { // dummy action for inactive invocation counters - method->invocation_counter()->set_carry(); - method->invocation_counter()->set_state(InvocationCounter::wait_for_nothing); + MethodCounters* mcs = method->method_counters(); + assert(mcs != NULL, ""); + mcs->invocation_counter()->set_carry(); + mcs->invocation_counter()->set_state(InvocationCounter::wait_for_nothing); return NULL; } static address do_decay(methodHandle method, TRAPS) { // decay invocation counters so compilation gets delayed - method->invocation_counter()->decay(); + MethodCounters* mcs = method->method_counters(); + assert(mcs != NULL, ""); + mcs->invocation_counter()->decay(); return NULL; } diff --git a/hotspot/src/share/vm/oops/method.cpp b/hotspot/src/share/vm/oops/method.cpp index 1e74a214830..b06c081781a 100644 --- a/hotspot/src/share/vm/oops/method.cpp +++ b/hotspot/src/share/vm/oops/method.cpp @@ -91,7 +91,7 @@ Method::Method(ConstMethod* xconst, AccessFlags access_flags, int size) { set_hidden(false); set_dont_inline(false); set_method_data(NULL); - set_interpreter_throwout_count(0); + set_method_counters(NULL); set_vtable_index(Method::garbage_vtable_index); // Fix and bury in Method* @@ -105,16 +105,6 @@ Method::Method(ConstMethod* xconst, AccessFlags access_flags, int size) { } NOT_PRODUCT(set_compiled_invocation_count(0);) - set_interpreter_invocation_count(0); - invocation_counter()->init(); - backedge_counter()->init(); - clear_number_of_breakpoints(); - -#ifdef TIERED - set_rate(0); - set_prev_event_count(0); - set_prev_time(0); -#endif } // Release Method*. The nmethod will be gone when we get here because @@ -124,6 +114,8 @@ void Method::deallocate_contents(ClassLoaderData* loader_data) { set_constMethod(NULL); MetadataFactory::free_metadata(loader_data, method_data()); set_method_data(NULL); + MetadataFactory::free_metadata(loader_data, method_counters()); + set_method_counters(NULL); // The nmethod will be gone when we get here. if (code() != NULL) _code = NULL; } @@ -323,7 +315,10 @@ bool Method::was_executed_more_than(int n) { // compiler does not bump invocation counter of compiled methods return true; } - else if (_invocation_counter.carry() || (method_data() != NULL && method_data()->invocation_counter()->carry())) { + else if ((method_counters() != NULL && + method_counters()->invocation_counter()->carry()) || + (method_data() != NULL && + method_data()->invocation_counter()->carry())) { // The carry bit is set when the counter overflows and causes // a compilation to occur. We don't know how many times // the counter has been reset, so we simply assume it has @@ -387,6 +382,18 @@ void Method::build_interpreter_method_data(methodHandle method, TRAPS) { } } +MethodCounters* Method::build_method_counters(Method* m, TRAPS) { + methodHandle mh(m); + ClassLoaderData* loader_data = mh->method_holder()->class_loader_data(); + MethodCounters* counters = MethodCounters::allocate(loader_data, CHECK_NULL); + if (mh->method_counters() == NULL) { + mh->set_method_counters(counters); + } else { + MetadataFactory::free_metadata(loader_data, counters); + } + return mh->method_counters(); +} + void Method::cleanup_inline_caches() { // The current system doesn't use inline caches in the interpreter // => nothing to do (keep this method around for future use) @@ -794,8 +801,6 @@ void Method::unlink_method() { set_signature_handler(NULL); } NOT_PRODUCT(set_compiled_invocation_count(0);) - invocation_counter()->reset(); - backedge_counter()->reset(); _adapter = NULL; _from_compiled_entry = NULL; @@ -808,8 +813,7 @@ void Method::unlink_method() { assert(!DumpSharedSpaces || _method_data == NULL, "unexpected method data?"); set_method_data(NULL); - set_interpreter_throwout_count(0); - set_interpreter_invocation_count(0); + set_method_counters(NULL); } // Called when the method_holder is getting linked. Setup entrypoints so the method @@ -1545,28 +1549,34 @@ void Method::clear_all_breakpoints() { int Method::invocation_count() { + MethodCounters *mcs = method_counters(); if (TieredCompilation) { MethodData* const mdo = method_data(); - if (invocation_counter()->carry() || ((mdo != NULL) ? mdo->invocation_counter()->carry() : false)) { + if (((mcs != NULL) ? mcs->invocation_counter()->carry() : false) || + ((mdo != NULL) ? mdo->invocation_counter()->carry() : false)) { return InvocationCounter::count_limit; } else { - return invocation_counter()->count() + ((mdo != NULL) ? mdo->invocation_counter()->count() : 0); + return ((mcs != NULL) ? mcs->invocation_counter()->count() : 0) + + ((mdo != NULL) ? mdo->invocation_counter()->count() : 0); } } else { - return invocation_counter()->count(); + return (mcs == NULL) ? 0 : mcs->invocation_counter()->count(); } } int Method::backedge_count() { + MethodCounters *mcs = method_counters(); if (TieredCompilation) { MethodData* const mdo = method_data(); - if (backedge_counter()->carry() || ((mdo != NULL) ? mdo->backedge_counter()->carry() : false)) { + if (((mcs != NULL) ? mcs->backedge_counter()->carry() : false) || + ((mdo != NULL) ? mdo->backedge_counter()->carry() : false)) { return InvocationCounter::count_limit; } else { - return backedge_counter()->count() + ((mdo != NULL) ? mdo->backedge_counter()->count() : 0); + return ((mcs != NULL) ? mcs->backedge_counter()->count() : 0) + + ((mdo != NULL) ? mdo->backedge_counter()->count() : 0); } } else { - return backedge_counter()->count(); + return (mcs == NULL) ? 0 : mcs->backedge_counter()->count(); } } @@ -1621,12 +1631,12 @@ void BreakpointInfo::set(Method* method) { assert(orig_bytecode() == code, "original bytecode must be the same"); } #endif + Thread *thread = Thread::current(); *method->bcp_from(_bci) = Bytecodes::_breakpoint; - method->incr_number_of_breakpoints(); + method->incr_number_of_breakpoints(thread); SystemDictionary::notice_modification(); { // Deoptimize all dependents on this method - Thread *thread = Thread::current(); HandleMark hm(thread); methodHandle mh(thread, method); Universe::flush_dependents_on_method(mh); @@ -1636,7 +1646,7 @@ void BreakpointInfo::set(Method* method) { void BreakpointInfo::clear(Method* method) { *method->bcp_from(_bci) = orig_bytecode(); assert(method->number_of_breakpoints() > 0, "must not go negative"); - method->decr_number_of_breakpoints(); + method->decr_number_of_breakpoints(Thread::current()); } // jmethodID handling diff --git a/hotspot/src/share/vm/oops/method.hpp b/hotspot/src/share/vm/oops/method.hpp index ea92383d1c2..3ca007f304b 100644 --- a/hotspot/src/share/vm/oops/method.hpp +++ b/hotspot/src/share/vm/oops/method.hpp @@ -31,6 +31,7 @@ #include "interpreter/invocationCounter.hpp" #include "oops/annotations.hpp" #include "oops/constantPool.hpp" +#include "oops/methodCounters.hpp" #include "oops/instanceKlass.hpp" #include "oops/oop.hpp" #include "oops/typeArrayOop.hpp" @@ -100,6 +101,7 @@ class CheckedExceptionElement; class LocalVariableTableElement; class AdapterHandlerEntry; class MethodData; +class MethodCounters; class ConstMethod; class InlineTableSizes; class KlassSizeStats; @@ -109,7 +111,7 @@ class Method : public Metadata { private: ConstMethod* _constMethod; // Method read-only data. MethodData* _method_data; - int _interpreter_invocation_count; // Count of times invoked (reused as prev_event_count in tiered) + MethodCounters* _method_counters; AccessFlags _access_flags; // Access flags int _vtable_index; // vtable index of this method (see VtableIndexFlag) // note: can have vtables with >2**16 elements (because of inheritance) @@ -124,15 +126,6 @@ class Method : public Metadata { _hidden : 1, _dont_inline : 1, : 3; - u2 _interpreter_throwout_count; // Count of times method was exited via exception while interpreting - u2 _number_of_breakpoints; // fullspeed debugging support - InvocationCounter _invocation_counter; // Incremented before each activation of the method - used to trigger frequency-based optimizations - InvocationCounter _backedge_counter; // Incremented before each backedge taken - used to trigger frequencey-based optimizations - -#ifdef TIERED - float _rate; // Events (invocation and backedge counter increments) per millisecond - jlong _prev_time; // Previous time the rate was acquired -#endif #ifndef PRODUCT int _compiled_invocation_count; // Number of nmethod invocations so far (for perf. debugging) @@ -247,11 +240,31 @@ class Method : public Metadata { void clear_all_breakpoints(); // Tracking number of breakpoints, for fullspeed debugging. // Only mutated by VM thread. - u2 number_of_breakpoints() const { return _number_of_breakpoints; } - void incr_number_of_breakpoints() { ++_number_of_breakpoints; } - void decr_number_of_breakpoints() { --_number_of_breakpoints; } + u2 number_of_breakpoints() const { + if (method_counters() == NULL) { + return 0; + } else { + return method_counters()->number_of_breakpoints(); + } + } + void incr_number_of_breakpoints(TRAPS) { + MethodCounters* mcs = get_method_counters(CHECK); + if (mcs != NULL) { + mcs->incr_number_of_breakpoints(); + } + } + void decr_number_of_breakpoints(TRAPS) { + MethodCounters* mcs = get_method_counters(CHECK); + if (mcs != NULL) { + mcs->decr_number_of_breakpoints(); + } + } // Initialization only - void clear_number_of_breakpoints() { _number_of_breakpoints = 0; } + void clear_number_of_breakpoints() { + if (method_counters() != NULL) { + method_counters()->clear_number_of_breakpoints(); + } + } // index into InstanceKlass methods() array // note: also used by jfr @@ -288,14 +301,20 @@ class Method : public Metadata { void set_highest_osr_comp_level(int level); // Count of times method was exited via exception while interpreting - void interpreter_throwout_increment() { - if (_interpreter_throwout_count < 65534) { - _interpreter_throwout_count++; + void interpreter_throwout_increment(TRAPS) { + MethodCounters* mcs = get_method_counters(CHECK); + if (mcs != NULL) { + mcs->interpreter_throwout_increment(); } } - int interpreter_throwout_count() const { return _interpreter_throwout_count; } - void set_interpreter_throwout_count(int count) { _interpreter_throwout_count = count; } + int interpreter_throwout_count() const { + if (method_counters() == NULL) { + return 0; + } else { + return method_counters()->interpreter_throwout_count(); + } + } // size of parameters int size_of_parameters() const { return constMethod()->size_of_parameters(); } @@ -339,23 +358,54 @@ class Method : public Metadata { MethodData* method_data() const { return _method_data; } + void set_method_data(MethodData* data) { _method_data = data; } - // invocation counter - InvocationCounter* invocation_counter() { return &_invocation_counter; } - InvocationCounter* backedge_counter() { return &_backedge_counter; } + MethodCounters* method_counters() const { + return _method_counters; + } + + + void set_method_counters(MethodCounters* counters) { + _method_counters = counters; + } #ifdef TIERED // We are reusing interpreter_invocation_count as a holder for the previous event count! // We can do that since interpreter_invocation_count is not used in tiered. - int prev_event_count() const { return _interpreter_invocation_count; } - void set_prev_event_count(int count) { _interpreter_invocation_count = count; } - jlong prev_time() const { return _prev_time; } - void set_prev_time(jlong time) { _prev_time = time; } - float rate() const { return _rate; } - void set_rate(float rate) { _rate = rate; } + int prev_event_count() const { + if (method_counters() == NULL) { + return 0; + } else { + return method_counters()->interpreter_invocation_count(); + } + } + void set_prev_event_count(int count, TRAPS) { + MethodCounters* mcs = get_method_counters(CHECK); + if (mcs != NULL) { + mcs->set_interpreter_invocation_count(count); + } + } + jlong prev_time() const { + return method_counters() == NULL ? 0 : method_counters()->prev_time(); + } + void set_prev_time(jlong time, TRAPS) { + MethodCounters* mcs = get_method_counters(CHECK); + if (mcs != NULL) { + mcs->set_prev_time(time); + } + } + float rate() const { + return method_counters() == NULL ? 0 : method_counters()->rate(); + } + void set_rate(float rate, TRAPS) { + MethodCounters* mcs = get_method_counters(CHECK); + if (mcs != NULL) { + mcs->set_rate(rate); + } + } #endif int invocation_count(); @@ -366,14 +416,17 @@ class Method : public Metadata { static void build_interpreter_method_data(methodHandle method, TRAPS); + static MethodCounters* build_method_counters(Method* m, TRAPS); + int interpreter_invocation_count() { if (TieredCompilation) return invocation_count(); - else return _interpreter_invocation_count; + else return (method_counters() == NULL) ? 0 : + method_counters()->interpreter_invocation_count(); } - void set_interpreter_invocation_count(int count) { _interpreter_invocation_count = count; } - int increment_interpreter_invocation_count() { + int increment_interpreter_invocation_count(TRAPS) { if (TieredCompilation) ShouldNotReachHere(); - return ++_interpreter_invocation_count; + MethodCounters* mcs = get_method_counters(CHECK_0); + return (mcs == NULL) ? 0 : mcs->increment_interpreter_invocation_count(); } #ifndef PRODUCT @@ -582,12 +635,12 @@ class Method : public Metadata { #endif /* CC_INTERP */ static ByteSize from_compiled_offset() { return byte_offset_of(Method, _from_compiled_entry); } static ByteSize code_offset() { return byte_offset_of(Method, _code); } - static ByteSize invocation_counter_offset() { return byte_offset_of(Method, _invocation_counter); } - static ByteSize backedge_counter_offset() { return byte_offset_of(Method, _backedge_counter); } static ByteSize method_data_offset() { return byte_offset_of(Method, _method_data); } - static ByteSize interpreter_invocation_counter_offset() { return byte_offset_of(Method, _interpreter_invocation_count); } + static ByteSize method_counters_offset() { + return byte_offset_of(Method, _method_counters); + } #ifndef PRODUCT static ByteSize compiled_invocation_counter_offset() { return byte_offset_of(Method, _compiled_invocation_count); } #endif // not PRODUCT @@ -598,8 +651,6 @@ class Method : public Metadata { // for code generation static int method_data_offset_in_bytes() { return offset_of(Method, _method_data); } - static int interpreter_invocation_counter_offset_in_bytes() - { return offset_of(Method, _interpreter_invocation_count); } static int intrinsic_id_offset_in_bytes() { return offset_of(Method, _intrinsic_id); } static int intrinsic_id_size_in_bytes() { return sizeof(u1); } @@ -757,6 +808,13 @@ class Method : public Metadata { private: void print_made_not_compilable(int comp_level, bool is_osr, bool report, const char* reason); + MethodCounters* get_method_counters(TRAPS) { + if (_method_counters == NULL) { + build_method_counters(this, CHECK_AND_CLEAR_NULL); + } + return _method_counters; + } + public: bool is_not_c1_compilable() const { return access_flags().is_not_c1_compilable(); } void set_not_c1_compilable() { _access_flags.set_not_c1_compilable(); } diff --git a/hotspot/src/share/vm/oops/methodCounters.cpp b/hotspot/src/share/vm/oops/methodCounters.cpp new file mode 100644 index 00000000000..53d3e682b77 --- /dev/null +++ b/hotspot/src/share/vm/oops/methodCounters.cpp @@ -0,0 +1,37 @@ +/* + * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ +#include "precompiled.hpp" +#include "oops/methodCounters.hpp" +#include "runtime/thread.inline.hpp" + +MethodCounters* MethodCounters::allocate(ClassLoaderData* loader_data, TRAPS) { + return new(loader_data, size(), false, THREAD) MethodCounters(); +} + +void MethodCounters::clear_counters() { + invocation_counter()->reset(); + backedge_counter()->reset(); + set_interpreter_throwout_count(0); + set_interpreter_invocation_count(0); +} diff --git a/hotspot/src/share/vm/oops/methodCounters.hpp b/hotspot/src/share/vm/oops/methodCounters.hpp new file mode 100644 index 00000000000..0a6c895b328 --- /dev/null +++ b/hotspot/src/share/vm/oops/methodCounters.hpp @@ -0,0 +1,124 @@ +/* + * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +#ifndef SHARE_VM_OOPS_METHODCOUNTERS_HPP +#define SHARE_VM_OOPS_METHODCOUNTERS_HPP + +#include "oops/metadata.hpp" +#include "interpreter/invocationCounter.hpp" + +class MethodCounters: public MetaspaceObj { + friend class VMStructs; + private: + int _interpreter_invocation_count; // Count of times invoked (reused as prev_event_count in tiered) + u2 _interpreter_throwout_count; // Count of times method was exited via exception while interpreting + u2 _number_of_breakpoints; // fullspeed debugging support + InvocationCounter _invocation_counter; // Incremented before each activation of the method - used to trigger frequency-based optimizations + InvocationCounter _backedge_counter; // Incremented before each backedge taken - used to trigger frequencey-based optimizations + +#ifdef TIERED + float _rate; // Events (invocation and backedge counter increments) per millisecond + jlong _prev_time; // Previous time the rate was acquired +#endif + + MethodCounters() : _interpreter_invocation_count(0), + _interpreter_throwout_count(0), + _number_of_breakpoints(0) +#ifdef TIERED + , _rate(0), + _prev_time(0) +#endif + { + invocation_counter()->init(); + backedge_counter()->init(); + } + + public: + static MethodCounters* allocate(ClassLoaderData* loader_data, TRAPS); + + void deallocate_contents(ClassLoaderData* loader_data) {} + DEBUG_ONLY(bool on_stack() { return false; }) // for template + + static int size() { return sizeof(MethodCounters) / wordSize; } + + bool is_klass() const { return false; } + + void clear_counters(); + + int interpreter_invocation_count() { + return _interpreter_invocation_count; + } + void set_interpreter_invocation_count(int count) { + _interpreter_invocation_count = count; + } + int increment_interpreter_invocation_count() { + return ++_interpreter_invocation_count; + } + + void interpreter_throwout_increment() { + if (_interpreter_throwout_count < 65534) { + _interpreter_throwout_count++; + } + } + int interpreter_throwout_count() const { + return _interpreter_throwout_count; + } + void set_interpreter_throwout_count(int count) { + _interpreter_throwout_count = count; + } + + u2 number_of_breakpoints() const { return _number_of_breakpoints; } + void incr_number_of_breakpoints() { ++_number_of_breakpoints; } + void decr_number_of_breakpoints() { --_number_of_breakpoints; } + void clear_number_of_breakpoints() { _number_of_breakpoints = 0; } + +#ifdef TIERED + jlong prev_time() const { return _prev_time; } + void set_prev_time(jlong time) { _prev_time = time; } + float rate() const { return _rate; } + void set_rate(float rate) { _rate = rate; } +#endif + + // invocation counter + InvocationCounter* invocation_counter() { return &_invocation_counter; } + InvocationCounter* backedge_counter() { return &_backedge_counter; } + + static ByteSize interpreter_invocation_counter_offset() { + return byte_offset_of(MethodCounters, _interpreter_invocation_count); + } + + static ByteSize invocation_counter_offset() { + return byte_offset_of(MethodCounters, _invocation_counter); + } + + static ByteSize backedge_counter_offset() { + return byte_offset_of(MethodCounters, _backedge_counter); + } + + static int interpreter_invocation_counter_offset_in_bytes() { + return offset_of(MethodCounters, _interpreter_invocation_count); + } + +}; +#endif //SHARE_VM_OOPS_METHODCOUNTERS_HPP diff --git a/hotspot/src/share/vm/oops/methodData.cpp b/hotspot/src/share/vm/oops/methodData.cpp index e43b93bafc0..b1a024f3d7c 100644 --- a/hotspot/src/share/vm/oops/methodData.cpp +++ b/hotspot/src/share/vm/oops/methodData.cpp @@ -732,14 +732,17 @@ int MethodData::mileage_of(Method* method) { } else { int iic = method->interpreter_invocation_count(); if (mileage < iic) mileage = iic; - InvocationCounter* ic = method->invocation_counter(); - InvocationCounter* bc = method->backedge_counter(); - int icval = ic->count(); - if (ic->carry()) icval += CompileThreshold; - if (mileage < icval) mileage = icval; - int bcval = bc->count(); - if (bc->carry()) bcval += CompileThreshold; - if (mileage < bcval) mileage = bcval; + MethodCounters* mcs = method->method_counters(); + if (mcs != NULL) { + InvocationCounter* ic = mcs->invocation_counter(); + InvocationCounter* bc = mcs->backedge_counter(); + int icval = ic->count(); + if (ic->carry()) icval += CompileThreshold; + if (mileage < icval) mileage = icval; + int bcval = bc->count(); + if (bc->carry()) bcval += CompileThreshold; + if (mileage < bcval) mileage = bcval; + } } return mileage; } diff --git a/hotspot/src/share/vm/opto/parseHelper.cpp b/hotspot/src/share/vm/opto/parseHelper.cpp index f2a1bd2bef4..e9486088dc9 100644 --- a/hotspot/src/share/vm/opto/parseHelper.cpp +++ b/hotspot/src/share/vm/opto/parseHelper.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -337,19 +337,21 @@ void Parse::increment_and_test_invocation_counter(int limit) { if (!count_invocations()) return; // Get the Method* node. - const TypePtr* adr_type = TypeMetadataPtr::make(method()); - Node *method_node = makecon(adr_type); + ciMethod* m = method(); + address counters_adr = m->ensure_method_counters(); - // Load the interpreter_invocation_counter from the Method*. - int offset = Method::interpreter_invocation_counter_offset_in_bytes(); - Node* adr_node = basic_plus_adr(method_node, method_node, offset); - Node* cnt = make_load(NULL, adr_node, TypeInt::INT, T_INT, adr_type); + Node* ctrl = control(); + const TypePtr* adr_type = TypeRawPtr::make(counters_adr); + Node *counters_node = makecon(adr_type); + Node* adr_iic_node = basic_plus_adr(counters_node, counters_node, + MethodCounters::interpreter_invocation_counter_offset_in_bytes()); + Node* cnt = make_load(ctrl, adr_iic_node, TypeInt::INT, T_INT, adr_type); test_counter_against_threshold(cnt, limit); // Add one to the counter and store Node* incr = _gvn.transform(new (C) AddINode(cnt, _gvn.intcon(1))); - store_to_memory( NULL, adr_node, incr, T_INT, adr_type ); + store_to_memory( ctrl, adr_iic_node, incr, T_INT, adr_type ); } //----------------------------method_data_addressing--------------------------- diff --git a/hotspot/src/share/vm/runtime/advancedThresholdPolicy.cpp b/hotspot/src/share/vm/runtime/advancedThresholdPolicy.cpp index ce5804a6052..81c2b74739d 100644 --- a/hotspot/src/share/vm/runtime/advancedThresholdPolicy.cpp +++ b/hotspot/src/share/vm/runtime/advancedThresholdPolicy.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -74,10 +74,11 @@ void AdvancedThresholdPolicy::initialize() { // update_rate() is called from select_task() while holding a compile queue lock. void AdvancedThresholdPolicy::update_rate(jlong t, Method* m) { + JavaThread* THREAD = JavaThread::current(); if (is_old(m)) { // We don't remove old methods from the queue, // so we can just zero the rate. - m->set_rate(0); + m->set_rate(0, THREAD); return; } @@ -93,13 +94,13 @@ void AdvancedThresholdPolicy::update_rate(jlong t, Method* m) { if (delta_s >= TieredRateUpdateMinTime) { // And we must've taken the previous point at least 1ms before. if (delta_t >= TieredRateUpdateMinTime && delta_e > 0) { - m->set_prev_time(t); - m->set_prev_event_count(event_count); - m->set_rate((float)delta_e / (float)delta_t); // Rate is events per millisecond + m->set_prev_time(t, THREAD); + m->set_prev_event_count(event_count, THREAD); + m->set_rate((float)delta_e / (float)delta_t, THREAD); // Rate is events per millisecond } else if (delta_t > TieredRateUpdateMaxTime && delta_e == 0) { // If nothing happened for 25ms, zero the rate. Don't modify prev values. - m->set_rate(0); + m->set_rate(0, THREAD); } } } diff --git a/hotspot/src/share/vm/runtime/compilationPolicy.cpp b/hotspot/src/share/vm/runtime/compilationPolicy.cpp index 713163a1001..cec42ae9195 100644 --- a/hotspot/src/share/vm/runtime/compilationPolicy.cpp +++ b/hotspot/src/share/vm/runtime/compilationPolicy.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -197,8 +197,10 @@ void NonTieredCompPolicy::reset_counter_for_invocation_event(methodHandle m) { // BUT also make sure the method doesn't look like it was never executed. // Set carry bit and reduce counter's value to min(count, CompileThreshold/2). - m->invocation_counter()->set_carry(); - m->backedge_counter()->set_carry(); + MethodCounters* mcs = m->method_counters(); + assert(mcs != NULL, "MethodCounters cannot be NULL for profiling"); + mcs->invocation_counter()->set_carry(); + mcs->backedge_counter()->set_carry(); assert(!m->was_never_executed(), "don't reset to 0 -- could be mistaken for never-executed"); } @@ -206,8 +208,10 @@ void NonTieredCompPolicy::reset_counter_for_invocation_event(methodHandle m) { void NonTieredCompPolicy::reset_counter_for_back_branch_event(methodHandle m) { // Delay next back-branch event but pump up invocation counter to triger // whole method compilation. - InvocationCounter* i = m->invocation_counter(); - InvocationCounter* b = m->backedge_counter(); + MethodCounters* mcs = m->method_counters(); + assert(mcs != NULL, "MethodCounters cannot be NULL for profiling"); + InvocationCounter* i = mcs->invocation_counter(); + InvocationCounter* b = mcs->backedge_counter(); // Don't set invocation_counter's value too low otherwise the method will // look like immature (ic < ~5300) which prevents the inlining based on @@ -226,7 +230,10 @@ void NonTieredCompPolicy::reset_counter_for_back_branch_event(methodHandle m) { class CounterDecay : public AllStatic { static jlong _last_timestamp; static void do_method(Method* m) { - m->invocation_counter()->decay(); + MethodCounters* mcs = m->method_counters(); + if (mcs != NULL) { + mcs->invocation_counter()->decay(); + } } public: static void decay(); @@ -264,30 +271,43 @@ void NonTieredCompPolicy::do_safepoint_work() { void NonTieredCompPolicy::reprofile(ScopeDesc* trap_scope, bool is_osr) { ScopeDesc* sd = trap_scope; + MethodCounters* mcs; + InvocationCounter* c; for (; !sd->is_top(); sd = sd->sender()) { - // Reset ICs of inlined methods, since they can trigger compilations also. - sd->method()->invocation_counter()->reset(); + mcs = sd->method()->method_counters(); + if (mcs != NULL) { + // Reset ICs of inlined methods, since they can trigger compilations also. + mcs->invocation_counter()->reset(); + } } - InvocationCounter* c = sd->method()->invocation_counter(); - if (is_osr) { - // It was an OSR method, so bump the count higher. - c->set(c->state(), CompileThreshold); - } else { - c->reset(); + mcs = sd->method()->method_counters(); + if (mcs != NULL) { + c = mcs->invocation_counter(); + if (is_osr) { + // It was an OSR method, so bump the count higher. + c->set(c->state(), CompileThreshold); + } else { + c->reset(); + } + mcs->backedge_counter()->reset(); } - sd->method()->backedge_counter()->reset(); } // This method can be called by any component of the runtime to notify the policy // that it's recommended to delay the complation of this method. void NonTieredCompPolicy::delay_compilation(Method* method) { - method->invocation_counter()->decay(); - method->backedge_counter()->decay(); + MethodCounters* mcs = method->method_counters(); + assert(mcs != NULL, "MethodCounters cannot be NULL"); + mcs->invocation_counter()->decay(); + mcs->backedge_counter()->decay(); } void NonTieredCompPolicy::disable_compilation(Method* method) { - method->invocation_counter()->set_state(InvocationCounter::wait_for_nothing); - method->backedge_counter()->set_state(InvocationCounter::wait_for_nothing); + MethodCounters* mcs = method->method_counters(); + if (mcs != NULL) { + mcs->invocation_counter()->set_state(InvocationCounter::wait_for_nothing); + mcs->backedge_counter()->set_state(InvocationCounter::wait_for_nothing); + } } CompileTask* NonTieredCompPolicy::select_task(CompileQueue* compile_queue) { @@ -370,8 +390,10 @@ nmethod* NonTieredCompPolicy::event(methodHandle method, methodHandle inlinee, i #ifndef PRODUCT void NonTieredCompPolicy::trace_frequency_counter_overflow(methodHandle m, int branch_bci, int bci) { if (TraceInvocationCounterOverflow) { - InvocationCounter* ic = m->invocation_counter(); - InvocationCounter* bc = m->backedge_counter(); + MethodCounters* mcs = m->method_counters(); + assert(mcs != NULL, "MethodCounters cannot be NULL for profiling"); + InvocationCounter* ic = mcs->invocation_counter(); + InvocationCounter* bc = mcs->backedge_counter(); ResourceMark rm; const char* msg = bci == InvocationEntryBci diff --git a/hotspot/src/share/vm/runtime/fprofiler.cpp b/hotspot/src/share/vm/runtime/fprofiler.cpp index ce910b45fca..111c4db5aa3 100644 --- a/hotspot/src/share/vm/runtime/fprofiler.cpp +++ b/hotspot/src/share/vm/runtime/fprofiler.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -421,7 +421,8 @@ class interpretedNode : public ProfilerNode { void print_method_on(outputStream* st) { ProfilerNode::print_method_on(st); - if (Verbose) method()->invocation_counter()->print_short(); + MethodCounters* mcs = method()->method_counters(); + if (Verbose && mcs != NULL) mcs->invocation_counter()->print_short(); } }; diff --git a/hotspot/src/share/vm/runtime/simpleThresholdPolicy.cpp b/hotspot/src/share/vm/runtime/simpleThresholdPolicy.cpp index fbb0f89c380..0752fac9d79 100644 --- a/hotspot/src/share/vm/runtime/simpleThresholdPolicy.cpp +++ b/hotspot/src/share/vm/runtime/simpleThresholdPolicy.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -153,8 +153,10 @@ void SimpleThresholdPolicy::set_carry_if_necessary(InvocationCounter *counter) { // Set carry flags on the counters if necessary void SimpleThresholdPolicy::handle_counter_overflow(Method* method) { - set_carry_if_necessary(method->invocation_counter()); - set_carry_if_necessary(method->backedge_counter()); + MethodCounters *mcs = method->method_counters(); + assert(mcs != NULL, ""); + set_carry_if_necessary(mcs->invocation_counter()); + set_carry_if_necessary(mcs->backedge_counter()); MethodData* mdo = method->method_data(); if (mdo != NULL) { set_carry_if_necessary(mdo->invocation_counter()); diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index b3e445f3d9e..f26d86db5c2 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -77,6 +77,7 @@ #include "oops/klass.hpp" #include "oops/markOop.hpp" #include "oops/methodData.hpp" +#include "oops/methodCounters.hpp" #include "oops/method.hpp" #include "oops/objArrayKlass.hpp" #include "oops/objArrayOop.hpp" @@ -348,16 +349,17 @@ typedef BinaryTreeDictionary MetablockTreeDictionary; nonstatic_field(MethodData, _arg_local, intx) \ nonstatic_field(MethodData, _arg_stack, intx) \ nonstatic_field(MethodData, _arg_returned, intx) \ - nonstatic_field(Method, _constMethod, ConstMethod*) \ - nonstatic_field(Method, _method_data, MethodData*) \ - nonstatic_field(Method, _interpreter_invocation_count, int) \ + nonstatic_field(MethodCounters, _interpreter_invocation_count, int) \ + nonstatic_field(MethodCounters, _interpreter_throwout_count, u2) \ + nonstatic_field(MethodCounters, _number_of_breakpoints, u2) \ + nonstatic_field(MethodCounters, _invocation_counter, InvocationCounter) \ + nonstatic_field(MethodCounters, _backedge_counter, InvocationCounter) \ + nonstatic_field(Method, _constMethod, ConstMethod*) \ + nonstatic_field(Method, _method_data, MethodData*) \ + nonstatic_field(Method, _method_counters, MethodCounters*) \ nonstatic_field(Method, _access_flags, AccessFlags) \ nonstatic_field(Method, _vtable_index, int) \ nonstatic_field(Method, _method_size, u2) \ - nonstatic_field(Method, _interpreter_throwout_count, u2) \ - nonstatic_field(Method, _number_of_breakpoints, u2) \ - nonstatic_field(Method, _invocation_counter, InvocationCounter) \ - nonstatic_field(Method, _backedge_counter, InvocationCounter) \ nonproduct_nonstatic_field(Method, _compiled_invocation_count, int) \ volatile_nonstatic_field(Method, _code, nmethod*) \ nonstatic_field(Method, _i2i_entry, address) \ @@ -1381,6 +1383,7 @@ typedef BinaryTreeDictionary MetablockTreeDictionary; declare_type(ConstantPoolCache, MetaspaceObj) \ declare_type(MethodData, Metadata) \ declare_type(Method, Metadata) \ + declare_type(MethodCounters, MetaspaceObj) \ declare_type(ConstMethod, MetaspaceObj) \ \ declare_toplevel_type(Symbol) \ From 37fe1421a84ea88556ff0afbfb19ba00973ebbec Mon Sep 17 00:00:00 2001 From: Zhengyu Gu Date: Wed, 10 Apr 2013 08:55:50 -0400 Subject: [PATCH 04/50] 8010151: nsk/regression/b6653214 fails "assert(snapshot != NULL) failed: Worker should not be started" Fixed a racing condition when shutting down NMT while worker thread is being started, also fixed a few mis-declared volatile pointers. Reviewed-by: dholmes, dlong --- hotspot/src/share/vm/runtime/thread.hpp | 4 +-- .../src/share/vm/services/memTrackWorker.cpp | 11 ++++---- .../src/share/vm/services/memTrackWorker.hpp | 4 ++- hotspot/src/share/vm/services/memTracker.cpp | 26 +++++++++---------- hotspot/src/share/vm/services/memTracker.hpp | 8 +++--- 5 files changed, 27 insertions(+), 26 deletions(-) diff --git a/hotspot/src/share/vm/runtime/thread.hpp b/hotspot/src/share/vm/runtime/thread.hpp index 259a4765cf4..d64ca311c65 100644 --- a/hotspot/src/share/vm/runtime/thread.hpp +++ b/hotspot/src/share/vm/runtime/thread.hpp @@ -1056,11 +1056,11 @@ class JavaThread: public Thread { #if INCLUDE_NMT // native memory tracking inline MemRecorder* get_recorder() const { return (MemRecorder*)_recorder; } - inline void set_recorder(MemRecorder* rc) { _recorder = (volatile MemRecorder*)rc; } + inline void set_recorder(MemRecorder* rc) { _recorder = rc; } private: // per-thread memory recorder - volatile MemRecorder* _recorder; + MemRecorder* volatile _recorder; #endif // INCLUDE_NMT // Suspend/resume support for JavaThread diff --git a/hotspot/src/share/vm/services/memTrackWorker.cpp b/hotspot/src/share/vm/services/memTrackWorker.cpp index 8c38d1a3731..3e9bcd2f6c4 100644 --- a/hotspot/src/share/vm/services/memTrackWorker.cpp +++ b/hotspot/src/share/vm/services/memTrackWorker.cpp @@ -39,7 +39,7 @@ void GenerationData::reset() { } } -MemTrackWorker::MemTrackWorker() { +MemTrackWorker::MemTrackWorker(MemSnapshot* snapshot): _snapshot(snapshot) { // create thread uses cgc thread type for now. We should revisit // the option, or create new thread type. _has_error = !os::create_thread(this, os::cgc_thread); @@ -88,8 +88,7 @@ void MemTrackWorker::run() { assert(MemTracker::is_on(), "native memory tracking is off"); this->initialize_thread_local_storage(); this->record_stack_base_and_size(); - MemSnapshot* snapshot = MemTracker::get_snapshot(); - assert(snapshot != NULL, "Worker should not be started"); + assert(_snapshot != NULL, "Worker should not be started"); MemRecorder* rec; unsigned long processing_generation = 0; bool worker_idle = false; @@ -109,7 +108,7 @@ void MemTrackWorker::run() { } // merge the recorder into staging area - if (!snapshot->merge(rec)) { + if (!_snapshot->merge(rec)) { MemTracker::shutdown(MemTracker::NMT_out_of_memory); } else { NOT_PRODUCT(_merge_count ++;) @@ -132,7 +131,7 @@ void MemTrackWorker::run() { _head = (_head + 1) % MAX_GENERATIONS; } // promote this generation data to snapshot - if (!snapshot->promote(number_of_classes)) { + if (!_snapshot->promote(number_of_classes)) { // failed to promote, means out of memory MemTracker::shutdown(MemTracker::NMT_out_of_memory); } @@ -140,7 +139,7 @@ void MemTrackWorker::run() { // worker thread is idle worker_idle = true; MemTracker::report_worker_idle(); - snapshot->wait(1000); + _snapshot->wait(1000); ThreadCritical tc; // check if more data arrived if (!_gen[_head].has_more_recorder()) { diff --git a/hotspot/src/share/vm/services/memTrackWorker.hpp b/hotspot/src/share/vm/services/memTrackWorker.hpp index be80e294d58..964aad31db8 100644 --- a/hotspot/src/share/vm/services/memTrackWorker.hpp +++ b/hotspot/src/share/vm/services/memTrackWorker.hpp @@ -85,8 +85,10 @@ class MemTrackWorker : public NamedThread { bool _has_error; + MemSnapshot* _snapshot; + public: - MemTrackWorker(); + MemTrackWorker(MemSnapshot* snapshot); ~MemTrackWorker(); _NOINLINE_ void* operator new(size_t size); _NOINLINE_ void* operator new(size_t size, const std::nothrow_t& nothrow_constant); diff --git a/hotspot/src/share/vm/services/memTracker.cpp b/hotspot/src/share/vm/services/memTracker.cpp index 13b6de80a21..3d4393073fc 100644 --- a/hotspot/src/share/vm/services/memTracker.cpp +++ b/hotspot/src/share/vm/services/memTracker.cpp @@ -53,12 +53,12 @@ void SyncThreadRecorderClosure::do_thread(Thread* thread) { } -MemRecorder* MemTracker::_global_recorder = NULL; +MemRecorder* volatile MemTracker::_global_recorder = NULL; MemSnapshot* MemTracker::_snapshot = NULL; MemBaseline MemTracker::_baseline; Mutex* MemTracker::_query_lock = NULL; -volatile MemRecorder* MemTracker::_merge_pending_queue = NULL; -volatile MemRecorder* MemTracker::_pooled_recorders = NULL; +MemRecorder* volatile MemTracker::_merge_pending_queue = NULL; +MemRecorder* volatile MemTracker::_pooled_recorders = NULL; MemTrackWorker* MemTracker::_worker_thread = NULL; int MemTracker::_sync_point_skip_count = 0; MemTracker::NMTLevel MemTracker::_tracking_level = MemTracker::NMT_off; @@ -128,7 +128,7 @@ void MemTracker::start() { _snapshot = new (std::nothrow)MemSnapshot(); if (_snapshot != NULL) { - if (!_snapshot->out_of_memory() && start_worker()) { + if (!_snapshot->out_of_memory() && start_worker(_snapshot)) { _state = NMT_started; NMT_track_callsite = (_tracking_level == NMT_detail && can_walk_stack()); return; @@ -209,7 +209,7 @@ void MemTracker::final_shutdown() { // delete all pooled recorders void MemTracker::delete_all_pooled_recorders() { // free all pooled recorders - volatile MemRecorder* cur_head = _pooled_recorders; + MemRecorder* volatile cur_head = _pooled_recorders; if (cur_head != NULL) { MemRecorder* null_ptr = NULL; while (cur_head != NULL && (void*)cur_head != Atomic::cmpxchg_ptr((void*)null_ptr, @@ -543,14 +543,14 @@ void MemTracker::sync() { /* * Start worker thread. */ -bool MemTracker::start_worker() { - assert(_worker_thread == NULL, "Just Check"); - _worker_thread = new (std::nothrow) MemTrackWorker(); - if (_worker_thread == NULL || _worker_thread->has_error()) { - if (_worker_thread != NULL) { - delete _worker_thread; - _worker_thread = NULL; - } +bool MemTracker::start_worker(MemSnapshot* snapshot) { + assert(_worker_thread == NULL && _snapshot != NULL, "Just Check"); + _worker_thread = new (std::nothrow) MemTrackWorker(snapshot); + if (_worker_thread == NULL) { + return false; + } else if (_worker_thread->has_error()) { + delete _worker_thread; + _worker_thread = NULL; return false; } _worker_thread->start(); diff --git a/hotspot/src/share/vm/services/memTracker.hpp b/hotspot/src/share/vm/services/memTracker.hpp index ebcc41500d3..a7d06755288 100644 --- a/hotspot/src/share/vm/services/memTracker.hpp +++ b/hotspot/src/share/vm/services/memTracker.hpp @@ -421,7 +421,7 @@ class MemTracker : AllStatic { private: // start native memory tracking worker thread - static bool start_worker(); + static bool start_worker(MemSnapshot* snapshot); // called by worker thread to complete shutdown process static void final_shutdown(); @@ -475,18 +475,18 @@ class MemTracker : AllStatic { // a thread can start to allocate memory before it is attached // to VM 'Thread', those memory activities are recorded here. // ThreadCritical is required to guard this global recorder. - static MemRecorder* _global_recorder; + static MemRecorder* volatile _global_recorder; // main thread id debug_only(static intx _main_thread_tid;) // pending recorders to be merged - static volatile MemRecorder* _merge_pending_queue; + static MemRecorder* volatile _merge_pending_queue; NOT_PRODUCT(static volatile jint _pending_recorder_count;) // pooled memory recorders - static volatile MemRecorder* _pooled_recorders; + static MemRecorder* volatile _pooled_recorders; // memory recorder pool management, uses following // counter to determine if a released memory recorder From 01e43be718963d47cdd27ccd5f91cfbfbdd351c7 Mon Sep 17 00:00:00 2001 From: Christian Thalinger Date: Fri, 12 Apr 2013 12:22:59 -0700 Subject: [PATCH 05/50] 8011933: add number of classes, methods and time spent to CompileTheWorld Reviewed-by: jrose, kvn --- .../src/share/vm/classfile/classLoader.cpp | 28 ++++++++++++------- .../src/share/vm/classfile/classLoader.hpp | 5 ++-- 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/hotspot/src/share/vm/classfile/classLoader.cpp b/hotspot/src/share/vm/classfile/classLoader.cpp index 7e92f0661c8..5b9358b98e5 100644 --- a/hotspot/src/share/vm/classfile/classLoader.cpp +++ b/hotspot/src/share/vm/classfile/classLoader.cpp @@ -1274,13 +1274,16 @@ void ClassLoader::compile_the_world() { Handle system_class_loader (THREAD, SystemDictionary::java_system_loader()); // Iterate over all bootstrap class path entries ClassPathEntry* e = _first_entry; + jlong start = os::javaTimeMillis(); while (e != NULL) { // We stop at rt.jar, unless it is the first bootstrap path entry if (e->is_rt_jar() && e != _first_entry) break; e->compile_the_world(system_class_loader, CATCH); e = e->next(); } - tty->print_cr("CompileTheWorld : Done"); + jlong end = os::javaTimeMillis(); + tty->print_cr("CompileTheWorld : Done (%d classes, %d methods, %d ms)", + _compile_the_world_class_counter, _compile_the_world_method_counter, (end - start)); { // Print statistics as if before normal exit: extern void print_statistics(); @@ -1289,7 +1292,8 @@ void ClassLoader::compile_the_world() { vm_exit(0); } -int ClassLoader::_compile_the_world_counter = 0; +int ClassLoader::_compile_the_world_class_counter = 0; +int ClassLoader::_compile_the_world_method_counter = 0; static int _codecache_sweep_counter = 0; // Filter out all exceptions except OOMs @@ -1311,8 +1315,8 @@ void ClassLoader::compile_the_world_in(char* name, Handle loader, TRAPS) { // If the file has a period after removing .class, it's not really a // valid class file. The class loader will check everything else. if (strchr(buffer, '.') == NULL) { - _compile_the_world_counter++; - if (_compile_the_world_counter > CompileTheWorldStopAt) return; + _compile_the_world_class_counter++; + if (_compile_the_world_class_counter > CompileTheWorldStopAt) return; // Construct name without extension TempNewSymbol sym = SymbolTable::new_symbol(buffer, CHECK); @@ -1329,16 +1333,16 @@ void ClassLoader::compile_the_world_in(char* name, Handle loader, TRAPS) { if (HAS_PENDING_EXCEPTION) { // If something went wrong in preloading we just ignore it clear_pending_exception_if_not_oom(CHECK); - tty->print_cr("Preloading failed for (%d) %s", _compile_the_world_counter, buffer); + tty->print_cr("Preloading failed for (%d) %s", _compile_the_world_class_counter, buffer); } } - if (_compile_the_world_counter >= CompileTheWorldStartAt) { + if (_compile_the_world_class_counter >= CompileTheWorldStartAt) { if (k.is_null() || exception_occurred) { // If something went wrong (e.g. ExceptionInInitializerError) we skip this class - tty->print_cr("CompileTheWorld (%d) : Skipping %s", _compile_the_world_counter, buffer); + tty->print_cr("CompileTheWorld (%d) : Skipping %s", _compile_the_world_class_counter, buffer); } else { - tty->print_cr("CompileTheWorld (%d) : %s", _compile_the_world_counter, buffer); + tty->print_cr("CompileTheWorld (%d) : %s", _compile_the_world_class_counter, buffer); // Preload all classes to get around uncommon traps // Iterate over all methods in class for (int n = 0; n < k->methods()->length(); n++) { @@ -1356,7 +1360,9 @@ void ClassLoader::compile_the_world_in(char* name, Handle loader, TRAPS) { methodHandle(), 0, "CTW", THREAD); if (HAS_PENDING_EXCEPTION) { clear_pending_exception_if_not_oom(CHECK); - tty->print_cr("CompileTheWorld (%d) : Skipping method: %s", _compile_the_world_counter, m->name()->as_C_string()); + tty->print_cr("CompileTheWorld (%d) : Skipping method: %s", _compile_the_world_class_counter, m->name()->as_C_string()); + } else { + _compile_the_world_method_counter++; } if (TieredCompilation && TieredStopAtLevel >= CompLevel_full_optimization) { // Clobber the first compile and force second tier compilation @@ -1370,7 +1376,9 @@ void ClassLoader::compile_the_world_in(char* name, Handle loader, TRAPS) { methodHandle(), 0, "CTW", THREAD); if (HAS_PENDING_EXCEPTION) { clear_pending_exception_if_not_oom(CHECK); - tty->print_cr("CompileTheWorld (%d) : Skipping method: %s", _compile_the_world_counter, m->name()->as_C_string()); + tty->print_cr("CompileTheWorld (%d) : Skipping method: %s", _compile_the_world_class_counter, m->name()->as_C_string()); + } else { + _compile_the_world_method_counter++; } } } diff --git a/hotspot/src/share/vm/classfile/classLoader.hpp b/hotspot/src/share/vm/classfile/classLoader.hpp index aa68ed2d0c1..786914cad22 100644 --- a/hotspot/src/share/vm/classfile/classLoader.hpp +++ b/hotspot/src/share/vm/classfile/classLoader.hpp @@ -340,11 +340,12 @@ class ClassLoader: AllStatic { // Force compilation of all methods in all classes in bootstrap class path (stress test) #ifndef PRODUCT private: - static int _compile_the_world_counter; + static int _compile_the_world_class_counter; + static int _compile_the_world_method_counter; public: static void compile_the_world(); static void compile_the_world_in(char* name, Handle loader, TRAPS); - static int compile_the_world_counter() { return _compile_the_world_counter; } + static int compile_the_world_counter() { return _compile_the_world_class_counter; } #endif //PRODUCT }; From 4ac4649aabfe803de91f98f74c2faaa19715ec5e Mon Sep 17 00:00:00 2001 From: Christian Thalinger Date: Fri, 12 Apr 2013 15:43:07 -0700 Subject: [PATCH 06/50] 8011678: test/Makefile should pick up JT_HOME environment variable Reviewed-by: kvn --- hotspot/test/Makefile | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/hotspot/test/Makefile b/hotspot/test/Makefile index 7bd42a1e28a..f8bccc6693b 100644 --- a/hotspot/test/Makefile +++ b/hotspot/test/Makefile @@ -162,7 +162,9 @@ clean: # jtreg tests # Expect JT_HOME to be set for jtreg tests. (home for jtreg) -JT_HOME = $(SLASH_JAVA)/re/jtreg/4.0/promoted/latest/binaries/jtreg +ifndef JT_HOME + JT_HOME = $(SLASH_JAVA)/re/jtreg/4.0/promoted/latest/binaries/jtreg +endif ifdef JPRT_JTREG_HOME JT_HOME = $(JPRT_JTREG_HOME) endif From 55c4ce1ca1ed5cc8369b9e7524e6bf8afcb9c281 Mon Sep 17 00:00:00 2001 From: David Chase Date: Fri, 12 Apr 2013 15:53:30 -0700 Subject: [PATCH 07/50] 7104565: trim jprt build targets Remove JPRT debug builds, remove -DDEBUG -DFASTDEBUG and use ASSERT instead in sources Reviewed-by: dholmes, kvn, coleenp --- hotspot/make/Makefile | 63 ++++++++++++------- hotspot/make/bsd/Makefile | 44 ++++++------- hotspot/make/bsd/makefiles/buildtree.make | 16 +++-- hotspot/make/bsd/makefiles/debug.make | 19 +++--- hotspot/make/bsd/makefiles/defs.make | 11 ++-- hotspot/make/bsd/makefiles/fastdebug.make | 6 +- hotspot/make/bsd/makefiles/jvmg.make | 42 ------------- hotspot/make/bsd/makefiles/profiled.make | 30 --------- hotspot/make/jprt.properties | 49 ++++----------- hotspot/make/linux/Makefile | 43 ++++++------- hotspot/make/linux/makefiles/buildtree.make | 16 +++-- hotspot/make/linux/makefiles/debug.make | 19 +++--- hotspot/make/linux/makefiles/defs.make | 25 ++++---- hotspot/make/linux/makefiles/fastdebug.make | 6 +- hotspot/make/linux/makefiles/jvmg.make | 42 ------------- hotspot/make/linux/makefiles/profiled.make | 30 --------- hotspot/make/solaris/Makefile | 28 +++++---- hotspot/make/solaris/makefiles/buildtree.make | 20 +++--- hotspot/make/solaris/makefiles/debug.make | 20 +++--- hotspot/make/solaris/makefiles/defs.make | 13 ++-- hotspot/make/solaris/makefiles/fastdebug.make | 8 +-- hotspot/make/solaris/makefiles/jvmg.make | 56 ----------------- hotspot/make/solaris/makefiles/profiled.make | 44 ------------- hotspot/make/windows/build.make | 10 +-- hotspot/make/windows/makefiles/defs.make | 6 +- hotspot/make/windows/makefiles/vm.make | 6 +- .../projectfiles/compiler2/ADLCompiler.dsp | 2 +- .../projectfiles/tiered/ADLCompiler.dsp | 2 +- hotspot/src/cpu/sparc/vm/frame_sparc.cpp | 4 +- .../src/os/bsd/dtrace/generateJvmOffsets.cpp | 6 +- .../os/solaris/dtrace/generateJvmOffsets.cpp | 8 +-- hotspot/src/os/windows/vm/os_windows.cpp | 3 - hotspot/src/share/tools/hsdis/Makefile | 7 +-- .../src/share/vm/classfile/stackMapFrame.hpp | 6 +- .../concurrentMarkSweepGeneration.cpp | 14 ++--- hotspot/src/share/vm/memory/allocation.hpp | 4 +- hotspot/src/share/vm/runtime/vmThread.cpp | 2 +- 37 files changed, 225 insertions(+), 505 deletions(-) delete mode 100644 hotspot/make/bsd/makefiles/jvmg.make delete mode 100644 hotspot/make/bsd/makefiles/profiled.make delete mode 100644 hotspot/make/linux/makefiles/jvmg.make delete mode 100644 hotspot/make/linux/makefiles/profiled.make delete mode 100644 hotspot/make/solaris/makefiles/jvmg.make delete mode 100644 hotspot/make/solaris/makefiles/profiled.make diff --git a/hotspot/make/Makefile b/hotspot/make/Makefile index 8dad67f074e..e1fda57c4c6 100644 --- a/hotspot/make/Makefile +++ b/hotspot/make/Makefile @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Top level gnumake file for hotspot builds @@ -85,15 +85,15 @@ else endif # Typical C1/C2 targets made available with this Makefile -C1_VM_TARGETS=product1 fastdebug1 optimized1 jvmg1 -C2_VM_TARGETS=product fastdebug optimized jvmg -ZERO_VM_TARGETS=productzero fastdebugzero optimizedzero jvmgzero -SHARK_VM_TARGETS=productshark fastdebugshark optimizedshark jvmgshark -MINIMAL1_VM_TARGETS=productminimal1 fastdebugminimal1 jvmgminimal1 +C1_VM_TARGETS=product1 fastdebug1 optimized1 debug1 +C2_VM_TARGETS=product fastdebug optimized debug +ZERO_VM_TARGETS=productzero fastdebugzero optimizedzero debugzero +SHARK_VM_TARGETS=productshark fastdebugshark optimizedshark debugshark +MINIMAL1_VM_TARGETS=productminimal1 fastdebugminimal1 debugminimal1 COMMON_VM_PRODUCT_TARGETS=product product1 docs export_product COMMON_VM_FASTDEBUG_TARGETS=fastdebug fastdebug1 docs export_fastdebug -COMMON_VM_DEBUG_TARGETS=jvmg jvmg1 docs export_debug +COMMON_VM_DEBUG_TARGETS=debug debug1 docs export_debug # JDK directory list JDK_DIRS=bin include jre lib demo @@ -103,13 +103,13 @@ all: all_product all_fastdebug ifeq ($(JVM_VARIANT_MINIMAL1),true) all_product: productminimal1 all_fastdebug: fastdebugminimal1 -all_debug: jvmgminimal1 +all_debug: debugminimal1 endif ifdef BUILD_CLIENT_ONLY all_product: product1 docs export_product all_fastdebug: fastdebug1 docs export_fastdebug -all_debug: jvmg1 docs export_debug +all_debug: debug1 docs export_debug else ifeq ($(MACOSX_UNIVERSAL),true) all_product: universal_product @@ -127,13 +127,13 @@ all_optimized: optimized optimized1 docs export_optimized allzero: all_productzero all_fastdebugzero all_productzero: productzero docs export_product all_fastdebugzero: fastdebugzero docs export_fastdebug -all_debugzero: jvmgzero docs export_debug +all_debugzero: debugzero docs export_debug all_optimizedzero: optimizedzero docs export_optimized allshark: all_productshark all_fastdebugshark all_productshark: productshark docs export_product all_fastdebugshark: fastdebugshark docs export_fastdebug -all_debugshark: jvmgshark docs export_debug +all_debugshark: debugshark docs export_debug all_optimizedshark: optimizedshark docs export_optimized # Do everything @@ -227,7 +227,7 @@ generic_buildshark: $(MKDIR) -p $(OUTPUTDIR) $(CD) $(OUTPUTDIR); \ $(MAKE) -f $(ABS_OS_MAKEFILE) \ - $(MAKE_ARGS) $(VM_TARGET) + $(MAKE_ARGS) $(VM_TARGET) generic_buildminimal1: ifeq ($(JVM_VARIANT_MINIMAL1),true) @@ -260,7 +260,7 @@ export_fastdebug: EXPORT_SUBDIR=/$(@:export_%=%) \ generic_export export_debug: - $(MAKE) BUILD_FLAVOR=$(@:export_%=%) VM_SUBDIR=${VM_DEBUG} \ + $(MAKE) BUILD_FLAVOR=$(@:export_%=%) VM_SUBDIR=$(@:export_%=%) \ EXPORT_SUBDIR=/$(@:export_%=%) \ generic_export export_optimized: @@ -281,7 +281,7 @@ export_fastdebug_jdk:: ALT_EXPORT_PATH=$(JDK_IMAGE_DIR)/$(@:export_%_jdk=%) \ generic_export export_debug_jdk:: - $(MAKE) BUILD_FLAVOR=$(@:export_%_jdk=%) VM_SUBDIR=${VM_DEBUG} \ + $(MAKE) BUILD_FLAVOR=$(@:export_%_jdk=%) VM_SUBDIR=$(@:export_%_jdk=%) \ ALT_EXPORT_PATH=$(JDK_IMAGE_DIR)/$(@:export_%_jdk=%) \ generic_export @@ -323,7 +323,7 @@ endif # Bin files (windows) ifeq ($(OSNAME),windows) -# Get jvm.lib +# Get jvm.lib $(EXPORT_LIB_DIR)/%.lib: $(MISC_DIR)/%.lib $(install-file) @@ -541,11 +541,11 @@ generic_test: @$(RUN_JVM) -XXaltjvm=$(ALTJVM_DIR) -showversion -help # C2 test targets -test_product test_optimized test_fastdebug test_jvmg: +test_product test_optimized test_fastdebug test_debug: @$(MAKE) generic_test ALTJVM_DIR="$(C2_DIR)/$(@:test_%=%)" # C1 test targets -test_product1 test_optimized1 test_fastdebug1 test_jvmg1: +test_product1 test_optimized1 test_fastdebug1 test_debug1: ifeq ($(ARCH_DATA_MODEL), 32) @$(MAKE) generic_test ALTJVM_DIR="$(C1_DIR)/$(@:test_%1=%)" else @@ -553,15 +553,15 @@ test_product1 test_optimized1 test_fastdebug1 test_jvmg1: endif # Zero test targets -test_productzero test_optimizedzero test_fastdebugzero test_jvmgzero: +test_productzero test_optimizedzero test_fastdebugzero test_debugzero: @$(MAKE) generic_test ALTJVM_DIR="$(ZERO_DIR)/$(@:test_%zero=%)" # Shark test targets -test_productshark test_optimizedshark test_fastdebugshark test_jvmgshark: +test_productshark test_optimizedshark test_fastdebugshark test_debugshark: @$(MAKE) generic_test ALTJVM_DIR="$(SHARK_DIR)/$(@:test_%shark=%)" # Minimal1 test targets -test_productminimal1 test_optimizedminimal1 test_fastdebugminimal1 test_jvmgminimal1: +test_productminimal1 test_optimizedminimal1 test_fastdebugminimal1 test_debugminimal1: @$(MAKE) generic_test ALTJVM_DIR="$(MINIMAL1_DIR)/$(@:test_%minimal1=%)" @@ -626,7 +626,7 @@ help: intro_help target_help variable_help notes_help examples_help # Intro help message intro_help: @$(ECHO) \ -"Makefile for the Hotspot workspace." +"Makefile for the Hotspot workspace." @$(ECHO) \ "Default behavior is to build and create an export area for the j2se builds." @@ -637,7 +637,7 @@ target_help: @$(ECHO) "world: Same as: all create_jdk" @$(ECHO) "all_product: Same as: product product1 export_product" @$(ECHO) "all_fastdebug: Same as: fastdebug fastdebug1 export_fastdebug" - @$(ECHO) "all_debug: Same as: jvmg jvmg1 export_debug" + @$(ECHO) "all_debug: Same as: debug debug1 export_debug" @$(ECHO) "all_optimized: Same as: optimized optimized1 export_optimized" @$(ECHO) "clean: Clean all areas" @$(ECHO) "export_product: Export product files to EXPORT_PATH" @@ -730,7 +730,7 @@ examples_help: @$(ECHO) \ " $(MAKE) world" @$(ECHO) \ -" $(MAKE) ALT_BOOTDIR=/opt/java/jdk$(PREVIOUS_JDK_VERSION)" +" $(MAKE) ALT_BOOTDIR=/opt/java/jdk$(PREVIOUS_JDK_VERSION)" @$(ECHO) \ " $(MAKE) ALT_JDK_IMPORT_PATH=/opt/java/jdk$(JDK_VERSION)" @@ -741,6 +741,23 @@ include $(GAMMADIR)/make/$(OSNAME)/makefiles/universal.gmk endif endif +# Compatibility for transition to new naming +warn_jvmg_deprecated: + echo "Warning: The jvmg target has been replaced with debug" + echo "Warning: Please update your usage" + +jvmg: warn_jvmg_deprecated debug + +jvmg1: warn_jvmg_deprecated debug1 + +jvmgminimal1: warn_jvmg_deprecated debugminimal1 + +jvmgcore: warn_jvmg_deprecated debugcore + +jvmgzero: warn_jvmg_deprecated debugzero + +jvmgshark: warn_jvmg_deprecated debugshark + # JPRT rule to build this workspace include $(GAMMADIR)/make/jprt.gmk diff --git a/hotspot/make/bsd/Makefile b/hotspot/make/bsd/Makefile index 024aef9cba6..d9058c24e25 100644 --- a/hotspot/make/bsd/Makefile +++ b/hotspot/make/bsd/Makefile @@ -1,5 +1,5 @@ # -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -142,55 +142,43 @@ VARIANTARCH = $(subst i386,i486,$(ZERO_LIBARCH)) # # debug compiler2 __compiler2/debug # fastdebug compiler2 __compiler2/fastdebug -# jvmg compiler2 __compiler2/jvmg # optimized compiler2 __compiler2/optimized -# profiled compiler2 __compiler2/profiled # product compiler2 __compiler2/product # # debug1 compiler1 __compiler1/debug # fastdebug1 compiler1 __compiler1/fastdebug -# jvmg1 compiler1 __compiler1/jvmg # optimized1 compiler1 __compiler1/optimized -# profiled1 compiler1 __compiler1/profiled # product1 compiler1 __compiler1/product # # debugcore core __core/debug # fastdebugcore core __core/fastdebug -# jvmgcore core __core/jvmg # optimizedcore core __core/optimized -# profiledcore core __core/profiled # productcore core __core/product # # debugzero zero __zero/debug # fastdebugzero zero __zero/fastdebug -# jvmgzero zero __zero/jvmg # optimizedzero zero __zero/optimized -# profiledzero zero __zero/profiled # productzero zero __zero/product # # debugshark shark __shark/debug # fastdebugshark shark __shark/fastdebug -# jvmgshark shark __shark/jvmg # optimizedshark shark __shark/optimized -# profiledshark shark __shark/profiled # productshark shark __shark/product # # fastdebugminimal1 minimal1 __minimal1/fastdebug -# jvmgminimal1 minimal1 __minimal1/jvmg +# debugminimal1 minimal1 __minimal1/debug # productminimal1 minimal1 __minimal1/product # # What you get with each target: # -# debug* - "thin" libjvm - debug info linked into the gamma launcher +# debug* - debug compile with asserts enabled # fastdebug* - optimized compile, but with asserts enabled -# jvmg* - "fat" libjvm - debug info linked into libjvm.so # optimized* - optimized compile, no asserts -# profiled* - gprof # product* - the shippable thing: optimized compile, no asserts, -DPRODUCT # This target list needs to be coordinated with the usage message # in the build.sh script: -TARGETS = debug jvmg fastdebug optimized profiled product +TARGETS = debug fastdebug optimized product ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true) SUBDIR_DOCS = $(OSNAME)_$(VARIANTARCH)_docs @@ -354,15 +342,29 @@ docs: checks $(MAKE) -f $(GAMMADIR)/make/$(OSNAME)/makefiles/jvmti.make $(MFLAGS) $(BUILDTREE_VARS) JvmtiOutDir=$(SUBDIR_DOCS) jvmtidocs # Synonyms for win32-like targets. -compiler2: jvmg product +compiler2: debug product -compiler1: jvmg1 product1 +compiler1: debug1 product1 -core: jvmgcore productcore +core: debugcore productcore -zero: jvmgzero productzero +zero: debugzero productzero -shark: jvmgshark productshark +shark: debugshark productshark + +warn_jvmg_deprecated: + echo "Warning: The jvmg target has been replaced with debug" + echo "Warning: Please update your usage" + +jvmg: warn_jvmg_deprecated debug + +jvmg1: warn_jvmg_deprecated debug1 + +jvmgcore: warn_jvmg_deprecated debugcore + +jvmgzero: warn_jvmg_deprecated debugzero + +jvmgshark: warn_jvmg_deprecated debugshark clean_docs: rm -rf $(SUBDIR_DOCS) diff --git a/hotspot/make/bsd/makefiles/buildtree.make b/hotspot/make/bsd/makefiles/buildtree.make index 752e0febb76..9d0a2174c54 100644 --- a/hotspot/make/bsd/makefiles/buildtree.make +++ b/hotspot/make/bsd/makefiles/buildtree.make @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Usage: @@ -46,11 +46,11 @@ # Makefile - for "make foo" # flags.make - with macro settings # vm.make - to support making "$(MAKE) -v vm.make" in makefiles -# adlc.make - +# adlc.make - # jvmti.make - generate JVMTI bindings from the spec (JSR-163) # sa.make - generate SA jar file and natives # env.[ck]sh - environment settings -# +# # The makefiles are split this way so that "make foo" will run faster by not # having to read the dependency files for the vm. @@ -122,7 +122,7 @@ SIMPLE_DIRS = \ $(PLATFORM_DIR)/generated/jvmtifiles \ $(PLATFORM_DIR)/generated/dtracefiles -TARGETS = debug fastdebug jvmg optimized product profiled +TARGETS = debug fastdebug optimized product SUBMAKE_DIRS = $(addprefix $(PLATFORM_DIR)/,$(TARGETS)) # For dependencies and recursive makes. @@ -186,8 +186,8 @@ $(SIMPLE_DIRS): $(QUIETLY) mkdir -p $@ # Convenience macro which takes a source relative path, applies $(1) to the -# absolute path, and then replaces $(GAMMADIR) in the result with a -# literal "$(GAMMADIR)/" suitable for inclusion in a Makefile. +# absolute path, and then replaces $(GAMMADIR) in the result with a +# literal "$(GAMMADIR)/" suitable for inclusion in a Makefile. gamma-path=$(subst $(GAMMADIR),\$$(GAMMADIR),$(call $(1),$(HS_COMMON_SRC)/$(2))) # This bit is needed to enable local rebuilds. @@ -279,8 +279,6 @@ flags_vm.make: $(BUILDTREE_MAKE) ../shared_dirs.lst $(QUIETLY) ( \ $(BUILDTREE_COMMENT); \ echo; \ - [ "$(TARGET)" = profiled ] && \ - echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/optimized.make"; \ echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(TARGET).make"; \ ) > $@ @@ -381,7 +379,7 @@ jdkpath.sh: $(BUILDTREE_MAKE) $(QUIETLY) ( \ $(BUILDTREE_COMMENT); \ echo "JDK=${JAVA_HOME}"; \ - ) > $@ + ) > $@ FORCE: diff --git a/hotspot/make/bsd/makefiles/debug.make b/hotspot/make/bsd/makefiles/debug.make index 5849ed67eed..c14d974fbfb 100644 --- a/hotspot/make/bsd/makefiles/debug.make +++ b/hotspot/make/bsd/makefiles/debug.make @@ -1,5 +1,5 @@ # -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Sets make macros for making debug version of VM @@ -27,17 +27,16 @@ # Compiler specific DEBUG_CFLAGS are passed in from gcc.make, sparcWorks.make DEBUG_CFLAGS/DEFAULT= $(DEBUG_CFLAGS) DEBUG_CFLAGS/BYFILE = $(DEBUG_CFLAGS/$@)$(DEBUG_CFLAGS/DEFAULT$(DEBUG_CFLAGS/$@)) -CFLAGS += $(DEBUG_CFLAGS/BYFILE) + +# _NMT_NOINLINE_ informs NMT that no inlining by Compiler +CFLAGS += $(DEBUG_CFLAGS/BYFILE) -D_NMT_NOINLINE_ + +# Set the environment variable HOTSPARC_GENERIC to "true" +# to inhibit the effect of the previous line on CFLAGS. # Linker mapfile MAPFILE = $(GAMMADIR)/make/bsd/makefiles/mapfile-vers-debug -_JUNK_ := $(shell echo -e >&2 ""\ - "----------------------------------------------------------------------\n" \ - "WARNING: 'make debug' is deprecated. It will be removed in the future.\n" \ - "Please use 'make jvmg' to build debug JVM. \n" \ - "----------------------------------------------------------------------\n") - VERSION = debug -SYSDEFS += -DASSERT -DDEBUG +SYSDEFS += -DASSERT PICFLAGS = DEFAULT diff --git a/hotspot/make/bsd/makefiles/defs.make b/hotspot/make/bsd/makefiles/defs.make index 4c56c973892..14d3d4aa2ca 100644 --- a/hotspot/make/bsd/makefiles/defs.make +++ b/hotspot/make/bsd/makefiles/defs.make @@ -1,5 +1,5 @@ # -# Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # The common definitions for hotspot bsd builds. @@ -86,7 +86,7 @@ ifneq (,$(findstring $(ARCH), amd64 x86_64)) VM_PLATFORM = bsd_i486 HS_ARCH = x86 # We have to reset ARCH to i386 since SRCARCH relies on it - ARCH = i386 + ARCH = i386 endif endif @@ -146,9 +146,6 @@ else LIBRARY_SUFFIX=so endif -# FIXUP: The subdirectory for a debug build is NOT the same on all platforms -VM_DEBUG=jvmg - EXPORT_LIST += $(EXPORT_DOCS_DIR)/platform/jvmti/jvmti.html # client and server subdirectories have symbolic links to ../libjsig.so @@ -177,7 +174,7 @@ ifeq ($(JVM_VARIANT_MINIMAL1),true) else EXPORT_LIST += $(EXPORT_MINIMAL_DIR)/libjvm.debuginfo endif - endif + endif endif # Serviceability Binaries diff --git a/hotspot/make/bsd/makefiles/fastdebug.make b/hotspot/make/bsd/makefiles/fastdebug.make index c59310634c3..951891ed813 100644 --- a/hotspot/make/bsd/makefiles/fastdebug.make +++ b/hotspot/make/bsd/makefiles/fastdebug.make @@ -1,5 +1,5 @@ # -# Copyright (c) 1999, 2012 Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1999, 2013 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Sets make macros for making debug version of VM @@ -59,5 +59,5 @@ CFLAGS$(HOTSPARC_GENERIC) += $(OPT_CFLAGS/BYFILE) MAPFILE = $(GAMMADIR)/make/bsd/makefiles/mapfile-vers-debug VERSION = optimized -SYSDEFS += -DASSERT -DFASTDEBUG +SYSDEFS += -DASSERT PICFLAGS = DEFAULT diff --git a/hotspot/make/bsd/makefiles/jvmg.make b/hotspot/make/bsd/makefiles/jvmg.make deleted file mode 100644 index 52dbdb94b98..00000000000 --- a/hotspot/make/bsd/makefiles/jvmg.make +++ /dev/null @@ -1,42 +0,0 @@ -# -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# - -# Sets make macros for making debug version of VM - -# Compiler specific DEBUG_CFLAGS are passed in from gcc.make, sparcWorks.make -DEBUG_CFLAGS/DEFAULT= $(DEBUG_CFLAGS) -DEBUG_CFLAGS/BYFILE = $(DEBUG_CFLAGS/$@)$(DEBUG_CFLAGS/DEFAULT$(DEBUG_CFLAGS/$@)) - -# _NMT_NOINLINE_ informs NMT that no inlining by Compiler -CFLAGS += $(DEBUG_CFLAGS/BYFILE) -D_NMT_NOINLINE_ - -# Set the environment variable HOTSPARC_GENERIC to "true" -# to inhibit the effect of the previous line on CFLAGS. - -# Linker mapfile -MAPFILE = $(GAMMADIR)/make/bsd/makefiles/mapfile-vers-debug - -VERSION = debug -SYSDEFS += -DASSERT -DDEBUG -PICFLAGS = DEFAULT diff --git a/hotspot/make/bsd/makefiles/profiled.make b/hotspot/make/bsd/makefiles/profiled.make deleted file mode 100644 index fa5c9153b23..00000000000 --- a/hotspot/make/bsd/makefiles/profiled.make +++ /dev/null @@ -1,30 +0,0 @@ -# -# Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# - -# Sets make macros for making profiled version of Gamma VM -# (It is also optimized.) - -CFLAGS += -pg -AOUT_FLAGS += -pg -LDNOMAP = true diff --git a/hotspot/make/jprt.properties b/hotspot/make/jprt.properties index 8bf107758c9..af7f321b722 100644 --- a/hotspot/make/jprt.properties +++ b/hotspot/make/jprt.properties @@ -133,15 +133,15 @@ jprt.my.windows.x64=${jprt.my.windows.x64.${jprt.tools.default.release}} # Standard list of jprt build targets for this source tree jprt.build.targets.standard= \ - ${jprt.my.solaris.sparc}-{product|fastdebug|debug}, \ - ${jprt.my.solaris.sparcv9}-{product|fastdebug|debug}, \ - ${jprt.my.solaris.i586}-{product|fastdebug|debug}, \ - ${jprt.my.solaris.x64}-{product|fastdebug|debug}, \ - ${jprt.my.linux.i586}-{product|fastdebug|debug}, \ + ${jprt.my.solaris.sparc}-{product|fastdebug}, \ + ${jprt.my.solaris.sparcv9}-{product|fastdebug}, \ + ${jprt.my.solaris.i586}-{product|fastdebug}, \ + ${jprt.my.solaris.x64}-{product|fastdebug}, \ + ${jprt.my.linux.i586}-{product|fastdebug}, \ ${jprt.my.linux.x64}-{product|fastdebug}, \ - ${jprt.my.macosx.x64}-{product|fastdebug|debug}, \ - ${jprt.my.windows.i586}-{product|fastdebug|debug}, \ - ${jprt.my.windows.x64}-{product|fastdebug|debug}, \ + ${jprt.my.macosx.x64}-{product|fastdebug}, \ + ${jprt.my.windows.i586}-{product|fastdebug}, \ + ${jprt.my.windows.x64}-{product|fastdebug}, \ ${jprt.my.linux.armvh}-{product|fastdebug} jprt.build.targets.open= \ @@ -150,7 +150,7 @@ jprt.build.targets.open= \ ${jprt.my.linux.x64}-{productOpen} jprt.build.targets.embedded= \ - ${jprt.my.linux.i586}-{productEmb|fastdebugEmb|debugEmb}, \ + ${jprt.my.linux.i586}-{productEmb|fastdebugEmb}, \ ${jprt.my.linux.ppc}-{productEmb|fastdebugEmb}, \ ${jprt.my.linux.ppcv2}-{productEmb|fastdebugEmb}, \ ${jprt.my.linux.ppcsflt}-{productEmb|fastdebugEmb}, \ @@ -174,21 +174,18 @@ jprt.my.solaris.sparc.test.targets= \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-scimark, \ ${jprt.my.solaris.sparc}-product-{c1|c2}-runThese, \ ${jprt.my.solaris.sparc}-fastdebug-c1-runThese_Xshare, \ - ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCBasher_default, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCBasher_SerialGC, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCBasher_ParallelGC, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCBasher_ParNewGC, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCBasher_CMS, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCBasher_G1, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCBasher_ParOldGC, \ - ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCOld_default, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCOld_SerialGC, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCOld_ParallelGC, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCOld_ParNewGC, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCOld_CMS, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCOld_G1, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-GCOld_ParOldGC, \ - ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-jbb_default, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-c2-jbb_default_nontiered, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-jbb_SerialGC, \ ${jprt.my.solaris.sparc}-{product|fastdebug}-{c1|c2}-jbb_ParallelGC, \ @@ -201,21 +198,18 @@ jprt.my.solaris.sparcv9.test.targets= \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-jvm98_nontiered, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-scimark, \ ${jprt.my.solaris.sparcv9}-product-c2-runThese, \ - ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCBasher_default, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCBasher_SerialGC, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCBasher_ParallelGC, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCBasher_ParNewGC, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCBasher_CMS, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCBasher_G1, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCBasher_ParOldGC, \ - ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCOld_default, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCOld_SerialGC, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCOld_ParallelGC, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCOld_ParNewGC, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCOld_CMS, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCOld_G1, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-GCOld_ParOldGC, \ - ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-jbb_default, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-jbb_default_nontiered, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-jbb_SerialGC, \ ${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-jbb_ParallelGC, \ @@ -229,21 +223,18 @@ jprt.my.solaris.x64.test.targets= \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-scimark, \ ${jprt.my.solaris.x64}-product-c2-runThese, \ ${jprt.my.solaris.x64}-product-c2-runThese_Xcomp, \ - ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCBasher_default, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCBasher_SerialGC, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCBasher_ParallelGC, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCBasher_ParNewGC, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCBasher_CMS, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCBasher_G1, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCBasher_ParOldGC, \ - ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCOld_default, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCOld_SerialGC, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCOld_ParallelGC, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCOld_ParNewGC, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCOld_CMS, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCOld_G1, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-GCOld_ParOldGC, \ - ${jprt.my.solaris.x64}-{product|fastdebug}-c2-jbb_default, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-jbb_default_nontiered, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-jbb_SerialGC, \ ${jprt.my.solaris.x64}-{product|fastdebug}-c2-jbb_ParallelGC, \ @@ -258,28 +249,24 @@ jprt.my.solaris.i586.test.targets= \ ${jprt.my.solaris.i586}-product-{c1|c2}-runThese_Xcomp, \ ${jprt.my.solaris.i586}-fastdebug-c1-runThese_Xcomp, \ ${jprt.my.solaris.i586}-fastdebug-c1-runThese_Xshare, \ - ${jprt.my.solaris.i586}-product-c1-GCBasher_default, \ ${jprt.my.solaris.i586}-product-c1-GCBasher_SerialGC, \ ${jprt.my.solaris.i586}-product-c1-GCBasher_ParallelGC, \ ${jprt.my.solaris.i586}-product-c1-GCBasher_ParNewGC, \ ${jprt.my.solaris.i586}-product-c1-GCBasher_CMS, \ ${jprt.my.solaris.i586}-product-c1-GCBasher_G1, \ ${jprt.my.solaris.i586}-product-c1-GCBasher_ParOldGC, \ - ${jprt.my.solaris.i586}-fastdebug-c2-GCBasher_default, \ ${jprt.my.solaris.i586}-fastdebug-c2-GCBasher_SerialGC, \ ${jprt.my.solaris.i586}-fastdebug-c2-GCBasher_ParallelGC, \ ${jprt.my.solaris.i586}-fastdebug-c2-GCBasher_ParNewGC, \ ${jprt.my.solaris.i586}-fastdebug-c2-GCBasher_CMS, \ ${jprt.my.solaris.i586}-fastdebug-c2-GCBasher_G1, \ ${jprt.my.solaris.i586}-fastdebug-c2-GCBasher_ParOldGC, \ - ${jprt.my.solaris.i586}-product-c1-GCOld_default, \ ${jprt.my.solaris.i586}-product-c1-GCOld_SerialGC, \ ${jprt.my.solaris.i586}-product-c1-GCOld_ParallelGC, \ ${jprt.my.solaris.i586}-product-c1-GCOld_ParNewGC, \ ${jprt.my.solaris.i586}-product-c1-GCOld_CMS, \ ${jprt.my.solaris.i586}-product-c1-GCOld_G1, \ ${jprt.my.solaris.i586}-product-c1-GCOld_ParOldGC, \ - ${jprt.my.solaris.i586}-fastdebug-c2-jbb_default, \ ${jprt.my.solaris.i586}-fastdebug-c2-jbb_default_nontiered, \ ${jprt.my.solaris.i586}-fastdebug-c2-jbb_ParallelGC, \ ${jprt.my.solaris.i586}-fastdebug-c2-jbb_CMS, \ @@ -293,21 +280,19 @@ jprt.my.linux.i586.test.targets = \ ${jprt.my.linux.i586}-product-c1-runThese_Xcomp, \ ${jprt.my.linux.i586}-fastdebug-c1-runThese_Xshare, \ ${jprt.my.linux.i586}-fastdebug-c2-runThese_Xcomp, \ - ${jprt.my.linux.i586}-{product|fastdebug}-{c1|c2}-GCBasher_default, \ ${jprt.my.linux.i586}-{product|fastdebug}-{c1|c2}-GCBasher_SerialGC, \ ${jprt.my.linux.i586}-{product|fastdebug}-{c1|c2}-GCBasher_ParallelGC, \ ${jprt.my.linux.i586}-{product|fastdebug}-{c1|c2}-GCBasher_ParNewGC, \ ${jprt.my.linux.i586}-{product|fastdebug}-{c1|c2}-GCBasher_CMS, \ ${jprt.my.linux.i586}-{product|fastdebug}-{c1|c2}-GCBasher_G1, \ ${jprt.my.linux.i586}-{product|fastdebug}-{c1|c2}-GCBasher_ParOldGC, \ - ${jprt.my.linux.i586}-product-{c1|c2}-GCOld_default, \ ${jprt.my.linux.i586}-product-{c1|c2}-GCOld_SerialGC, \ ${jprt.my.linux.i586}-product-{c1|c2}-GCOld_ParallelGC, \ ${jprt.my.linux.i586}-product-{c1|c2}-GCOld_ParNewGC, \ ${jprt.my.linux.i586}-product-{c1|c2}-GCOld_CMS, \ ${jprt.my.linux.i586}-product-{c1|c2}-GCOld_G1, \ ${jprt.my.linux.i586}-product-{c1|c2}-GCOld_ParOldGC, \ - ${jprt.my.linux.i586}-{product|fastdebug}-c1-jbb_default, \ + ${jprt.my.linux.i586}-{product|fastdebug}-c1-jbb_SerialGC, \ ${jprt.my.linux.i586}-{product|fastdebug}-c2-jbb_default_nontiered, \ ${jprt.my.linux.i586}-{product|fastdebug}-c1-jbb_ParallelGC, \ ${jprt.my.linux.i586}-{product|fastdebug}-c1-jbb_CMS, \ @@ -318,21 +303,18 @@ jprt.my.linux.x64.test.targets = \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-jvm98, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-jvm98_nontiered, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-scimark, \ - ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCBasher_default, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCBasher_SerialGC, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCBasher_ParallelGC, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCBasher_ParNewGC, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCBasher_CMS, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCBasher_G1, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCBasher_ParOldGC, \ - ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCOld_default, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCOld_SerialGC, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCOld_ParallelGC, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCOld_ParNewGC, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCOld_CMS, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCOld_G1, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-GCOld_ParOldGC, \ - ${jprt.my.linux.x64}-{product|fastdebug}-c2-jbb_default, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-jbb_default_nontiered, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-jbb_ParallelGC, \ ${jprt.my.linux.x64}-{product|fastdebug}-c2-jbb_G1, \ @@ -342,21 +324,18 @@ jprt.my.macosx.x64.test.targets = \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-jvm98, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-jvm98_nontiered, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-scimark, \ - ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCBasher_default, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCBasher_SerialGC, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCBasher_ParallelGC, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCBasher_ParNewGC, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCBasher_CMS, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCBasher_G1, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCBasher_ParOldGC, \ - ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCOld_default, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCOld_SerialGC, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCOld_ParallelGC, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCOld_ParNewGC, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCOld_CMS, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCOld_G1, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-GCOld_ParOldGC, \ - ${jprt.my.macosx.x64}-{product|fastdebug}-c2-jbb_default, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-jbb_default_nontiered, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-jbb_ParallelGC, \ ${jprt.my.macosx.x64}-{product|fastdebug}-c2-jbb_G1, \ @@ -369,14 +348,12 @@ jprt.my.windows.i586.test.targets = \ ${jprt.my.windows.i586}-product-{c1|c2}-runThese, \ ${jprt.my.windows.i586}-product-{c1|c2}-runThese_Xcomp, \ ${jprt.my.windows.i586}-fastdebug-c1-runThese_Xshare, \ - ${jprt.my.windows.i586}-{product|fastdebug}-{c1|c2}-GCBasher_default, \ ${jprt.my.windows.i586}-{product|fastdebug}-{c1|c2}-GCBasher_SerialGC, \ ${jprt.my.windows.i586}-{product|fastdebug}-{c1|c2}-GCBasher_ParallelGC, \ ${jprt.my.windows.i586}-{product|fastdebug}-{c1|c2}-GCBasher_ParNewGC, \ ${jprt.my.windows.i586}-{product|fastdebug}-{c1|c2}-GCBasher_CMS, \ ${jprt.my.windows.i586}-{product|fastdebug}-{c1|c2}-GCBasher_G1, \ ${jprt.my.windows.i586}-{product|fastdebug}-{c1|c2}-GCBasher_ParOldGC, \ - ${jprt.my.windows.i586}-product-{c1|c2}-GCOld_default, \ ${jprt.my.windows.i586}-product-{c1|c2}-GCOld_SerialGC, \ ${jprt.my.windows.i586}-product-{c1|c2}-GCOld_ParallelGC, \ ${jprt.my.windows.i586}-product-{c1|c2}-GCOld_ParNewGC, \ @@ -396,14 +373,12 @@ jprt.my.windows.x64.test.targets = \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-scimark, \ ${jprt.my.windows.x64}-product-c2-runThese, \ ${jprt.my.windows.x64}-product-c2-runThese_Xcomp, \ - ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCBasher_default, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCBasher_SerialGC, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCBasher_ParallelGC, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCBasher_ParNewGC, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCBasher_CMS, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCBasher_G1, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCBasher_ParOldGC, \ - ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCOld_default, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCOld_SerialGC, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCOld_ParallelGC, \ ${jprt.my.windows.x64}-{product|fastdebug}-c2-GCOld_ParNewGC, \ @@ -419,7 +394,7 @@ jprt.my.windows.x64.test.targets = \ # Some basic "smoke" tests for OpenJDK builds jprt.test.targets.open = \ - ${jprt.my.solaris.x64}-{productOpen|debugOpen|fastdebugOpen}-c2-jvm98, \ + ${jprt.my.solaris.x64}-{productOpen|fastdebugOpen}-c2-jvm98, \ ${jprt.my.solaris.i586}-{productOpen|fastdebugOpen}-c2-jvm98, \ ${jprt.my.linux.x64}-{productOpen|fastdebugOpen}-c2-jvm98 @@ -520,5 +495,5 @@ jprt.make.rule.test.targets.jdk7u8=${jprt.make.rule.test.targets.jdk7} jprt.make.rule.test.targets=${jprt.make.rule.test.targets.${jprt.tools.default.release}} # 7155453: Work-around to prevent popups on OSX from blocking test completion -# but the work-around is added to all platforms to be consistent +# but the work-around is added to all platforms to be consistent jprt.jbb.options=-Djava.awt.headless=true diff --git a/hotspot/make/linux/Makefile b/hotspot/make/linux/Makefile index 04d0b8e5c64..0820c254612 100644 --- a/hotspot/make/linux/Makefile +++ b/hotspot/make/linux/Makefile @@ -1,5 +1,5 @@ # -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -142,55 +142,42 @@ VARIANTARCH = $(subst i386,i486,$(ZERO_LIBARCH)) # # debug compiler2 __compiler2/debug # fastdebug compiler2 __compiler2/fastdebug -# jvmg compiler2 __compiler2/jvmg # optimized compiler2 __compiler2/optimized -# profiled compiler2 __compiler2/profiled # product compiler2 __compiler2/product # # debug1 compiler1 __compiler1/debug # fastdebug1 compiler1 __compiler1/fastdebug -# jvmg1 compiler1 __compiler1/jvmg # optimized1 compiler1 __compiler1/optimized -# profiled1 compiler1 __compiler1/profiled # product1 compiler1 __compiler1/product # # debugcore core __core/debug # fastdebugcore core __core/fastdebug -# jvmgcore core __core/jvmg # optimizedcore core __core/optimized -# profiledcore core __core/profiled # productcore core __core/product # # debugzero zero __zero/debug # fastdebugzero zero __zero/fastdebug -# jvmgzero zero __zero/jvmg # optimizedzero zero __zero/optimized -# profiledzero zero __zero/profiled # productzero zero __zero/product # # debugshark shark __shark/debug # fastdebugshark shark __shark/fastdebug -# jvmgshark shark __shark/jvmg # optimizedshark shark __shark/optimized -# profiledshark shark __shark/profiled # productshark shark __shark/product # # fastdebugminimal1 minimal1 __minimal1/fastdebug -# jvmgminimal1 minimal1 __minimal1/jvmg # productminimal1 minimal1 __minimal1/product # # What you get with each target: # -# debug* - "thin" libjvm - debug info linked into the gamma launcher +# debug* - debug compile with asserts enabled # fastdebug* - optimized compile, but with asserts enabled -# jvmg* - "fat" libjvm - debug info linked into libjvm.so # optimized* - optimized compile, no asserts -# profiled* - gprof # product* - the shippable thing: optimized compile, no asserts, -DPRODUCT # This target list needs to be coordinated with the usage message # in the build.sh script: -TARGETS = debug jvmg fastdebug optimized profiled product +TARGETS = debug fastdebug optimized product ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true) SUBDIR_DOCS = $(OSNAME)_$(VARIANTARCH)_docs @@ -357,15 +344,29 @@ docs: checks $(MAKE) -f $(GAMMADIR)/make/$(OSNAME)/makefiles/jvmti.make $(MFLAGS) $(BUILDTREE_VARS) JvmtiOutDir=$(SUBDIR_DOCS) BUILD_FLAVOR=product jvmtidocs # Synonyms for win32-like targets. -compiler2: jvmg product +compiler2: debug product -compiler1: jvmg1 product1 +compiler1: debug1 product1 -core: jvmgcore productcore +core: debugcore productcore -zero: jvmgzero productzero +zero: debugzero productzero -shark: jvmgshark productshark +shark: debugshark productshark + +warn_jvmg_deprecated: + echo "Warning: The jvmg target has been replaced with debug" + echo "Warning: Please update your usage" + +jvmg: warn_jvmg_deprecated debug + +jvmg1: warn_jvmg_deprecated debug1 + +jvmgcore: warn_jvmg_deprecated debugcore + +jvmgzero: warn_jvmg_deprecated debugzero + +jvmgshark: warn_jvmg_deprecated debugshark clean_docs: rm -rf $(SUBDIR_DOCS) diff --git a/hotspot/make/linux/makefiles/buildtree.make b/hotspot/make/linux/makefiles/buildtree.make index f980dcdafe0..0b7c12001b3 100644 --- a/hotspot/make/linux/makefiles/buildtree.make +++ b/hotspot/make/linux/makefiles/buildtree.make @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Usage: @@ -46,11 +46,11 @@ # Makefile - for "make foo" # flags.make - with macro settings # vm.make - to support making "$(MAKE) -v vm.make" in makefiles -# adlc.make - +# adlc.make - # jvmti.make - generate JVMTI bindings from the spec (JSR-163) # sa.make - generate SA jar file and natives # env.[ck]sh - environment settings -# +# # The makefiles are split this way so that "make foo" will run faster by not # having to read the dependency files for the vm. @@ -117,7 +117,7 @@ SIMPLE_DIRS = \ $(PLATFORM_DIR)/generated/adfiles \ $(PLATFORM_DIR)/generated/jvmtifiles -TARGETS = debug fastdebug jvmg optimized product profiled +TARGETS = debug fastdebug optimized product SUBMAKE_DIRS = $(addprefix $(PLATFORM_DIR)/,$(TARGETS)) # For dependencies and recursive makes. @@ -179,8 +179,8 @@ $(SIMPLE_DIRS): $(QUIETLY) mkdir -p $@ # Convenience macro which takes a source relative path, applies $(1) to the -# absolute path, and then replaces $(GAMMADIR) in the result with a -# literal "$(GAMMADIR)/" suitable for inclusion in a Makefile. +# absolute path, and then replaces $(GAMMADIR) in the result with a +# literal "$(GAMMADIR)/" suitable for inclusion in a Makefile. gamma-path=$(subst $(GAMMADIR),\$$(GAMMADIR),$(call $(1),$(HS_COMMON_SRC)/$(2))) # This bit is needed to enable local rebuilds. @@ -284,8 +284,6 @@ flags_vm.make: $(BUILDTREE_MAKE) ../shared_dirs.lst $(QUIETLY) ( \ $(BUILDTREE_COMMENT); \ echo; \ - [ "$(TARGET)" = profiled ] && \ - echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/optimized.make"; \ echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(TARGET).make"; \ ) > $@ @@ -376,7 +374,7 @@ jdkpath.sh: $(BUILDTREE_MAKE) $(QUIETLY) ( \ $(BUILDTREE_COMMENT); \ echo "JDK=${JAVA_HOME}"; \ - ) > $@ + ) > $@ FORCE: diff --git a/hotspot/make/linux/makefiles/debug.make b/hotspot/make/linux/makefiles/debug.make index e51d4c192d2..7c57280a12c 100644 --- a/hotspot/make/linux/makefiles/debug.make +++ b/hotspot/make/linux/makefiles/debug.make @@ -1,5 +1,5 @@ # -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Sets make macros for making debug version of VM @@ -27,17 +27,16 @@ # Compiler specific DEBUG_CFLAGS are passed in from gcc.make, sparcWorks.make DEBUG_CFLAGS/DEFAULT= $(DEBUG_CFLAGS) DEBUG_CFLAGS/BYFILE = $(DEBUG_CFLAGS/$@)$(DEBUG_CFLAGS/DEFAULT$(DEBUG_CFLAGS/$@)) -CFLAGS += $(DEBUG_CFLAGS/BYFILE) + +# _NMT_NOINLINE_ informs NMT that no inlining by Compiler +CFLAGS += $(DEBUG_CFLAGS/BYFILE) -D_NMT_NOINLINE_ + +# Set the environment variable HOTSPARC_GENERIC to "true" +# to inhibit the effect of the previous line on CFLAGS. # Linker mapfile MAPFILE = $(GAMMADIR)/make/linux/makefiles/mapfile-vers-debug -_JUNK_ := $(shell echo -e >&2 ""\ - "----------------------------------------------------------------------\n" \ - "WARNING: 'make debug' is deprecated. It will be removed in the future.\n" \ - "Please use 'make jvmg' to build debug JVM. \n" \ - "----------------------------------------------------------------------\n") - VERSION = debug -SYSDEFS += -DASSERT -DDEBUG +SYSDEFS += -DASSERT PICFLAGS = DEFAULT diff --git a/hotspot/make/linux/makefiles/defs.make b/hotspot/make/linux/makefiles/defs.make index 9bdbdf226e6..778830814ac 100644 --- a/hotspot/make/linux/makefiles/defs.make +++ b/hotspot/make/linux/makefiles/defs.make @@ -1,5 +1,5 @@ # -# Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # The common definitions for hotspot linux builds. @@ -92,7 +92,7 @@ ifneq (,$(findstring $(ARCH), amd64 x86_64)) VM_PLATFORM = linux_i486 HS_ARCH = x86 # We have to reset ARCH to i686 since SRCARCH relies on it - ARCH = i686 + ARCH = i686 endif endif @@ -240,9 +240,6 @@ JDK_INCLUDE_SUBDIR=linux # Library suffix LIBRARY_SUFFIX=so -# FIXUP: The subdirectory for a debug build is NOT the same on all platforms -VM_DEBUG=jvmg - EXPORT_LIST += $(EXPORT_DOCS_DIR)/platform/jvmti/jvmti.html # client and server subdirectories have symbolic links to ../libjsig.so @@ -279,7 +276,7 @@ ifeq ($(JVM_VARIANT_CLIENT),true) else EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.debuginfo endif - endif + endif endif ifeq ($(JVM_VARIANT_MINIMAL1),true) @@ -292,15 +289,15 @@ ifeq ($(JVM_VARIANT_MINIMAL1),true) else EXPORT_LIST += $(EXPORT_MINIMAL_DIR)/libjvm.debuginfo endif - endif + endif endif # Serviceability Binaries # No SA Support for PPC, IA64, ARM or zero ADD_SA_BINARIES/x86 = $(EXPORT_JRE_LIB_ARCH_DIR)/libsaproc.$(LIBRARY_SUFFIX) \ - $(EXPORT_LIB_DIR)/sa-jdi.jar + $(EXPORT_LIB_DIR)/sa-jdi.jar ADD_SA_BINARIES/sparc = $(EXPORT_JRE_LIB_ARCH_DIR)/libsaproc.$(LIBRARY_SUFFIX) \ - $(EXPORT_LIB_DIR)/sa-jdi.jar + $(EXPORT_LIB_DIR)/sa-jdi.jar ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1) ifeq ($(ZIP_DEBUGINFO_FILES),1) ADD_SA_BINARIES/x86 += $(EXPORT_JRE_LIB_ARCH_DIR)/libsaproc.diz @@ -310,10 +307,10 @@ ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1) ADD_SA_BINARIES/sparc += $(EXPORT_JRE_LIB_ARCH_DIR)/libsaproc.debuginfo endif endif -ADD_SA_BINARIES/ppc = -ADD_SA_BINARIES/ia64 = -ADD_SA_BINARIES/arm = -ADD_SA_BINARIES/zero = +ADD_SA_BINARIES/ppc = +ADD_SA_BINARIES/ia64 = +ADD_SA_BINARIES/arm = +ADD_SA_BINARIES/zero = -include $(HS_ALT_MAKE)/linux/makefiles/defs.make diff --git a/hotspot/make/linux/makefiles/fastdebug.make b/hotspot/make/linux/makefiles/fastdebug.make index 86ffc36b7c2..abefd2b4ca0 100644 --- a/hotspot/make/linux/makefiles/fastdebug.make +++ b/hotspot/make/linux/makefiles/fastdebug.make @@ -1,5 +1,5 @@ # -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Sets make macros for making debug version of VM @@ -59,5 +59,5 @@ CFLAGS$(HOTSPARC_GENERIC) += $(OPT_CFLAGS/BYFILE) MAPFILE = $(GAMMADIR)/make/linux/makefiles/mapfile-vers-debug VERSION = optimized -SYSDEFS += -DASSERT -DFASTDEBUG +SYSDEFS += -DASSERT PICFLAGS = DEFAULT diff --git a/hotspot/make/linux/makefiles/jvmg.make b/hotspot/make/linux/makefiles/jvmg.make deleted file mode 100644 index 24047f7c358..00000000000 --- a/hotspot/make/linux/makefiles/jvmg.make +++ /dev/null @@ -1,42 +0,0 @@ -# -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# - -# Sets make macros for making debug version of VM - -# Compiler specific DEBUG_CFLAGS are passed in from gcc.make, sparcWorks.make -DEBUG_CFLAGS/DEFAULT= $(DEBUG_CFLAGS) -DEBUG_CFLAGS/BYFILE = $(DEBUG_CFLAGS/$@)$(DEBUG_CFLAGS/DEFAULT$(DEBUG_CFLAGS/$@)) - -# _NMT_NOINLINE_ informs NMT that no inlining by Compiler -CFLAGS += $(DEBUG_CFLAGS/BYFILE) -D_NMT_NOINLINE_ - -# Set the environment variable HOTSPARC_GENERIC to "true" -# to inhibit the effect of the previous line on CFLAGS. - -# Linker mapfile -MAPFILE = $(GAMMADIR)/make/linux/makefiles/mapfile-vers-debug - -VERSION = debug -SYSDEFS += -DASSERT -DDEBUG -PICFLAGS = DEFAULT diff --git a/hotspot/make/linux/makefiles/profiled.make b/hotspot/make/linux/makefiles/profiled.make deleted file mode 100644 index fa5c9153b23..00000000000 --- a/hotspot/make/linux/makefiles/profiled.make +++ /dev/null @@ -1,30 +0,0 @@ -# -# Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# - -# Sets make macros for making profiled version of Gamma VM -# (It is also optimized.) - -CFLAGS += -pg -AOUT_FLAGS += -pg -LDNOMAP = true diff --git a/hotspot/make/solaris/Makefile b/hotspot/make/solaris/Makefile index 7ae82d856f3..7ae2be418d3 100644 --- a/hotspot/make/solaris/Makefile +++ b/hotspot/make/solaris/Makefile @@ -120,37 +120,29 @@ endif # # debug compiler2 __compiler2/debug # fastdebug compiler2 __compiler2/fastdebug -# jvmg compiler2 __compiler2/jvmg # optimized compiler2 __compiler2/optimized -# profiled compiler2 __compiler2/profiled # product compiler2 __compiler2/product # # debug1 compiler1 __compiler1/debug # fastdebug1 compiler1 __compiler1/fastdebug -# jvmg1 compiler1 __compiler1/jvmg # optimized1 compiler1 __compiler1/optimized -# profiled1 compiler1 __compiler1/profiled # product1 compiler1 __compiler1/product # # debugcore core __core/debug # fastdebugcore core __core/fastdebug -# jvmgcore core __core/jvmg # optimizedcore core __core/optimized -# profiledcore core __core/profiled # productcore core __core/product # # What you get with each target: # -# debug* - "thin" libjvm - debug info linked into the gamma launcher +# debug* - debug compile with asserts enabled # fastdebug* - optimized compile, but with asserts enabled -# jvmg* - "fat" libjvm - debug info linked into libjvm.so # optimized* - optimized compile, no asserts -# profiled* - gprof # product* - the shippable thing: optimized compile, no asserts, -DPRODUCT # This target list needs to be coordinated with the usage message # in the build.sh script: -TARGETS = debug jvmg fastdebug optimized profiled product +TARGETS = debug fastdebug optimized product SUBDIR_DOCS = $(OSNAME)_$(BUILDARCH)_docs SUBDIRS_C1 = $(addprefix $(OSNAME)_$(BUILDARCH)_compiler1/,$(TARGETS)) @@ -267,11 +259,21 @@ docs: checks $(MAKE) -f $(GAMMADIR)/make/$(OSNAME)/makefiles/jvmti.make $(MFLAGS) $(BUILDTREE_VARS) JvmtiOutDir=$(SUBDIR_DOCS) BUILD_FLAVOR=product jvmtidocs # Synonyms for win32-like targets. -compiler2: jvmg product +compiler2: debug product -compiler1: jvmg1 product1 +compiler1: debug1 product1 -core: jvmgcore productcore +core: debugcore productcore + +warn_jvmg_deprecated: + echo "Warning: The jvmg target has been replaced with debug" + echo "Warning: Please update your usage" + +jvmg: warn_jvmg_deprecated debug + +jvmg1: warn_jvmg_deprecated debug1 + +jvmgcore: warn_jvmg_deprecated debugcore clean_docs: rm -rf $(SUBDIR_DOCS) diff --git a/hotspot/make/solaris/makefiles/buildtree.make b/hotspot/make/solaris/makefiles/buildtree.make index a3ab0b5e52c..989470f293f 100644 --- a/hotspot/make/solaris/makefiles/buildtree.make +++ b/hotspot/make/solaris/makefiles/buildtree.make @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Usage: @@ -46,11 +46,11 @@ # Makefile - for "make foo" # flags.make - with macro settings # vm.make - to support making "$(MAKE) -v vm.make" in makefiles -# adlc.make - +# adlc.make - # jvmti.make - generate JVMTI bindings from the spec (JSR-163) # sa.make - generate SA jar file and natives # env.[ck]sh - environment settings -# +# # The makefiles are split this way so that "make foo" will run faster by not # having to read the dependency files for the vm. @@ -69,7 +69,7 @@ PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH).gcc GCC_LIB = /usr/local/lib else PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH) -GCC_LIB = +GCC_LIB = endif ifdef FORCE_TIERED @@ -110,7 +110,7 @@ SIMPLE_DIRS = \ $(PLATFORM_DIR)/generated/adfiles \ $(PLATFORM_DIR)/generated/jvmtifiles -TARGETS = debug fastdebug jvmg optimized product profiled +TARGETS = debug fastdebug optimized product SUBMAKE_DIRS = $(addprefix $(PLATFORM_DIR)/,$(TARGETS)) # For dependencies and recursive makes. @@ -153,7 +153,7 @@ ifndef OPENJDK endif endif -BUILDTREE_VARS += HOTSPOT_RELEASE_VERSION=$(HS_BUILD_VER) HOTSPOT_BUILD_VERSION= JRE_RELEASE_VERSION=$(JRE_RELEASE_VERSION) +BUILDTREE_VARS += HOTSPOT_RELEASE_VERSION=$(HS_BUILD_VER) HOTSPOT_BUILD_VERSION= JRE_RELEASE_VERSION=$(JRE_RELEASE_VERSION) BUILDTREE = \ $(MAKE) -f $(BUILDTREE_MAKE) $(BUILDTREE_TARGETS) $(BUILDTREE_VARS) @@ -172,8 +172,8 @@ $(SIMPLE_DIRS): $(QUIETLY) mkdir -p $@ # Convenience macro which takes a source relative path, applies $(1) to the -# absolute path, and then replaces $(GAMMADIR) in the result with a -# literal "$(GAMMADIR)/" suitable for inclusion in a Makefile. +# absolute path, and then replaces $(GAMMADIR) in the result with a +# literal "$(GAMMADIR)/" suitable for inclusion in a Makefile. gamma-path=$(subst $(GAMMADIR),\$$(GAMMADIR),$(call $(1),$(HS_COMMON_SRC)/$(2))) # This bit is needed to enable local rebuilds. @@ -274,8 +274,6 @@ flags_vm.make: $(BUILDTREE_MAKE) ../shared_dirs.lst $(QUIETLY) ( \ $(BUILDTREE_COMMENT); \ echo; \ - [ "$(TARGET)" = profiled ] && \ - echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/optimized.make"; \ echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(TARGET).make"; \ ) > $@ @@ -366,7 +364,7 @@ jdkpath.sh: $(BUILDTREE_MAKE) $(QUIETLY) ( \ $(BUILDTREE_COMMENT); \ echo "JDK=${JAVA_HOME}"; \ - ) > $@ + ) > $@ FORCE: diff --git a/hotspot/make/solaris/makefiles/debug.make b/hotspot/make/solaris/makefiles/debug.make index 602c07dc366..3fba8e1239d 100644 --- a/hotspot/make/solaris/makefiles/debug.make +++ b/hotspot/make/solaris/makefiles/debug.make @@ -1,5 +1,5 @@ # -# Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Sets make macros for making debug version of VM @@ -37,22 +37,20 @@ ifeq ($(COMPILER_REV_NUMERIC),508) endif endif -CFLAGS += $(DEBUG_CFLAGS/BYFILE) +# _NMT_NOINLINE_ informs NMT that no inlining by Compiler +CFLAGS += $(DEBUG_CFLAGS/BYFILE) -D_NMT_NOINLINE_ + +# Set the environment variable HOTSPARC_GENERIC to "true" +# to inhibit the effect of the previous line on CFLAGS. # Linker mapfiles MAPFILE = $(GAMMADIR)/make/solaris/makefiles/mapfile-vers \ $(GAMMADIR)/make/solaris/makefiles/mapfile-vers-debug -# This mapfile is only needed when compiling with dtrace support, +# This mapfile is only needed when compiling with dtrace support, # and mustn't be otherwise. MAPFILE_DTRACE = $(GAMMADIR)/make/solaris/makefiles/mapfile-vers-$(TYPE) -_JUNK_ := $(shell echo >&2 ""\ - "-------------------------------------------------------------------------\n" \ - "WARNING: 'gnumake debug' is deprecated. It will be removed in the future.\n" \ - "Please use 'gnumake jvmg' to build debug JVM. \n" \ - "-------------------------------------------------------------------------\n") - VERSION = debug -SYSDEFS += -DASSERT -DDEBUG +SYSDEFS += -DASSERT PICFLAGS = DEFAULT diff --git a/hotspot/make/solaris/makefiles/defs.make b/hotspot/make/solaris/makefiles/defs.make index 14d0aced5a1..74ca7f70e2a 100644 --- a/hotspot/make/solaris/makefiles/defs.make +++ b/hotspot/make/solaris/makefiles/defs.make @@ -1,5 +1,5 @@ # -# Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # The common definitions for hotspot solaris builds. @@ -172,9 +172,6 @@ JDK_INCLUDE_SUBDIR=solaris # Library suffix LIBRARY_SUFFIX=so -# FIXUP: The subdirectory for a debug build is NOT the same on all platforms -VM_DEBUG=jvmg - EXPORT_LIST += $(EXPORT_DOCS_DIR)/platform/jvmti/jvmti.html # client and server subdirectories have symbolic links to ../libjsig.$(LIBRARY_SUFFIX) @@ -221,8 +218,8 @@ ifeq ($(JVM_VARIANT_SERVER),true) endif ifeq ($(JVM_VARIANT_CLIENT),true) EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt - EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX) - EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_db.$(LIBRARY_SUFFIX) + EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX) + EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_db.$(LIBRARY_SUFFIX) EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_dtrace.$(LIBRARY_SUFFIX) ifeq ($(ARCH_DATA_MODEL),32) EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_db.$(LIBRARY_SUFFIX) @@ -257,4 +254,4 @@ ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1) EXPORT_LIST += $(EXPORT_JRE_LIB_ARCH_DIR)/libsaproc.debuginfo endif endif -EXPORT_LIST += $(EXPORT_LIB_DIR)/sa-jdi.jar +EXPORT_LIST += $(EXPORT_LIB_DIR)/sa-jdi.jar diff --git a/hotspot/make/solaris/makefiles/fastdebug.make b/hotspot/make/solaris/makefiles/fastdebug.make index fdafd773bd3..3719c3edbda 100644 --- a/hotspot/make/solaris/makefiles/fastdebug.make +++ b/hotspot/make/solaris/makefiles/fastdebug.make @@ -1,5 +1,5 @@ # -# Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Sets make macros for making debug version of VM @@ -118,10 +118,10 @@ CFLAGS += $(DEBUG_CFLAGS/BYFILE) MAPFILE = $(GAMMADIR)/make/solaris/makefiles/mapfile-vers \ $(GAMMADIR)/make/solaris/makefiles/mapfile-vers-debug -# This mapfile is only needed when compiling with dtrace support, +# This mapfile is only needed when compiling with dtrace support, # and mustn't be otherwise. MAPFILE_DTRACE = $(GAMMADIR)/make/solaris/makefiles/mapfile-vers-$(TYPE) VERSION = optimized -SYSDEFS += -DASSERT -DFASTDEBUG -DCHECK_UNHANDLED_OOPS +SYSDEFS += -DASSERT -DCHECK_UNHANDLED_OOPS PICFLAGS = DEFAULT diff --git a/hotspot/make/solaris/makefiles/jvmg.make b/hotspot/make/solaris/makefiles/jvmg.make deleted file mode 100644 index c9102393c8f..00000000000 --- a/hotspot/make/solaris/makefiles/jvmg.make +++ /dev/null @@ -1,56 +0,0 @@ -# -# Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# - -# Sets make macros for making debug version of VM - -# Compiler specific DEBUG_CFLAGS are passed in from gcc.make, sparcWorks.make -DEBUG_CFLAGS/DEFAULT= $(DEBUG_CFLAGS) -DEBUG_CFLAGS/BYFILE = $(DEBUG_CFLAGS/$@)$(DEBUG_CFLAGS/DEFAULT$(DEBUG_CFLAGS/$@)) - -ifeq ("${Platform_compiler}", "sparcWorks") - -ifeq ($(COMPILER_REV_NUMERIC),508) - # SS11 SEGV when compiling with -g and -xarch=v8, using different backend - DEBUG_CFLAGS/compileBroker.o = $(DEBUG_CFLAGS) -xO0 - DEBUG_CFLAGS/jvmtiTagMap.o = $(DEBUG_CFLAGS) -xO0 -endif -endif - -# _NMT_NOINLINE_ informs NMT that no inlining by Compiler -CFLAGS += $(DEBUG_CFLAGS/BYFILE) -D_NMT_NOINLINE_ - -# Set the environment variable HOTSPARC_GENERIC to "true" -# to inhibit the effect of the previous line on CFLAGS. - -# Linker mapfiles -MAPFILE = $(GAMMADIR)/make/solaris/makefiles/mapfile-vers \ - $(GAMMADIR)/make/solaris/makefiles/mapfile-vers-debug - -# This mapfile is only needed when compiling with dtrace support, -# and mustn't be otherwise. -MAPFILE_DTRACE = $(GAMMADIR)/make/solaris/makefiles/mapfile-vers-$(TYPE) - -VERSION = debug -SYSDEFS += -DASSERT -DDEBUG -PICFLAGS = DEFAULT diff --git a/hotspot/make/solaris/makefiles/profiled.make b/hotspot/make/solaris/makefiles/profiled.make deleted file mode 100644 index cbbdb03bcdb..00000000000 --- a/hotspot/make/solaris/makefiles/profiled.make +++ /dev/null @@ -1,44 +0,0 @@ -# -# Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# - -# Sets make macros for making profiled version of Gamma VM -# (It is also optimized.) - -CFLAGS += -pg - -# On x86 Solaris 2.6, 7, and 8 if LD_LIBRARY_PATH has /usr/lib in it then -# adlc linked with -pg puts out empty header files. To avoid linking adlc -# with -pg the profile flag is split out separately and used in rules.make - -PROF_AOUT_FLAGS += -pg - -# To do a profiled build of the product, such as for generating the -# reordering file, set PROFILE_PRODUCT. Otherwise the reordering file will -# contain references to functions which are not defined in the PRODUCT build. - -ifdef PROFILE_PRODUCT - SYSDEFS += -DPRODUCT -endif - -LDNOMAP = true diff --git a/hotspot/make/windows/build.make b/hotspot/make/windows/build.make index e2f50542523..c072a170135 100644 --- a/hotspot/make/windows/build.make +++ b/hotspot/make/windows/build.make @@ -1,5 +1,5 @@ # -# Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -235,18 +235,14 @@ product release optimized: checks $(variantDir) $(variantDir)\local.make sanity cd $(variantDir) nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=product ARCH=$(ARCH) -# The debug or jvmg (all the same thing) is an optional build -debug jvmg: checks $(variantDir) $(variantDir)\local.make sanity +# The debug build is an optional build +debug: checks $(variantDir) $(variantDir)\local.make sanity cd $(variantDir) nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=debug ARCH=$(ARCH) fastdebug: checks $(variantDir) $(variantDir)\local.make sanity cd $(variantDir) nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=fastdebug ARCH=$(ARCH) -develop: checks $(variantDir) $(variantDir)\local.make sanity - cd $(variantDir) - nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=product DEVELOP=1 ARCH=$(ARCH) - # target to create just the directory structure tree: checks $(variantDir) $(variantDir)\local.make sanity mkdir $(variantDir)\product diff --git a/hotspot/make/windows/makefiles/defs.make b/hotspot/make/windows/makefiles/defs.make index ca1f327be75..4bee0afa8b0 100644 --- a/hotspot/make/windows/makefiles/defs.make +++ b/hotspot/make/windows/makefiles/defs.make @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # The common definitions for hotspot windows builds. @@ -209,8 +209,6 @@ endif ifneq (,$(findstring MINGW,$(SYSTEM_UNAME))) USING_MINGW=true endif -# FIXUP: The subdirectory for a debug build is NOT the same on all platforms -VM_DEBUG=debug # Windows wants particular paths due to nmake (must be after macros defined) # It is important that gnumake invokes nmake with C:\\...\\ formated @@ -292,7 +290,7 @@ ifeq ($(BUILD_WIN_SA), 1) MAKE_ARGS += BUILD_WIN_SA=1 endif -# Propagate compiler and tools paths from configure to nmake. +# Propagate compiler and tools paths from configure to nmake. # Need to make sure they contain \\ and not /. ifneq ($(SPEC),) ifeq ($(USING_CYGWIN), true) diff --git a/hotspot/make/windows/makefiles/vm.make b/hotspot/make/windows/makefiles/vm.make index bd02d42fa4f..9e7c64b8f33 100644 --- a/hotspot/make/windows/makefiles/vm.make +++ b/hotspot/make/windows/makefiles/vm.make @@ -31,11 +31,7 @@ COMMONSRC=$(WorkSpace)\src ALTSRC=$(WorkSpace)\src\closed !ifdef RELEASE -!ifdef DEVELOP -CXX_FLAGS=$(CXX_FLAGS) /D "DEBUG" -!else CXX_FLAGS=$(CXX_FLAGS) /D "PRODUCT" -!endif !else CXX_FLAGS=$(CXX_FLAGS) /D "ASSERT" !endif @@ -186,7 +182,7 @@ VM_PATH={$(VM_PATH)} # Special case files not using precompiled header files. -c1_RInfo_$(Platform_arch).obj: $(WorkSpace)\src\cpu\$(Platform_arch)\vm\c1_RInfo_$(Platform_arch).cpp +c1_RInfo_$(Platform_arch).obj: $(WorkSpace)\src\cpu\$(Platform_arch)\vm\c1_RInfo_$(Platform_arch).cpp $(CXX) $(CXX_FLAGS) $(CXX_DONT_USE_PCH) /c $(WorkSpace)\src\cpu\$(Platform_arch)\vm\c1_RInfo_$(Platform_arch).cpp os_windows.obj: $(WorkSpace)\src\os\windows\vm\os_windows.cpp diff --git a/hotspot/make/windows/projectfiles/compiler2/ADLCompiler.dsp b/hotspot/make/windows/projectfiles/compiler2/ADLCompiler.dsp index a93b8c46eca..557cce42c76 100644 --- a/hotspot/make/windows/projectfiles/compiler2/ADLCompiler.dsp +++ b/hotspot/make/windows/projectfiles/compiler2/ADLCompiler.dsp @@ -67,7 +67,7 @@ LINK32=link.exe # PROP Ignore_Export_Lib 0 # PROP Target_Dir "" # ADD BASE CPP /nologo /W3 /Gm /GX /Zi /Od /D "WIN32" /D "_CONSOLE" /D "_MBCS" /YX /FD /c -# ADD CPP /nologo /ML /W3 /WX /Gm /GX /Zi /Od /I "." /I "$(HotSpotWorkSpace)\src\share\vm\opto" /I "$(HotSpotWorkSpace)\src\share\vm\prims" /I "$(HotSpotWorkSpace)\src\share\vm\lookup" /I "$(HotSpotWorkSpace)\src\share\vm\interpreter" /I "$(HotSpotWorkSpace)\src\share\vm\asm" /I "$(HotSpotWorkSpace)\src\share\vm\compiler" /I "$(HotSpotWorkSpace)\src\share\vm\utilities" /I "$(HotSpotWorkSpace)\src\share\vm\code" /I "$(HotSpotWorkSpace)\src\share\vm\oops" /I "$(HotSpotWorkSpace)\src\share\vm\runtime" /I "$(HotSpotWorkSpace)\src\share\vm\memory" /I "$(HotSpotWorkSpace)\src\share\vm\libadt" /I "$(HotSpotWorkSpace)\src\cpu\i486\vm" /I "$(HotSpotWorkSpace)\src\os\win32\vm" /D "WIN32" /D "DEBUG" /D "_WINDOWS" /D "ASSERT" /Fr /FD /c +# ADD CPP /nologo /ML /W3 /WX /Gm /GX /Zi /Od /I "." /I "$(HotSpotWorkSpace)\src\share\vm\opto" /I "$(HotSpotWorkSpace)\src\share\vm\prims" /I "$(HotSpotWorkSpace)\src\share\vm\lookup" /I "$(HotSpotWorkSpace)\src\share\vm\interpreter" /I "$(HotSpotWorkSpace)\src\share\vm\asm" /I "$(HotSpotWorkSpace)\src\share\vm\compiler" /I "$(HotSpotWorkSpace)\src\share\vm\utilities" /I "$(HotSpotWorkSpace)\src\share\vm\code" /I "$(HotSpotWorkSpace)\src\share\vm\oops" /I "$(HotSpotWorkSpace)\src\share\vm\runtime" /I "$(HotSpotWorkSpace)\src\share\vm\memory" /I "$(HotSpotWorkSpace)\src\share\vm\libadt" /I "$(HotSpotWorkSpace)\src\cpu\i486\vm" /I "$(HotSpotWorkSpace)\src\os\win32\vm" /D "WIN32" /D "_WINDOWS" /D "ASSERT" /Fr /FD /c # ADD BASE RSC /l 0x409 # ADD RSC /l 0x409 BSC32=bscmake.exe diff --git a/hotspot/make/windows/projectfiles/tiered/ADLCompiler.dsp b/hotspot/make/windows/projectfiles/tiered/ADLCompiler.dsp index a93b8c46eca..557cce42c76 100644 --- a/hotspot/make/windows/projectfiles/tiered/ADLCompiler.dsp +++ b/hotspot/make/windows/projectfiles/tiered/ADLCompiler.dsp @@ -67,7 +67,7 @@ LINK32=link.exe # PROP Ignore_Export_Lib 0 # PROP Target_Dir "" # ADD BASE CPP /nologo /W3 /Gm /GX /Zi /Od /D "WIN32" /D "_CONSOLE" /D "_MBCS" /YX /FD /c -# ADD CPP /nologo /ML /W3 /WX /Gm /GX /Zi /Od /I "." /I "$(HotSpotWorkSpace)\src\share\vm\opto" /I "$(HotSpotWorkSpace)\src\share\vm\prims" /I "$(HotSpotWorkSpace)\src\share\vm\lookup" /I "$(HotSpotWorkSpace)\src\share\vm\interpreter" /I "$(HotSpotWorkSpace)\src\share\vm\asm" /I "$(HotSpotWorkSpace)\src\share\vm\compiler" /I "$(HotSpotWorkSpace)\src\share\vm\utilities" /I "$(HotSpotWorkSpace)\src\share\vm\code" /I "$(HotSpotWorkSpace)\src\share\vm\oops" /I "$(HotSpotWorkSpace)\src\share\vm\runtime" /I "$(HotSpotWorkSpace)\src\share\vm\memory" /I "$(HotSpotWorkSpace)\src\share\vm\libadt" /I "$(HotSpotWorkSpace)\src\cpu\i486\vm" /I "$(HotSpotWorkSpace)\src\os\win32\vm" /D "WIN32" /D "DEBUG" /D "_WINDOWS" /D "ASSERT" /Fr /FD /c +# ADD CPP /nologo /ML /W3 /WX /Gm /GX /Zi /Od /I "." /I "$(HotSpotWorkSpace)\src\share\vm\opto" /I "$(HotSpotWorkSpace)\src\share\vm\prims" /I "$(HotSpotWorkSpace)\src\share\vm\lookup" /I "$(HotSpotWorkSpace)\src\share\vm\interpreter" /I "$(HotSpotWorkSpace)\src\share\vm\asm" /I "$(HotSpotWorkSpace)\src\share\vm\compiler" /I "$(HotSpotWorkSpace)\src\share\vm\utilities" /I "$(HotSpotWorkSpace)\src\share\vm\code" /I "$(HotSpotWorkSpace)\src\share\vm\oops" /I "$(HotSpotWorkSpace)\src\share\vm\runtime" /I "$(HotSpotWorkSpace)\src\share\vm\memory" /I "$(HotSpotWorkSpace)\src\share\vm\libadt" /I "$(HotSpotWorkSpace)\src\cpu\i486\vm" /I "$(HotSpotWorkSpace)\src\os\win32\vm" /D "WIN32" /D "_WINDOWS" /D "ASSERT" /Fr /FD /c # ADD BASE RSC /l 0x409 # ADD RSC /l 0x409 BSC32=bscmake.exe diff --git a/hotspot/src/cpu/sparc/vm/frame_sparc.cpp b/hotspot/src/cpu/sparc/vm/frame_sparc.cpp index 1c368ffe84e..94cef1a9a25 100644 --- a/hotspot/src/cpu/sparc/vm/frame_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/frame_sparc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -304,7 +304,7 @@ bool frame::safe_for_sender(JavaThread *thread) { // The sender should positively be an nmethod or call_stub. On sparc we might in fact see something else. // The cause of this is because at a save instruction the O7 we get is a leftover from an earlier - // window use. So if a runtime stub creates two frames (common in fastdebug/jvmg) then we see the + // window use. So if a runtime stub creates two frames (common in fastdebug/debug) then we see the // stale pc. So if the sender blob is not something we'd expect we have little choice but to declare // the stack unwalkable. pd_get_top_frame_for_signal_handler tries to recover from this by unwinding // that initial frame and retrying. diff --git a/hotspot/src/os/bsd/dtrace/generateJvmOffsets.cpp b/hotspot/src/os/bsd/dtrace/generateJvmOffsets.cpp index a21245afdc1..21d979f3efb 100644 --- a/hotspot/src/os/bsd/dtrace/generateJvmOffsets.cpp +++ b/hotspot/src/os/bsd/dtrace/generateJvmOffsets.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -60,7 +60,7 @@ #define PR_MODEL_LP64 2 #ifdef COMPILER1 -#if defined(DEBUG) || defined(FASTDEBUG) +#ifdef ASSERT /* * To avoid the most part of potential link errors @@ -84,7 +84,7 @@ address StubRoutines::_call_stub_return_address = NULL; StubQueue* AbstractInterpreter::_code = NULL; -#endif /* defined(DEBUG) || defined(FASTDEBUG) */ +#endif /* ASSERT */ #endif /* COMPILER1 */ #define GEN_OFFS(Type,Name) \ diff --git a/hotspot/src/os/solaris/dtrace/generateJvmOffsets.cpp b/hotspot/src/os/solaris/dtrace/generateJvmOffsets.cpp index 1a269539695..3fb13e5e97c 100644 --- a/hotspot/src/os/solaris/dtrace/generateJvmOffsets.cpp +++ b/hotspot/src/os/solaris/dtrace/generateJvmOffsets.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -55,14 +55,14 @@ #include "utilities/accessFlags.hpp" #include "utilities/globalDefinitions.hpp" #ifdef COMPILER1 -#if defined(DEBUG) || defined(FASTDEBUG) +#ifdef ASSERT /* * To avoid the most part of potential link errors * we link this program with -z nodefs . * * But for 'debug1' and 'fastdebug1' we still have to provide - * a particular workaround for the following symbols bellow. + * a particular workaround for the following symbols below. * It will be good to find out a generic way in the future. */ @@ -79,7 +79,7 @@ address StubRoutines::_call_stub_return_address = NULL; StubQueue* AbstractInterpreter::_code = NULL; -#endif /* defined(DEBUG) || defined(FASTDEBUG) */ +#endif /* ASSERT */ #endif /* COMPILER1 */ #define GEN_OFFS(Type,Name) \ diff --git a/hotspot/src/os/windows/vm/os_windows.cpp b/hotspot/src/os/windows/vm/os_windows.cpp index 0a8034d3217..a9b8136d305 100644 --- a/hotspot/src/os/windows/vm/os_windows.cpp +++ b/hotspot/src/os/windows/vm/os_windows.cpp @@ -4238,9 +4238,6 @@ char * os::native_path(char *path) { path[3] = '\0'; } - #ifdef DEBUG - jio_fprintf(stderr, "sysNativePath: %s\n", path); - #endif DEBUG return path; } diff --git a/hotspot/src/share/tools/hsdis/Makefile b/hotspot/src/share/tools/hsdis/Makefile index 3cfdf57e6bd..2a48f9a81d8 100644 --- a/hotspot/src/share/tools/hsdis/Makefile +++ b/hotspot/src/share/tools/hsdis/Makefile @@ -1,5 +1,5 @@ # -# Copyright (c) 2008, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2008, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # # Single gnu makefile for solaris, linux and windows (windows requires cygwin and mingw) @@ -66,7 +66,7 @@ ARCH=i386 endif CC = $(MINGW)-gcc CONFIGURE_ARGS= --host=$(MINGW) --target=$(MINGW) -else #linux +else #linux CPU = $(shell uname -m) ARCH1=$(CPU:x86_64=amd64) ARCH=$(ARCH1:i686=i386) @@ -116,7 +116,6 @@ OUTFLAGS += -o $@ else #Windows OS = windows CC = gcc -#CPPFLAGS += /D"WIN32" /D"_WINDOWS" /D"DEBUG" /D"NDEBUG" CFLAGS += /nologo /MD /W3 /WX /O2 /Fo$(@:.dll=.obj) /Gi- CFLAGS += LIBARCH=\"$(LIBARCH)\" DLDFLAGS += /dll /subsystem:windows /incremental:no \ diff --git a/hotspot/src/share/vm/classfile/stackMapFrame.hpp b/hotspot/src/share/vm/classfile/stackMapFrame.hpp index bdeb956ba68..237accec0d4 100644 --- a/hotspot/src/share/vm/classfile/stackMapFrame.hpp +++ b/hotspot/src/share/vm/classfile/stackMapFrame.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -175,14 +175,14 @@ class StackMapFrame : public ResourceObj { ErrorContext* ctx, TRAPS) const; inline void set_mark() { -#ifdef DEBUG +#ifdef ASSERT // Put bogus type to indicate it's no longer valid. if (_stack_mark != -1) { for (int i = _stack_mark - 1; i >= _stack_size; --i) { _stack[i] = VerificationType::bogus_type(); } } -#endif // def DEBUG +#endif // def ASSERT _stack_mark = _stack_size; } diff --git a/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/concurrentMarkSweepGeneration.cpp b/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/concurrentMarkSweepGeneration.cpp index c609f10f620..70a26089437 100644 --- a/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/concurrentMarkSweepGeneration.cpp +++ b/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/concurrentMarkSweepGeneration.cpp @@ -6921,7 +6921,7 @@ size_t ScanMarkedObjectsAgainCarefullyClosure::do_object_careful_m( size = CompactibleFreeListSpace::adjustObjectSize( p->oop_iterate(_scanningClosure)); } - #ifdef DEBUG + #ifdef ASSERT size_t direct_size = CompactibleFreeListSpace::adjustObjectSize(p->size()); assert(size == direct_size, "Inconsistency in size"); @@ -6933,7 +6933,7 @@ size_t ScanMarkedObjectsAgainCarefullyClosure::do_object_careful_m( assert(_bitMap->isMarked(addr+size-1), "inconsistent Printezis mark"); } - #endif // DEBUG + #endif // ASSERT } else { // an unitialized object assert(_bitMap->isMarked(addr+1), "missing Printezis mark?"); @@ -7075,14 +7075,14 @@ bool ScanMarkedObjectsAgainClosure::do_object_bm(oop p, MemRegion mr) { HeapWord* addr = (HeapWord*)p; assert(_span.contains(addr), "we are scanning the CMS generation"); bool is_obj_array = false; - #ifdef DEBUG + #ifdef ASSERT if (!_parallel) { assert(_mark_stack->isEmpty(), "pre-condition (eager drainage)"); assert(_collector->overflow_list_is_empty(), "overflow list should be empty"); } - #endif // DEBUG + #endif // ASSERT if (_bit_map->isMarked(addr)) { // Obj arrays are precisely marked, non-arrays are not; // so we scan objArrays precisely and non-arrays in their @@ -7102,14 +7102,14 @@ bool ScanMarkedObjectsAgainClosure::do_object_bm(oop p, MemRegion mr) { } } } - #ifdef DEBUG + #ifdef ASSERT if (!_parallel) { assert(_mark_stack->isEmpty(), "post-condition (eager drainage)"); assert(_collector->overflow_list_is_empty(), "overflow list should be empty"); } - #endif // DEBUG + #endif // ASSERT return is_obj_array; } @@ -8320,7 +8320,7 @@ size_t SweepClosure::do_live_chunk(FreeChunk* fc) { assert(size == CompactibleFreeListSpace::adjustObjectSize(size), "alignment problem"); -#ifdef DEBUG +#ifdef ASSERT if (oop(addr)->klass_or_null() != NULL) { // Ignore mark word because we are running concurrent with mutators assert(oop(addr)->is_oop(true), "live block should be an oop"); diff --git a/hotspot/src/share/vm/memory/allocation.hpp b/hotspot/src/share/vm/memory/allocation.hpp index bc01b0135b0..dd9a13503d8 100644 --- a/hotspot/src/share/vm/memory/allocation.hpp +++ b/hotspot/src/share/vm/memory/allocation.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -178,7 +178,7 @@ const bool NMT_track_callsite = false; #endif // INCLUDE_NMT // debug build does not inline -#if defined(_DEBUG_) +#if defined(_NMT_NOINLINE_) #define CURRENT_PC (NMT_track_callsite ? os::get_caller_pc(1) : 0) #define CALLER_PC (NMT_track_callsite ? os::get_caller_pc(2) : 0) #define CALLER_CALLER_PC (NMT_track_callsite ? os::get_caller_pc(3) : 0) diff --git a/hotspot/src/share/vm/runtime/vmThread.cpp b/hotspot/src/share/vm/runtime/vmThread.cpp index 286d457c997..8cfc2700835 100644 --- a/hotspot/src/share/vm/runtime/vmThread.cpp +++ b/hotspot/src/share/vm/runtime/vmThread.cpp @@ -123,7 +123,7 @@ VM_Operation* VMOperationQueue::queue_drain(int prio) { _queue[prio]->set_next(_queue[prio]); _queue[prio]->set_prev(_queue[prio]); assert(queue_empty(prio), "drain corrupted queue"); -#ifdef DEBUG +#ifdef ASSERT int len = 0; VM_Operation* cur; for(cur = r; cur != NULL; cur=cur->next()) len++; From 25c31f374227f5f6f9cd0213af40e019c8073867 Mon Sep 17 00:00:00 2001 From: David Chase Date: Fri, 12 Apr 2013 19:14:47 -0700 Subject: [PATCH 08/50] 6443505: Ideal() function for CmpLTMask Repair wrong code generation, added new matching rule Reviewed-by: kvn, twisti --- hotspot/src/cpu/sparc/vm/sparc.ad | 21 ++- hotspot/src/cpu/x86/vm/x86_32.ad | 125 ++++++++++-------- hotspot/src/cpu/x86/vm/x86_64.ad | 62 ++++++--- hotspot/src/share/vm/opto/cfgnode.cpp | 9 +- .../test/compiler/6443505/Test6443505.java | 107 +++++++++++++++ 5 files changed, 241 insertions(+), 83 deletions(-) create mode 100644 hotspot/test/compiler/6443505/Test6443505.java diff --git a/hotspot/src/cpu/sparc/vm/sparc.ad b/hotspot/src/cpu/sparc/vm/sparc.ad index 96accce0256..4107392e6b4 100644 --- a/hotspot/src/cpu/sparc/vm/sparc.ad +++ b/hotspot/src/cpu/sparc/vm/sparc.ad @@ -1,5 +1,5 @@ // -// Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. +// Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. // DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. // // This code is free software; you can redistribute it and/or modify it @@ -8223,10 +8223,25 @@ instruct cadd_cmpLTMask( iRegI p, iRegI q, iRegI y, iRegI tmp, flagsReg ccr ) %{ format %{ "SUBcc $p,$q,$p\t! p' = p-q\n\t" "ADD $p,$y,$tmp\t! g3=p-q+y\n\t" "MOVlt $tmp,$p\t! p' < 0 ? p'+y : p'" %} - ins_encode( enc_cadd_cmpLTMask(p, q, y, tmp) ); - ins_pipe( cadd_cmpltmask ); + ins_encode(enc_cadd_cmpLTMask(p, q, y, tmp)); + ins_pipe(cadd_cmpltmask); %} +instruct and_cmpLTMask(iRegI p, iRegI q, iRegI y, flagsReg ccr) %{ + match(Set p (AndI (CmpLTMask p q) y)); + effect(KILL ccr); + ins_cost(DEFAULT_COST*3); + + format %{ "CMP $p,$q\n\t" + "MOV $y,$p\n\t" + "MOVge G0,$p" %} + ins_encode %{ + __ cmp($p$$Register, $q$$Register); + __ mov($y$$Register, $p$$Register); + __ movcc(Assembler::greaterEqual, false, Assembler::icc, G0, $p$$Register); + %} + ins_pipe(ialu_reg_reg_ialu); +%} //----------------------------------------------------------------- // Direct raw moves between float and general registers using VIS3. diff --git a/hotspot/src/cpu/x86/vm/x86_32.ad b/hotspot/src/cpu/x86/vm/x86_32.ad index 67f33d3ba27..4560fb2c526 100644 --- a/hotspot/src/cpu/x86/vm/x86_32.ad +++ b/hotspot/src/cpu/x86/vm/x86_32.ad @@ -1,5 +1,5 @@ // -// Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. +// Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. // DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. // // This code is free software; you can redistribute it and/or modify it @@ -2317,30 +2317,6 @@ encode %{ emit_rm(cbuf, 0x3, $p$$reg, tmpReg); %} - enc_class enc_cmpLTP_mem(rRegI p, rRegI q, memory mem, eCXRegI tmp) %{ // cadd_cmpLT - int tmpReg = $tmp$$reg; - - // SUB $p,$q - emit_opcode(cbuf,0x2B); - emit_rm(cbuf, 0x3, $p$$reg, $q$$reg); - // SBB $tmp,$tmp - emit_opcode(cbuf,0x1B); - emit_rm(cbuf, 0x3, tmpReg, tmpReg); - // AND $tmp,$y - cbuf.set_insts_mark(); // Mark start of opcode for reloc info in mem operand - emit_opcode(cbuf,0x23); - int reg_encoding = tmpReg; - int base = $mem$$base; - int index = $mem$$index; - int scale = $mem$$scale; - int displace = $mem$$disp; - relocInfo::relocType disp_reloc = $mem->disp_reloc(); - encode_RegMem(cbuf, reg_encoding, base, index, scale, displace, disp_reloc); - // ADD $p,$tmp - emit_opcode(cbuf,0x03); - emit_rm(cbuf, 0x3, $p$$reg, tmpReg); - %} - enc_class shift_left_long( eRegL dst, eCXRegI shift ) %{ // TEST shift,32 emit_opcode(cbuf,0xF7); @@ -8922,9 +8898,9 @@ instruct convP2B( rRegI dst, eRegP src, eFlagsReg cr ) %{ %} %} -instruct cmpLTMask( eCXRegI dst, ncxRegI p, ncxRegI q, eFlagsReg cr ) %{ +instruct cmpLTMask(eCXRegI dst, ncxRegI p, ncxRegI q, eFlagsReg cr) %{ match(Set dst (CmpLTMask p q)); - effect( KILL cr ); + effect(KILL cr); ins_cost(400); // SETlt can only use low byte of EAX,EBX, ECX, or EDX as destination @@ -8932,50 +8908,83 @@ instruct cmpLTMask( eCXRegI dst, ncxRegI p, ncxRegI q, eFlagsReg cr ) %{ "CMP $p,$q\n\t" "SETlt $dst\n\t" "NEG $dst" %} - ins_encode( OpcRegReg(0x33,dst,dst), - OpcRegReg(0x3B,p,q), - setLT_reg(dst), neg_reg(dst) ); - ins_pipe( pipe_slow ); + ins_encode %{ + Register Rp = $p$$Register; + Register Rq = $q$$Register; + Register Rd = $dst$$Register; + Label done; + __ xorl(Rd, Rd); + __ cmpl(Rp, Rq); + __ setb(Assembler::less, Rd); + __ negl(Rd); + %} + + ins_pipe(pipe_slow); %} -instruct cmpLTMask0( rRegI dst, immI0 zero, eFlagsReg cr ) %{ +instruct cmpLTMask0(rRegI dst, immI0 zero, eFlagsReg cr) %{ match(Set dst (CmpLTMask dst zero)); - effect( DEF dst, KILL cr ); + effect(DEF dst, KILL cr); ins_cost(100); - format %{ "SAR $dst,31" %} - opcode(0xC1, 0x7); /* C1 /7 ib */ - ins_encode( RegOpcImm( dst, 0x1F ) ); - ins_pipe( ialu_reg ); + format %{ "SAR $dst,31\t# cmpLTMask0" %} + ins_encode %{ + __ sarl($dst$$Register, 31); + %} + ins_pipe(ialu_reg); %} - -instruct cadd_cmpLTMask( ncxRegI p, ncxRegI q, ncxRegI y, eCXRegI tmp, eFlagsReg cr ) %{ +/* better to save a register than avoid a branch */ +instruct cadd_cmpLTMask(rRegI p, rRegI q, rRegI y, eFlagsReg cr) %{ match(Set p (AddI (AndI (CmpLTMask p q) y) (SubI p q))); - effect( KILL tmp, KILL cr ); + effect(KILL cr); ins_cost(400); - // annoyingly, $tmp has no edges so you cant ask for it in - // any format or encoding - format %{ "SUB $p,$q\n\t" - "SBB ECX,ECX\n\t" - "AND ECX,$y\n\t" - "ADD $p,ECX" %} - ins_encode( enc_cmpLTP(p,q,y,tmp) ); - ins_pipe( pipe_cmplt ); + format %{ "SUB $p,$q\t# cadd_cmpLTMask\n\t" + "JGE done\n\t" + "ADD $p,$y\n" + "done: " %} + ins_encode %{ + Register Rp = $p$$Register; + Register Rq = $q$$Register; + Register Ry = $y$$Register; + Label done; + __ subl(Rp, Rq); + __ jccb(Assembler::greaterEqual, done); + __ addl(Rp, Ry); + __ bind(done); + %} + + ins_pipe(pipe_cmplt); +%} + +/* better to save a register than avoid a branch */ +instruct and_cmpLTMask(rRegI p, rRegI q, rRegI y, eFlagsReg cr) %{ + match(Set y (AndI (CmpLTMask p q) y)); + effect(KILL cr); + + ins_cost(300); + + format %{ "CMPL $p, $q\t# and_cmpLTMask\n\t" + "JLT done\n\t" + "XORL $y, $y\n" + "done: " %} + ins_encode %{ + Register Rp = $p$$Register; + Register Rq = $q$$Register; + Register Ry = $y$$Register; + Label done; + __ cmpl(Rp, Rq); + __ jccb(Assembler::less, done); + __ xorl(Ry, Ry); + __ bind(done); + %} + + ins_pipe(pipe_cmplt); %} /* If I enable this, I encourage spilling in the inner loop of compress. -instruct cadd_cmpLTMask_mem( ncxRegI p, ncxRegI q, memory y, eCXRegI tmp, eFlagsReg cr ) %{ +instruct cadd_cmpLTMask_mem(ncxRegI p, ncxRegI q, memory y, eCXRegI tmp, eFlagsReg cr) %{ match(Set p (AddI (AndI (CmpLTMask p q) (LoadI y)) (SubI p q))); - effect( USE_KILL tmp, KILL cr ); - ins_cost(400); - - format %{ "SUB $p,$q\n\t" - "SBB ECX,ECX\n\t" - "AND ECX,$y\n\t" - "ADD $p,ECX" %} - ins_encode( enc_cmpLTP_mem(p,q,y,tmp) ); -%} */ //----------Long Instructions------------------------------------------------ diff --git a/hotspot/src/cpu/x86/vm/x86_64.ad b/hotspot/src/cpu/x86/vm/x86_64.ad index a9b5820e273..2953b8bb41d 100644 --- a/hotspot/src/cpu/x86/vm/x86_64.ad +++ b/hotspot/src/cpu/x86/vm/x86_64.ad @@ -1,5 +1,5 @@ // -// Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. +// Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. // DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. // // This code is free software; you can redistribute it and/or modify it @@ -9434,7 +9434,7 @@ instruct cmpLTMask(rRegI dst, rRegI p, rRegI q, rFlagsReg cr) match(Set dst (CmpLTMask p q)); effect(KILL cr); - ins_cost(400); // XXX + ins_cost(400); format %{ "cmpl $p, $q\t# cmpLTMask\n\t" "setlt $dst\n\t" "movzbl $dst, $dst\n\t" @@ -9452,37 +9452,63 @@ instruct cmpLTMask0(rRegI dst, immI0 zero, rFlagsReg cr) match(Set dst (CmpLTMask dst zero)); effect(KILL cr); - ins_cost(100); // XXX + ins_cost(100); format %{ "sarl $dst, #31\t# cmpLTMask0" %} - opcode(0xC1, 0x7); /* C1 /7 ib */ - ins_encode(reg_opc_imm(dst, 0x1F)); + ins_encode %{ + __ sarl($dst$$Register, 31); + %} ins_pipe(ialu_reg); %} - -instruct cadd_cmpLTMask(rRegI p, rRegI q, rRegI y, rRegI tmp, rFlagsReg cr) +/* Better to save a register than avoid a branch */ +instruct cadd_cmpLTMask(rRegI p, rRegI q, rRegI y, rFlagsReg cr) %{ match(Set p (AddI (AndI (CmpLTMask p q) y) (SubI p q))); - effect(TEMP tmp, KILL cr); - - ins_cost(400); // XXX - format %{ "subl $p, $q\t# cadd_cmpLTMask1\n\t" - "sbbl $tmp, $tmp\n\t" - "andl $tmp, $y\n\t" - "addl $p, $tmp" %} + effect(KILL cr); + ins_cost(300); + format %{ "subl $p,$q\t# cadd_cmpLTMask\n\t" + "jge done\n\t" + "addl $p,$y\n" + "done: " %} ins_encode %{ Register Rp = $p$$Register; Register Rq = $q$$Register; Register Ry = $y$$Register; - Register Rt = $tmp$$Register; + Label done; __ subl(Rp, Rq); - __ sbbl(Rt, Rt); - __ andl(Rt, Ry); - __ addl(Rp, Rt); + __ jccb(Assembler::greaterEqual, done); + __ addl(Rp, Ry); + __ bind(done); %} ins_pipe(pipe_cmplt); %} +/* Better to save a register than avoid a branch */ +instruct and_cmpLTMask(rRegI p, rRegI q, rRegI y, rFlagsReg cr) +%{ + match(Set y (AndI (CmpLTMask p q) y)); + effect(KILL cr); + + ins_cost(300); + + format %{ "cmpl $p, $q\t# and_cmpLTMask\n\t" + "jlt done\n\t" + "xorl $y, $y\n" + "done: " %} + ins_encode %{ + Register Rp = $p$$Register; + Register Rq = $q$$Register; + Register Ry = $y$$Register; + Label done; + __ cmpl(Rp, Rq); + __ jccb(Assembler::less, done); + __ xorl(Ry, Ry); + __ bind(done); + %} + ins_pipe(pipe_cmplt); +%} + + //---------- FP Instructions------------------------------------------------ instruct cmpF_cc_reg(rFlagsRegU cr, regF src1, regF src2) diff --git a/hotspot/src/share/vm/opto/cfgnode.cpp b/hotspot/src/share/vm/opto/cfgnode.cpp index 12bccd9a538..68fcc9cbb8e 100644 --- a/hotspot/src/share/vm/opto/cfgnode.cpp +++ b/hotspot/src/share/vm/opto/cfgnode.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1306,10 +1306,11 @@ static Node* is_cond_add(PhaseGVN *phase, PhiNode *phi, int true_path) { return NULL; Node *x = n2; - Node *y = n1->in(1); - if( n2 == n1->in(1) ) { + Node *y = NULL; + if( x == n1->in(1) ) { y = n1->in(2); - } else if( n2 == n1->in(1) ) { + } else if( x == n1->in(2) ) { + y = n1->in(1); } else return NULL; // Not so profitable if compare and add are constants diff --git a/hotspot/test/compiler/6443505/Test6443505.java b/hotspot/test/compiler/6443505/Test6443505.java new file mode 100644 index 00000000000..28461b5f7dc --- /dev/null +++ b/hotspot/test/compiler/6443505/Test6443505.java @@ -0,0 +1,107 @@ +/* + * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +/** + * @test + * @bug 6443505 + * @summary Some cases for CmpLTMask missed; also wrong code. + * + * @run main/othervm -Xcomp -XX:CompileOnly="Test6443505.compiled" Test6443505 + */ + +public class Test6443505 { + + public static void main(String[] args) throws InterruptedException { + test(Integer.MIN_VALUE, 0); + test(0, Integer.MIN_VALUE); + test(Integer.MIN_VALUE, -1); + test(-1, Integer.MIN_VALUE); + test(Integer.MIN_VALUE, 1); + test(1, Integer.MIN_VALUE); + + test(Integer.MAX_VALUE, 0); + test(0, Integer.MAX_VALUE); + test(Integer.MAX_VALUE, -1); + test(-1, Integer.MAX_VALUE); + test(Integer.MAX_VALUE, 1); + test(1, Integer.MAX_VALUE); + + test(Integer.MIN_VALUE, Integer.MAX_VALUE); + test(Integer.MAX_VALUE, Integer.MIN_VALUE); + + test(1, -1); + test(1, 0); + test(1, 1); + test(-1, -1); + test(-1, 0); + test(-1, 1); + test(0, -1); + test(0, 0); + test(0, 1); + } + + public static void test(int a, int b) throws InterruptedException { + int C = compiled(4, a, b); + int I = interpreted(4, a, b); + if (C != I) { + System.err.println("#1 C = " + C + ", I = " + I); + System.err.println("#1 C != I, FAIL"); + System.exit(97); + } + + C = compiled(a, b, q, 4); + I = interpreted(a, b, q, 4); + if (C != I) { + System.err.println("#2 C = " + C + ", I = " + I); + System.err.println("#2 C != I, FAIL"); + System.exit(97); + } + + } + + static int q = 4; + + // If improperly compiled, uses carry/borrow bit, which is wrong. + // with -XX:+PrintOptoAssembly, look for cadd_cmpLTMask + static int compiled(int p, int x, int y) { + return (x < y) ? q + (x - y) : (x - y); + } + + // interpreted reference + static int interpreted(int p, int x, int y) { + return (x < y) ? q + (x - y) : (x - y); + } + + // Test new code with a range of cases + // with -XX:+PrintOptoAssembly, look for and_cmpLTMask + static int compiled(int x, int y, int q, int p) { + return (x < y) ? p + q : q; + } + + // interpreted reference + static int interpreted(int x, int y, int q, int p) { + return (x < y) ? p + q : q; + } + +} From 361d401c11d612c0b0a50cc28c754f21dc71e10a Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Mon, 15 Apr 2013 09:42:46 +0200 Subject: [PATCH 09/50] 8011582: assert(nbits == 32 || (-(1 << nbits-1) <= x && x < ( 1 << nbits-1))) failed: value out of range C1 runtime's predicate_failed_trap should use jump_to on sparc Reviewed-by: kvn --- hotspot/src/cpu/sparc/vm/c1_Runtime1_sparc.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/hotspot/src/cpu/sparc/vm/c1_Runtime1_sparc.cpp b/hotspot/src/cpu/sparc/vm/c1_Runtime1_sparc.cpp index 6723ef2c352..be4ae63e6aa 100644 --- a/hotspot/src/cpu/sparc/vm/c1_Runtime1_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/c1_Runtime1_sparc.cpp @@ -1000,9 +1000,10 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { DeoptimizationBlob* deopt_blob = SharedRuntime::deopt_blob(); assert(deopt_blob != NULL, "deoptimization blob must have been created"); restore_live_registers(sasm); - __ restore(); - __ br(Assembler::always, false, Assembler::pt, deopt_blob->unpack_with_reexecution(), relocInfo::runtime_call_type); - __ delayed()->nop(); + + AddressLiteral dest(deopt_blob->unpack_with_reexecution()); + __ jump_to(dest, O0); + __ delayed()->restore(); } break; From 9f96eb3ed5caefc5d1a5dfbdf530852550437e21 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Mon, 15 Apr 2013 17:17:11 +0200 Subject: [PATCH 10/50] 8011648: C1: optimized build is broken after 7153771 Missing #ifdef ASSERT Reviewed-by: kvn --- hotspot/src/share/vm/c1/c1_Canonicalizer.cpp | 2 ++ hotspot/src/share/vm/c1/c1_Canonicalizer.hpp | 2 ++ hotspot/src/share/vm/c1/c1_Instruction.hpp | 2 ++ hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp | 2 ++ hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp | 2 ++ hotspot/src/share/vm/c1/c1_LIR.cpp | 4 ++++ hotspot/src/share/vm/c1/c1_LIR.hpp | 5 ++++- hotspot/src/share/vm/c1/c1_LIRGenerator.cpp | 5 ++--- hotspot/src/share/vm/c1/c1_LIRGenerator.hpp | 2 ++ hotspot/src/share/vm/c1/c1_Optimizer.cpp | 5 ++++- hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp | 2 ++ hotspot/src/share/vm/c1/c1_ValueMap.hpp | 2 ++ 12 files changed, 30 insertions(+), 5 deletions(-) diff --git a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp index a4cda5f904f..b80b199c9c2 100644 --- a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp +++ b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp @@ -938,5 +938,7 @@ void Canonicalizer::do_ProfileCall(ProfileCall* x) {} void Canonicalizer::do_ProfileInvoke(ProfileInvoke* x) {} void Canonicalizer::do_RuntimeCall(RuntimeCall* x) {} void Canonicalizer::do_RangeCheckPredicate(RangeCheckPredicate* x) {} +#ifdef ASSERT void Canonicalizer::do_Assert(Assert* x) {} +#endif void Canonicalizer::do_MemBar(MemBar* x) {} diff --git a/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp b/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp index b8bcfd7e65f..9e34ac79a31 100644 --- a/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp +++ b/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp @@ -108,7 +108,9 @@ class Canonicalizer: InstructionVisitor { virtual void do_RuntimeCall (RuntimeCall* x); virtual void do_MemBar (MemBar* x); virtual void do_RangeCheckPredicate(RangeCheckPredicate* x); +#ifdef ASSERT virtual void do_Assert (Assert* x); +#endif }; #endif // SHARE_VM_C1_C1_CANONICALIZER_HPP diff --git a/hotspot/src/share/vm/c1/c1_Instruction.hpp b/hotspot/src/share/vm/c1/c1_Instruction.hpp index b93525bf502..6b1f6ddd380 100644 --- a/hotspot/src/share/vm/c1/c1_Instruction.hpp +++ b/hotspot/src/share/vm/c1/c1_Instruction.hpp @@ -111,7 +111,9 @@ class ProfileInvoke; class RuntimeCall; class MemBar; class RangeCheckPredicate; +#ifdef ASSERT class Assert; +#endif // A Value is a reference to the instruction creating the value typedef Instruction* Value; diff --git a/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp b/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp index 4c88e50cb21..cfca00ab277 100644 --- a/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp +++ b/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp @@ -871,12 +871,14 @@ void InstructionPrinter::do_RangeCheckPredicate(RangeCheckPredicate* x) { } } +#ifdef ASSERT void InstructionPrinter::do_Assert(Assert* x) { output()->print("assert "); print_value(x->x()); output()->print(" %s ", cond_name(x->cond())); print_value(x->y()); } +#endif void InstructionPrinter::do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) { print_unsafe_object_op(x, "UnsafePrefetchWrite"); diff --git a/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp b/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp index d8d6502ebd6..8c80b6c7507 100644 --- a/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp +++ b/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp @@ -136,7 +136,9 @@ class InstructionPrinter: public InstructionVisitor { virtual void do_RuntimeCall (RuntimeCall* x); virtual void do_MemBar (MemBar* x); virtual void do_RangeCheckPredicate(RangeCheckPredicate* x); +#ifdef ASSERT virtual void do_Assert (Assert* x); +#endif }; #endif // PRODUCT diff --git a/hotspot/src/share/vm/c1/c1_LIR.cpp b/hotspot/src/share/vm/c1/c1_LIR.cpp index df0828ee555..f26d1812c44 100644 --- a/hotspot/src/share/vm/c1/c1_LIR.cpp +++ b/hotspot/src/share/vm/c1/c1_LIR.cpp @@ -1778,7 +1778,9 @@ const char * LIR_Op::name() const { // LIR_OpProfileCall case lir_profile_call: s = "profile_call"; break; // LIR_OpAssert +#ifdef ASSERT case lir_assert: s = "assert"; break; +#endif case lir_none: ShouldNotReachHere();break; default: s = "illegal_op"; break; } @@ -2025,12 +2027,14 @@ void LIR_OpLock::print_instr(outputStream* out) const { out->print("[lbl:0x%x]", stub()->entry()); } +#ifdef ASSERT void LIR_OpAssert::print_instr(outputStream* out) const { print_condition(out, condition()); out->print(" "); in_opr1()->print(out); out->print(" "); in_opr2()->print(out); out->print(", \""); out->print(msg()); out->print("\""); } +#endif void LIR_OpDelay::print_instr(outputStream* out) const { diff --git a/hotspot/src/share/vm/c1/c1_LIR.hpp b/hotspot/src/share/vm/c1/c1_LIR.hpp index 5bd0e57d6f9..61dd59e3fe9 100644 --- a/hotspot/src/share/vm/c1/c1_LIR.hpp +++ b/hotspot/src/share/vm/c1/c1_LIR.hpp @@ -881,8 +881,9 @@ class LIR_OpLock; class LIR_OpTypeCheck; class LIR_OpCompareAndSwap; class LIR_OpProfileCall; +#ifdef ASSERT class LIR_OpAssert; - +#endif // LIR operation codes enum LIR_Code { @@ -1139,7 +1140,9 @@ class LIR_Op: public CompilationResourceObj { virtual LIR_OpTypeCheck* as_OpTypeCheck() { return NULL; } virtual LIR_OpCompareAndSwap* as_OpCompareAndSwap() { return NULL; } virtual LIR_OpProfileCall* as_OpProfileCall() { return NULL; } +#ifdef ASSERT virtual LIR_OpAssert* as_OpAssert() { return NULL; } +#endif virtual void verify() const {} }; diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp index ffb2965fdfc..1928df57836 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp @@ -3103,8 +3103,8 @@ void LIRGenerator::do_RuntimeCall(RuntimeCall* x) { } } -void LIRGenerator::do_Assert(Assert *x) { #ifdef ASSERT +void LIRGenerator::do_Assert(Assert *x) { ValueTag tag = x->x()->type()->tag(); If::Condition cond = x->cond(); @@ -3124,9 +3124,8 @@ void LIRGenerator::do_Assert(Assert *x) { LIR_Opr right = yin->result(); __ lir_assert(lir_cond(x->cond()), left, right, x->message(), true); -#endif } - +#endif void LIRGenerator::do_RangeCheckPredicate(RangeCheckPredicate *x) { diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp index 4c70a9f64fd..d3c76865dbd 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp @@ -537,7 +537,9 @@ class LIRGenerator: public InstructionVisitor, public BlockClosure { virtual void do_RuntimeCall (RuntimeCall* x); virtual void do_MemBar (MemBar* x); virtual void do_RangeCheckPredicate(RangeCheckPredicate* x); +#ifdef ASSERT virtual void do_Assert (Assert* x); +#endif }; diff --git a/hotspot/src/share/vm/c1/c1_Optimizer.cpp b/hotspot/src/share/vm/c1/c1_Optimizer.cpp index 74e9d2240db..90dc2797210 100644 --- a/hotspot/src/share/vm/c1/c1_Optimizer.cpp +++ b/hotspot/src/share/vm/c1/c1_Optimizer.cpp @@ -535,7 +535,9 @@ public: void do_RuntimeCall (RuntimeCall* x); void do_MemBar (MemBar* x); void do_RangeCheckPredicate(RangeCheckPredicate* x); +#ifdef ASSERT void do_Assert (Assert* x); +#endif }; @@ -718,8 +720,9 @@ void NullCheckVisitor::do_ProfileInvoke (ProfileInvoke* x) {} void NullCheckVisitor::do_RuntimeCall (RuntimeCall* x) {} void NullCheckVisitor::do_MemBar (MemBar* x) {} void NullCheckVisitor::do_RangeCheckPredicate(RangeCheckPredicate* x) {} +#ifdef ASSERT void NullCheckVisitor::do_Assert (Assert* x) {} - +#endif void NullCheckEliminator::visit(Value* p) { assert(*p != NULL, "should not find NULL instructions"); diff --git a/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp b/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp index af6d9d94815..ae1a2556881 100644 --- a/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp +++ b/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp @@ -166,7 +166,9 @@ public: void do_RuntimeCall (RuntimeCall* x) { /* nothing to do */ }; void do_MemBar (MemBar* x) { /* nothing to do */ }; void do_RangeCheckPredicate(RangeCheckPredicate* x) { /* nothing to do */ }; +#ifdef ASSERT void do_Assert (Assert* x) { /* nothing to do */ }; +#endif }; #ifdef ASSERT diff --git a/hotspot/src/share/vm/c1/c1_ValueMap.hpp b/hotspot/src/share/vm/c1/c1_ValueMap.hpp index c76ef46bef4..820d1909efa 100644 --- a/hotspot/src/share/vm/c1/c1_ValueMap.hpp +++ b/hotspot/src/share/vm/c1/c1_ValueMap.hpp @@ -207,7 +207,9 @@ class ValueNumberingVisitor: public InstructionVisitor { void do_RuntimeCall (RuntimeCall* x) { /* nothing to do */ }; void do_MemBar (MemBar* x) { /* nothing to do */ }; void do_RangeCheckPredicate(RangeCheckPredicate* x) { /* nothing to do */ }; +#ifdef ASSERT void do_Assert (Assert* x) { /* nothing to do */ }; +#endif }; From fbdab16d851ec916f10fad388ebb8341ed40c399 Mon Sep 17 00:00:00 2001 From: Christian Thalinger Date: Mon, 15 Apr 2013 16:20:05 -0700 Subject: [PATCH 11/50] 7172922: export_ makefile targets do not work unless all supported variants are built Reviewed-by: dholmes, kvn --- hotspot/make/Makefile | 307 +++++++++++++++++++++--------------------- 1 file changed, 156 insertions(+), 151 deletions(-) diff --git a/hotspot/make/Makefile b/hotspot/make/Makefile index e1fda57c4c6..e0d9826e468 100644 --- a/hotspot/make/Makefile +++ b/hotspot/make/Makefile @@ -287,186 +287,191 @@ export_debug_jdk:: # Export file copy rules XUSAGE=$(HS_SRC_DIR)/share/vm/Xusage.txt -DOCS_DIR=$(OUTPUTDIR)/$(VM_PLATFORM)_docs -C1_BASE_DIR=$(OUTPUTDIR)/$(VM_PLATFORM)_compiler1 -C2_BASE_DIR=$(OUTPUTDIR)/$(VM_PLATFORM)_compiler2 -ZERO_BASE_DIR=$(OUTPUTDIR)/$(VM_PLATFORM)_zero -SHARK_BASE_DIR=$(OUTPUTDIR)/$(VM_PLATFORM)_shark -C1_DIR=$(C1_BASE_DIR)/$(VM_SUBDIR) -C2_DIR=$(C2_BASE_DIR)/$(VM_SUBDIR) -ZERO_DIR=$(ZERO_BASE_DIR)/$(VM_SUBDIR) -SHARK_DIR=$(SHARK_BASE_DIR)/$(VM_SUBDIR) -MINIMAL1_BASE_DIR=$(OUTPUTDIR)/$(VM_PLATFORM)_minimal1 -MINIMAL1_DIR=$(MINIMAL1_BASE_DIR)/$(VM_SUBDIR) +DOCS_DIR =$(OUTPUTDIR)/$(VM_PLATFORM)_docs +C1_DIR =$(OUTPUTDIR)/$(VM_PLATFORM)_compiler1/$(VM_SUBDIR) +C2_DIR =$(OUTPUTDIR)/$(VM_PLATFORM)_compiler2/$(VM_SUBDIR) +MINIMAL1_DIR=$(OUTPUTDIR)/$(VM_PLATFORM)_minimal1/$(VM_SUBDIR) +ZERO_DIR =$(OUTPUTDIR)/$(VM_PLATFORM)_zero/$(VM_SUBDIR) +SHARK_DIR =$(OUTPUTDIR)/$(VM_PLATFORM)_shark/$(VM_SUBDIR) +# Server (C2) ifeq ($(JVM_VARIANT_SERVER), true) - MISC_DIR=$(C2_DIR) - GEN_DIR=$(C2_BASE_DIR)/generated +# Common +$(EXPORT_SERVER_DIR)/%.diz: $(C2_DIR)/%.diz + $(install-file) +$(EXPORT_LIB_DIR)/%.jar: $(C2_DIR)/../generated/%.jar + $(install-file) +$(EXPORT_INCLUDE_DIR)/%: $(C2_DIR)/../generated/jvmtifiles/% + $(install-file) +# Windows +$(EXPORT_SERVER_DIR)/%.dll: $(C2_DIR)/%.dll + $(install-file) +$(EXPORT_SERVER_DIR)/%.pdb: $(C2_DIR)/%.pdb + $(install-file) +$(EXPORT_SERVER_DIR)/%.map: $(C2_DIR)/%.map + $(install-file) +$(EXPORT_LIB_DIR)/%.lib: $(C2_DIR)/%.lib + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.diz: $(C2_DIR)/%.diz + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.dll: $(C2_DIR)/%.dll + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.pdb: $(C2_DIR)/%.pdb + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.map: $(C2_DIR)/%.map + $(install-file) +# Unix +$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_SERVER_DIR)/64/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo + $(install-file) +$(EXPORT_SERVER_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo + $(install-file) +$(EXPORT_SERVER_DIR)/64/%.debuginfo: $(C2_DIR)/%.debuginfo + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(C2_DIR)/%.diz + $(install-file) +$(EXPORT_SERVER_DIR)/64/%.diz: $(C2_DIR)/%.diz + $(install-file) endif + +# Client (C1) ifeq ($(JVM_VARIANT_CLIENT), true) - MISC_DIR=$(C1_DIR) - GEN_DIR=$(C1_BASE_DIR)/generated -endif -ifeq ($(JVM_VARIANT_ZEROSHARK), true) - MISC_DIR=$(SHARK_DIR) - GEN_DIR=$(SHARK_BASE_DIR)/generated -endif -ifeq ($(JVM_VARIANT_ZERO), true) - MISC_DIR=$(ZERO_DIR) - GEN_DIR=$(ZERO_BASE_DIR)/generated +# Common +$(EXPORT_CLIENT_DIR)/%.diz: $(C1_DIR)/%.diz + $(install-file) +$(EXPORT_LIB_DIR)/%.jar: $(C1_DIR)/../generated/%.jar + $(install-file) +$(EXPORT_INCLUDE_DIR)/%: $(C1_DIR)/../generated/jvmtifiles/% + $(install-file) +# Windows +$(EXPORT_CLIENT_DIR)/%.dll: $(C1_DIR)/%.dll + $(install-file) +$(EXPORT_CLIENT_DIR)/%.pdb: $(C1_DIR)/%.pdb + $(install-file) +$(EXPORT_CLIENT_DIR)/%.map: $(C1_DIR)/%.map + $(install-file) +$(EXPORT_LIB_DIR)/%.lib: $(C1_DIR)/%.lib + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.diz: $(C1_DIR)/%.diz + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.dll: $(C1_DIR)/%.dll + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.pdb: $(C1_DIR)/%.pdb + $(install-file) +$(EXPORT_JRE_BIN_DIR)/%.map: $(C1_DIR)/%.map + $(install-file) +# Unix +$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_CLIENT_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_CLIENT_DIR)/64/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo + $(install-file) +$(EXPORT_CLIENT_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo + $(install-file) +$(EXPORT_CLIENT_DIR)/64/%.debuginfo: $(C1_DIR)/%.debuginfo + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(C1_DIR)/%.diz + $(install-file) +$(EXPORT_CLIENT_DIR)/64/%.diz: $(C1_DIR)/%.diz + $(install-file) endif + +# Minimal1 ifeq ($(JVM_VARIANT_MINIMAL1), true) - MISC_DIR=$(MINIMAL1_DIR) - GEN_DIR=$(MINIMAL1_BASE_DIR)/generated -endif - -# Bin files (windows) -ifeq ($(OSNAME),windows) - -# Get jvm.lib -$(EXPORT_LIB_DIR)/%.lib: $(MISC_DIR)/%.lib +# Common +$(EXPORT_MINIMAL_DIR)/%.diz: $(MINIMAL1_DIR)/%.diz $(install-file) - -# Other libraries (like SA) -$(EXPORT_JRE_BIN_DIR)/%.diz: $(MISC_DIR)/%.diz +$(EXPORT_LIB_DIR)/%.jar: $(MINIMAL1_DIR)/../generated/%.jar $(install-file) -$(EXPORT_JRE_BIN_DIR)/%.dll: $(MISC_DIR)/%.dll +$(EXPORT_INCLUDE_DIR)/%: $(MINIMAL1_DIR)/../generated/jvmtifiles/% $(install-file) -$(EXPORT_JRE_BIN_DIR)/%.pdb: $(MISC_DIR)/%.pdb +# Windows +$(EXPORT_MINIMAL_DIR)/%.dll: $(MINIMAL1_DIR)/%.dll $(install-file) -$(EXPORT_JRE_BIN_DIR)/%.map: $(MISC_DIR)/%.map +$(EXPORT_MINIMAL_DIR)/%.pdb: $(MINIMAL1_DIR)/%.pdb $(install-file) - -# Client files always come from C1 area -$(EXPORT_CLIENT_DIR)/%.diz: $(C1_DIR)/%.diz +$(EXPORT_MINIMAL_DIR)/%.map: $(MINIMAL1_DIR)/%.map $(install-file) -$(EXPORT_CLIENT_DIR)/%.dll: $(C1_DIR)/%.dll +$(EXPORT_LIB_DIR)/%.lib: $(MINIMAL1_DIR)/%.lib $(install-file) -$(EXPORT_CLIENT_DIR)/%.pdb: $(C1_DIR)/%.pdb +$(EXPORT_JRE_BIN_DIR)/%.diz: $(MINIMAL1_DIR)/%.diz $(install-file) -$(EXPORT_CLIENT_DIR)/%.map: $(C1_DIR)/%.map +$(EXPORT_JRE_BIN_DIR)/%.dll: $(MINIMAL1_DIR)/%.dll $(install-file) - -# Server files always come from C2 area -$(EXPORT_SERVER_DIR)/%.diz: $(C2_DIR)/%.diz +$(EXPORT_JRE_BIN_DIR)/%.pdb: $(MINIMAL1_DIR)/%.pdb $(install-file) -$(EXPORT_SERVER_DIR)/%.dll: $(C2_DIR)/%.dll +$(EXPORT_JRE_BIN_DIR)/%.map: $(MINIMAL1_DIR)/%.map $(install-file) -$(EXPORT_SERVER_DIR)/%.pdb: $(C2_DIR)/%.pdb +# Unix +$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(MINIMAL1_DIR)/%.$(LIBRARY_SUFFIX) $(install-file) -$(EXPORT_SERVER_DIR)/%.map: $(C2_DIR)/%.map +$(EXPORT_MINIMAL_DIR)/%.$(LIBRARY_SUFFIX): $(MINIMAL1_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_MINIMAL_DIR)/64/%.$(LIBRARY_SUFFIX): $(MINIMAL1_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(MINIMAL1_DIR)/%.debuginfo + $(install-file) +$(EXPORT_MINIMAL_DIR)/%.debuginfo: $(MINIMAL1_DIR)/%.debuginfo + $(install-file) +$(EXPORT_MINIMAL_DIR)/64/%.debuginfo: $(MINIMAL1_DIR)/%.debuginfo + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(MINIMAL1_DIR)/%.diz + $(install-file) +$(EXPORT_MINIMAL_DIR)/64/%.diz: $(MINIMAL1_DIR)/%.diz $(install-file) endif -# Minimal JVM files always come from minimal area -$(EXPORT_MINIMAL_DIR)/%.diz: $(MINIMAL1_DIR)/%.diz +# Zero +ifeq ($(JVM_VARIANT_ZERO), true) +# Common +$(EXPORT_LIB_DIR)/%.jar: $(ZERO_DIR)/../generated/%.jar $(install-file) -$(EXPORT_MINIMAL_DIR)/%.dll: $(MINIMAL1_DIR)/%.dll +$(EXPORT_INCLUDE_DIR)/%: $(ZERO_DIR)/../generated/jvmtifiles/% $(install-file) -$(EXPORT_MINIMAL_DIR)/%.pdb: $(MINIMAL1_DIR)/%.pdb +# Unix +$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX) $(install-file) -$(EXPORT_MINIMAL_DIR)/%.map: $(MINIMAL1_DIR)/%.map +$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(ZERO_DIR)/%.debuginfo + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(ZERO_DIR)/%.diz + $(install-file) +$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_SERVER_DIR)/%.debuginfo: $(ZERO_DIR)/%.debuginfo + $(install-file) +$(EXPORT_SERVER_DIR)/%.diz: $(ZERO_DIR)/%.diz $(install-file) - -# Shared Library -ifneq ($(OSNAME),windows) - ifeq ($(JVM_VARIANT_SERVER), true) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_SERVER_DIR)/64/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo - $(install-file) - $(EXPORT_SERVER_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo - $(install-file) - $(EXPORT_SERVER_DIR)/64/%.debuginfo: $(C2_DIR)/%.debuginfo - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(C2_DIR)/%.diz - $(install-file) - $(EXPORT_SERVER_DIR)/%.diz: $(C2_DIR)/%.diz - $(install-file) - $(EXPORT_SERVER_DIR)/64/%.diz: $(C2_DIR)/%.diz - $(install-file) - endif - ifeq ($(JVM_VARIANT_CLIENT), true) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_CLIENT_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_CLIENT_DIR)/64/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo - $(install-file) - $(EXPORT_CLIENT_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo - $(install-file) - $(EXPORT_CLIENT_DIR)/64/%.debuginfo: $(C1_DIR)/%.debuginfo - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(C1_DIR)/%.diz - $(install-file) - $(EXPORT_CLIENT_DIR)/%.diz: $(C1_DIR)/%.diz - $(install-file) - $(EXPORT_CLIENT_DIR)/64/%.diz: $(C1_DIR)/%.diz - $(install-file) - endif - ifeq ($(JVM_VARIANT_ZEROSHARK), true) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo): $(SHARK_DIR)/%.debuginfo - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(SHARK_DIR)/%.diz - $(install-file) - $(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_SERVER_DIR)/%.debuginfo: $(SHARK_DIR)/%.debuginfo - $(install-file) - $(EXPORT_SERVER_DIR)/%.diz: $(SHARK_DIR)/%.diz - $(install-file) - endif - ifeq ($(JVM_VARIANT_ZERO), true) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(ZERO_DIR)/%.debuginfo - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(ZERO_DIR)/%.diz - $(install-file) - $(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_SERVER_DIR)/%.debuginfo: $(ZERO_DIR)/%.debuginfo - $(install-file) - $(EXPORT_SERVER_DIR)/%.diz: $(ZERO_DIR)/%.diz - $(install-file) - endif - ifeq ($(JVM_VARIANT_MINIMAL1), true) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(MINIMAL1_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_MINIMAL_DIR)/%.$(LIBRARY_SUFFIX): $(MINIMAL1_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_MINIMAL_DIR)/64/%.$(LIBRARY_SUFFIX): $(MINIMAL1_DIR)/%.$(LIBRARY_SUFFIX) - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(MINIMAL1_DIR)/%.debuginfo - $(install-file) - $(EXPORT_MINIMAL_DIR)/%.debuginfo: $(MINIMAL1_DIR)/%.debuginfo - $(install-file) - $(EXPORT_MINIMAL_DIR)/64/%.debuginfo: $(MINIMAL1_DIR)/%.debuginfo - $(install-file) - $(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(MINIMAL1_DIR)/%.diz - $(install-file) - $(EXPORT_MINIMAL_DIR)/%.diz: $(MINIMAL1_DIR)/%.diz - $(install-file) - $(EXPORT_MINIMAL_DIR)/64/%.diz: $(MINIMAL1_DIR)/%.diz - $(install-file) - endif endif -# Jar file (sa-jdi.jar) -$(EXPORT_LIB_DIR)/%.jar: $(GEN_DIR)/%.jar +# Shark +ifeq ($(JVM_VARIANT_ZEROSHARK), true) +# Common +$(EXPORT_LIB_DIR)/%.jar: $(SHARK_DIR)/../generated/%.jar $(install-file) - -# Include files (jvmti.h, jvmticmlr.h, jni.h, $(JDK_INCLUDE_SUBDIR)/jni_md.h, jmm.h, jfr.h) -$(EXPORT_INCLUDE_DIR)/%: $(GEN_DIR)/jvmtifiles/% +$(EXPORT_INCLUDE_DIR)/%: $(SHARK_DIR)/../generated/jvmtifiles/% $(install-file) +# Unix +$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo): $(SHARK_DIR)/%.debuginfo + $(install-file) +$(EXPORT_JRE_LIB_ARCH_DIR)/%.diz: $(SHARK_DIR)/%.diz + $(install-file) +$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX) + $(install-file) +$(EXPORT_SERVER_DIR)/%.debuginfo: $(SHARK_DIR)/%.debuginfo + $(install-file) +$(EXPORT_SERVER_DIR)/%.diz: $(SHARK_DIR)/%.diz + $(install-file) +endif $(EXPORT_INCLUDE_DIR)/%: $(HS_SRC_DIR)/share/vm/code/% $(install-file) From 09fdc18edc579a2c74468a8d627f9a31b1ff49a0 Mon Sep 17 00:00:00 2001 From: Niclas Adlertz Date: Tue, 16 Apr 2013 10:08:41 +0200 Subject: [PATCH 12/50] 8011621: live_ranges_in_separate_class.patch Reviewed-by: kvn, roland --- hotspot/make/bsd/makefiles/vm.make | 2 +- hotspot/make/linux/makefiles/vm.make | 2 +- hotspot/make/solaris/makefiles/vm.make | 2 +- hotspot/make/windows/create_obj_files.sh | 2 +- hotspot/src/os/bsd/vm/chaitin_bsd.cpp | 42 -- hotspot/src/os/linux/vm/chaitin_linux.cpp | 42 -- hotspot/src/os/solaris/vm/chaitin_solaris.cpp | 46 -- hotspot/src/os/windows/vm/chaitin_windows.cpp | 78 --- hotspot/src/share/vm/opto/chaitin.cpp | 448 ++++++++++++------ hotspot/src/share/vm/opto/chaitin.hpp | 185 ++++++-- hotspot/src/share/vm/opto/coalesce.cpp | 321 ++++--------- hotspot/src/share/vm/opto/coalesce.hpp | 14 +- hotspot/src/share/vm/opto/compile.cpp | 14 +- .../src/share/vm/opto/idealGraphPrinter.cpp | 2 +- hotspot/src/share/vm/opto/ifg.cpp | 74 +-- hotspot/src/share/vm/opto/live.cpp | 2 +- hotspot/src/share/vm/opto/live.hpp | 4 +- hotspot/src/share/vm/opto/postaloc.cpp | 45 +- hotspot/src/share/vm/opto/reg_split.cpp | 167 ++++--- hotspot/src/share/vm/opto/regalloc.hpp | 11 +- hotspot/src/share/vm/runtime/vmStructs.cpp | 1 - 21 files changed, 733 insertions(+), 771 deletions(-) delete mode 100644 hotspot/src/os/bsd/vm/chaitin_bsd.cpp delete mode 100644 hotspot/src/os/linux/vm/chaitin_linux.cpp delete mode 100644 hotspot/src/os/solaris/vm/chaitin_solaris.cpp delete mode 100644 hotspot/src/os/windows/vm/chaitin_windows.cpp diff --git a/hotspot/make/bsd/makefiles/vm.make b/hotspot/make/bsd/makefiles/vm.make index e93765dc50f..b9528e101ee 100644 --- a/hotspot/make/bsd/makefiles/vm.make +++ b/hotspot/make/bsd/makefiles/vm.make @@ -187,7 +187,7 @@ Src_Dirs/ZERO := $(CORE_PATHS) Src_Dirs/SHARK := $(CORE_PATHS) $(SHARK_PATHS) Src_Dirs := $(Src_Dirs/$(TYPE)) -COMPILER2_SPECIFIC_FILES := opto libadt bcEscapeAnalyzer.cpp chaitin\* c2_\* runtime_\* +COMPILER2_SPECIFIC_FILES := opto libadt bcEscapeAnalyzer.cpp c2_\* runtime_\* COMPILER1_SPECIFIC_FILES := c1_\* SHARK_SPECIFIC_FILES := shark ZERO_SPECIFIC_FILES := zero diff --git a/hotspot/make/linux/makefiles/vm.make b/hotspot/make/linux/makefiles/vm.make index b31064782f7..af060f8af0b 100644 --- a/hotspot/make/linux/makefiles/vm.make +++ b/hotspot/make/linux/makefiles/vm.make @@ -189,7 +189,7 @@ Src_Dirs/ZERO := $(CORE_PATHS) Src_Dirs/SHARK := $(CORE_PATHS) $(SHARK_PATHS) Src_Dirs := $(Src_Dirs/$(TYPE)) -COMPILER2_SPECIFIC_FILES := opto libadt bcEscapeAnalyzer.cpp chaitin\* c2_\* runtime_\* +COMPILER2_SPECIFIC_FILES := opto libadt bcEscapeAnalyzer.cpp c2_\* runtime_\* COMPILER1_SPECIFIC_FILES := c1_\* SHARK_SPECIFIC_FILES := shark ZERO_SPECIFIC_FILES := zero diff --git a/hotspot/make/solaris/makefiles/vm.make b/hotspot/make/solaris/makefiles/vm.make index 5aca8f05f76..62146d77f03 100644 --- a/hotspot/make/solaris/makefiles/vm.make +++ b/hotspot/make/solaris/makefiles/vm.make @@ -202,7 +202,7 @@ Src_Dirs/ZERO := $(CORE_PATHS) Src_Dirs/SHARK := $(CORE_PATHS) Src_Dirs := $(Src_Dirs/$(TYPE)) -COMPILER2_SPECIFIC_FILES := opto libadt bcEscapeAnalyzer.cpp chaitin\* c2_\* runtime_\* +COMPILER2_SPECIFIC_FILES := opto libadt bcEscapeAnalyzer.cpp c2_\* runtime_\* COMPILER1_SPECIFIC_FILES := c1_\* SHARK_SPECIFIC_FILES := shark ZERO_SPECIFIC_FILES := zero diff --git a/hotspot/make/windows/create_obj_files.sh b/hotspot/make/windows/create_obj_files.sh index 14a7087f2aa..257b3f140d2 100644 --- a/hotspot/make/windows/create_obj_files.sh +++ b/hotspot/make/windows/create_obj_files.sh @@ -114,7 +114,7 @@ case "${TYPE}" in "shark") Src_Dirs="${CORE_PATHS}" ;; esac -COMPILER2_SPECIFIC_FILES="opto libadt bcEscapeAnalyzer.cpp chaitin* c2_* runtime_*" +COMPILER2_SPECIFIC_FILES="opto libadt bcEscapeAnalyzer.cpp c2_* runtime_*" COMPILER1_SPECIFIC_FILES="c1_*" SHARK_SPECIFIC_FILES="shark" ZERO_SPECIFIC_FILES="zero" diff --git a/hotspot/src/os/bsd/vm/chaitin_bsd.cpp b/hotspot/src/os/bsd/vm/chaitin_bsd.cpp deleted file mode 100644 index e4925644dbc..00000000000 --- a/hotspot/src/os/bsd/vm/chaitin_bsd.cpp +++ /dev/null @@ -1,42 +0,0 @@ -/* - * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code 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 - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ - -#include "precompiled.hpp" -#include "opto/chaitin.hpp" -#include "opto/machnode.hpp" - -void PhaseRegAlloc::pd_preallocate_hook() { - // no action -} - -#ifdef ASSERT -void PhaseRegAlloc::pd_postallocate_verify_hook() { - // no action -} -#endif - - -// Reconciliation History -// chaitin_solaris.cpp 1.7 99/07/12 23:54:22 -// End diff --git a/hotspot/src/os/linux/vm/chaitin_linux.cpp b/hotspot/src/os/linux/vm/chaitin_linux.cpp deleted file mode 100644 index e4925644dbc..00000000000 --- a/hotspot/src/os/linux/vm/chaitin_linux.cpp +++ /dev/null @@ -1,42 +0,0 @@ -/* - * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code 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 - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ - -#include "precompiled.hpp" -#include "opto/chaitin.hpp" -#include "opto/machnode.hpp" - -void PhaseRegAlloc::pd_preallocate_hook() { - // no action -} - -#ifdef ASSERT -void PhaseRegAlloc::pd_postallocate_verify_hook() { - // no action -} -#endif - - -// Reconciliation History -// chaitin_solaris.cpp 1.7 99/07/12 23:54:22 -// End diff --git a/hotspot/src/os/solaris/vm/chaitin_solaris.cpp b/hotspot/src/os/solaris/vm/chaitin_solaris.cpp deleted file mode 100644 index 92a437f9683..00000000000 --- a/hotspot/src/os/solaris/vm/chaitin_solaris.cpp +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code 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 - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ - -#include "precompiled.hpp" -#include "opto/chaitin.hpp" -#include "opto/machnode.hpp" - -void PhaseRegAlloc::pd_preallocate_hook() { - // no action -} - -#ifdef ASSERT -void PhaseRegAlloc::pd_postallocate_verify_hook() { - // no action -} -#endif - - -//Reconciliation History -// 1.1 99/02/12 15:35:26 chaitin_win32.cpp -// 1.2 99/02/18 15:38:56 chaitin_win32.cpp -// 1.4 99/03/09 10:37:48 chaitin_win32.cpp -// 1.6 99/03/25 11:07:44 chaitin_win32.cpp -// 1.8 99/06/22 16:38:58 chaitin_win32.cpp -//End diff --git a/hotspot/src/os/windows/vm/chaitin_windows.cpp b/hotspot/src/os/windows/vm/chaitin_windows.cpp deleted file mode 100644 index bae10b3b5c4..00000000000 --- a/hotspot/src/os/windows/vm/chaitin_windows.cpp +++ /dev/null @@ -1,78 +0,0 @@ -/* - * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code 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 - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ - -#include "precompiled.hpp" -#include "opto/chaitin.hpp" -#include "opto/machnode.hpp" - -// Disallow the use of the frame pointer (EBP) for implicit null exceptions -// on win95/98. If we do not do this, the OS gets confused and gives a stack -// error. -void PhaseRegAlloc::pd_preallocate_hook() { -#ifndef _WIN64 - if (ImplicitNullChecks && !os::win32::is_nt()) { - for (uint block_num=1; block_num<_cfg._num_blocks; block_num++) { - Block *block = _cfg._blocks[block_num]; - - Node *block_end = block->end(); - if (block_end->is_MachNullCheck() && - block_end->as_Mach()->ideal_Opcode() != Op_Con) { - // The last instruction in the block is an implicit null check. - // Fix its input so that it does not load into the frame pointer. - _matcher.pd_implicit_null_fixup(block_end->in(1)->as_Mach(), - block_end->as_MachNullCheck()->_vidx); - } - } - } -#else - // WIN64==itanium on XP -#endif -} - -#ifdef ASSERT -// Verify that no implicit null check uses the frame pointer (EBP) as -// its register on win95/98. Use of the frame pointer in an implicit -// null check confuses the OS, yielding a stack error. -void PhaseRegAlloc::pd_postallocate_verify_hook() { -#ifndef _WIN64 - if (ImplicitNullChecks && !os::win32::is_nt()) { - for (uint block_num=1; block_num<_cfg._num_blocks; block_num++) { - Block *block = _cfg._blocks[block_num]; - - Node *block_end = block->_nodes[block->_nodes.size()-1]; - if (block_end->is_MachNullCheck() && block_end->as_Mach()->ideal_Opcode() != Op_Con) { - // The last instruction in the block is an implicit - // null check. Verify that this instruction does not - // use the frame pointer. - int reg = get_reg_first(block_end->in(1)->in(block_end->as_MachNullCheck()->_vidx)); - assert(reg != EBP_num, - "implicit null check using frame pointer on win95/98"); - } - } - } -#else - // WIN64==itanium on XP -#endif -} -#endif diff --git a/hotspot/src/share/vm/opto/chaitin.cpp b/hotspot/src/share/vm/opto/chaitin.cpp index 0fbe723c44f..9d69b0f3b71 100644 --- a/hotspot/src/share/vm/opto/chaitin.cpp +++ b/hotspot/src/share/vm/opto/chaitin.cpp @@ -145,6 +145,72 @@ void LRG_List::extend( uint nidx, uint lidx ) { #define NUMBUCKS 3 +// Straight out of Tarjan's union-find algorithm +uint LiveRangeMap::find_compress(uint lrg) { + uint cur = lrg; + uint next = _uf_map[cur]; + while (next != cur) { // Scan chain of equivalences + assert( next < cur, "always union smaller"); + cur = next; // until find a fixed-point + next = _uf_map[cur]; + } + + // Core of union-find algorithm: update chain of + // equivalences to be equal to the root. + while (lrg != next) { + uint tmp = _uf_map[lrg]; + _uf_map.map(lrg, next); + lrg = tmp; + } + return lrg; +} + +// Reset the Union-Find map to identity +void LiveRangeMap::reset_uf_map(uint max_lrg_id) { + _max_lrg_id= max_lrg_id; + // Force the Union-Find mapping to be at least this large + _uf_map.extend(_max_lrg_id, 0); + // Initialize it to be the ID mapping. + for (uint i = 0; i < _max_lrg_id; ++i) { + _uf_map.map(i, i); + } +} + +// Make all Nodes map directly to their final live range; no need for +// the Union-Find mapping after this call. +void LiveRangeMap::compress_uf_map_for_nodes() { + // For all Nodes, compress mapping + uint unique = _names.Size(); + for (uint i = 0; i < unique; ++i) { + uint lrg = _names[i]; + uint compressed_lrg = find(lrg); + if (lrg != compressed_lrg) { + _names.map(i, compressed_lrg); + } + } +} + +// Like Find above, but no path compress, so bad asymptotic behavior +uint LiveRangeMap::find_const(uint lrg) const { + if (!lrg) { + return lrg; // Ignore the zero LRG + } + + // Off the end? This happens during debugging dumps when you got + // brand new live ranges but have not told the allocator yet. + if (lrg >= _max_lrg_id) { + return lrg; + } + + uint next = _uf_map[lrg]; + while (next != lrg) { // Scan chain of equivalences + assert(next < lrg, "always union smaller"); + lrg = next; // until find a fixed-point + next = _uf_map[lrg]; + } + return next; +} + //------------------------------Chaitin---------------------------------------- PhaseChaitin::PhaseChaitin(uint unique, PhaseCFG &cfg, Matcher &matcher) : PhaseRegAlloc(unique, cfg, matcher, @@ -153,13 +219,13 @@ PhaseChaitin::PhaseChaitin(uint unique, PhaseCFG &cfg, Matcher &matcher) #else NULL #endif - ), - _names(unique), _uf_map(unique), - _maxlrg(0), _live(0), - _spilled_once(Thread::current()->resource_area()), - _spilled_twice(Thread::current()->resource_area()), - _lo_degree(0), _lo_stk_degree(0), _hi_degree(0), _simplified(0), - _oldphi(unique) + ) + , _lrg_map(unique) + , _live(0) + , _spilled_once(Thread::current()->resource_area()) + , _spilled_twice(Thread::current()->resource_area()) + , _lo_degree(0), _lo_stk_degree(0), _hi_degree(0), _simplified(0) + , _oldphi(unique) #ifndef PRODUCT , _trace_spilling(TraceSpilling || C->method_has_option("TraceSpilling")) #endif @@ -168,7 +234,6 @@ PhaseChaitin::PhaseChaitin(uint unique, PhaseCFG &cfg, Matcher &matcher) _high_frequency_lrg = MIN2(float(OPTO_LRG_HIGH_FREQ), _cfg._outer_loop_freq); - uint i,j; // Build a list of basic blocks, sorted by frequency _blks = NEW_RESOURCE_ARRAY( Block *, _cfg._num_blocks ); // Experiment with sorting strategies to speed compilation @@ -176,30 +241,30 @@ PhaseChaitin::PhaseChaitin(uint unique, PhaseCFG &cfg, Matcher &matcher) Block **buckets[NUMBUCKS]; // Array of buckets uint buckcnt[NUMBUCKS]; // Array of bucket counters double buckval[NUMBUCKS]; // Array of bucket value cutoffs - for( i = 0; i < NUMBUCKS; i++ ) { - buckets[i] = NEW_RESOURCE_ARRAY( Block *, _cfg._num_blocks ); + for (uint i = 0; i < NUMBUCKS; i++) { + buckets[i] = NEW_RESOURCE_ARRAY(Block *, _cfg._num_blocks); buckcnt[i] = 0; // Bump by three orders of magnitude each time cutoff *= 0.001; buckval[i] = cutoff; - for( j = 0; j < _cfg._num_blocks; j++ ) { + for (uint j = 0; j < _cfg._num_blocks; j++) { buckets[i][j] = NULL; } } // Sort blocks into buckets - for( i = 0; i < _cfg._num_blocks; i++ ) { - for( j = 0; j < NUMBUCKS; j++ ) { - if( (j == NUMBUCKS-1) || (_cfg._blocks[i]->_freq > buckval[j]) ) { + for (uint i = 0; i < _cfg._num_blocks; i++) { + for (uint j = 0; j < NUMBUCKS; j++) { + if ((j == NUMBUCKS - 1) || (_cfg._blocks[i]->_freq > buckval[j])) { // Assign block to end of list for appropriate bucket buckets[j][buckcnt[j]++] = _cfg._blocks[i]; - break; // kick out of inner loop + break; // kick out of inner loop } } } // Dump buckets into final block array uint blkcnt = 0; - for( i = 0; i < NUMBUCKS; i++ ) { - for( j = 0; j < buckcnt[i]; j++ ) { + for (uint i = 0; i < NUMBUCKS; i++) { + for (uint j = 0; j < buckcnt[i]; j++) { _blks[blkcnt++] = buckets[i][j]; } } @@ -207,6 +272,77 @@ PhaseChaitin::PhaseChaitin(uint unique, PhaseCFG &cfg, Matcher &matcher) assert(blkcnt == _cfg._num_blocks, "Block array not totally filled"); } +//------------------------------Union------------------------------------------ +// union 2 sets together. +void PhaseChaitin::Union( const Node *src_n, const Node *dst_n ) { + uint src = _lrg_map.find(src_n); + uint dst = _lrg_map.find(dst_n); + assert(src, ""); + assert(dst, ""); + assert(src < _lrg_map.max_lrg_id(), "oob"); + assert(dst < _lrg_map.max_lrg_id(), "oob"); + assert(src < dst, "always union smaller"); + _lrg_map.uf_map(dst, src); +} + +//------------------------------new_lrg---------------------------------------- +void PhaseChaitin::new_lrg(const Node *x, uint lrg) { + // Make the Node->LRG mapping + _lrg_map.extend(x->_idx,lrg); + // Make the Union-Find mapping an identity function + _lrg_map.uf_extend(lrg, lrg); +} + + +bool PhaseChaitin::clone_projs_shared(Block *b, uint idx, Node *con, Node *copy, uint max_lrg_id) { + Block *bcon = _cfg._bbs[con->_idx]; + uint cindex = bcon->find_node(con); + Node *con_next = bcon->_nodes[cindex+1]; + if (con_next->in(0) != con || !con_next->is_MachProj()) { + return false; // No MachProj's follow + } + + // Copy kills after the cloned constant + Node *kills = con_next->clone(); + kills->set_req(0, copy); + b->_nodes.insert(idx, kills); + _cfg._bbs.map(kills->_idx, b); + new_lrg(kills, max_lrg_id); + return true; +} + +//------------------------------compact---------------------------------------- +// Renumber the live ranges to compact them. Makes the IFG smaller. +void PhaseChaitin::compact() { + // Current the _uf_map contains a series of short chains which are headed + // by a self-cycle. All the chains run from big numbers to little numbers. + // The Find() call chases the chains & shortens them for the next Find call. + // We are going to change this structure slightly. Numbers above a moving + // wave 'i' are unchanged. Numbers below 'j' point directly to their + // compacted live range with no further chaining. There are no chains or + // cycles below 'i', so the Find call no longer works. + uint j=1; + uint i; + for (i = 1; i < _lrg_map.max_lrg_id(); i++) { + uint lr = _lrg_map.uf_live_range_id(i); + // Ignore unallocated live ranges + if (!lr) { + continue; + } + assert(lr <= i, ""); + _lrg_map.uf_map(i, ( lr == i ) ? j++ : _lrg_map.uf_live_range_id(lr)); + } + // Now change the Node->LR mapping to reflect the compacted names + uint unique = _lrg_map.size(); + for (i = 0; i < unique; i++) { + uint lrg_id = _lrg_map.live_range_id(i); + _lrg_map.map(i, _lrg_map.uf_live_range_id(lrg_id)); + } + + // Reset the Union-Find mapping + _lrg_map.reset_uf_map(j); +} + void PhaseChaitin::Register_Allocate() { // Above the OLD FP (and in registers) are the incoming arguments. Stack @@ -231,14 +367,12 @@ void PhaseChaitin::Register_Allocate() { // all copy-related live ranges low and then using the max copy-related // live range as a cut-off for LIVE and the IFG. In other words, I can // build a subset of LIVE and IFG just for copies. - PhaseLive live(_cfg,_names,&live_arena); + PhaseLive live(_cfg, _lrg_map.names(), &live_arena); // Need IFG for coalescing and coloring - PhaseIFG ifg( &live_arena ); + PhaseIFG ifg(&live_arena); _ifg = &ifg; - if (C->unique() > _names.Size()) _names.extend(C->unique()-1, 0); - // Come out of SSA world to the Named world. Assign (virtual) registers to // Nodes. Use the same register for all inputs and the output of PhiNodes // - effectively ending SSA form. This requires either coalescing live @@ -258,9 +392,9 @@ void PhaseChaitin::Register_Allocate() { _live = NULL; // Mark live as being not available rm.reset_to_mark(); // Reclaim working storage IndexSet::reset_memory(C, &live_arena); - ifg.init(_maxlrg); // Empty IFG + ifg.init(_lrg_map.max_lrg_id()); // Empty IFG gather_lrg_masks( false ); // Collect LRG masks - live.compute( _maxlrg ); // Compute liveness + live.compute(_lrg_map.max_lrg_id()); // Compute liveness _live = &live; // Mark LIVE as being available } @@ -270,19 +404,19 @@ void PhaseChaitin::Register_Allocate() { // across any GC point where the derived value is live. So this code looks // at all the GC points, and "stretches" the live range of any base pointer // to the GC point. - if( stretch_base_pointer_live_ranges(&live_arena) ) { - NOT_PRODUCT( Compile::TracePhase t3("computeLive (sbplr)", &_t_computeLive, TimeCompiler); ) + if (stretch_base_pointer_live_ranges(&live_arena)) { + NOT_PRODUCT(Compile::TracePhase t3("computeLive (sbplr)", &_t_computeLive, TimeCompiler);) // Since some live range stretched, I need to recompute live _live = NULL; rm.reset_to_mark(); // Reclaim working storage IndexSet::reset_memory(C, &live_arena); - ifg.init(_maxlrg); - gather_lrg_masks( false ); - live.compute( _maxlrg ); + ifg.init(_lrg_map.max_lrg_id()); + gather_lrg_masks(false); + live.compute(_lrg_map.max_lrg_id()); _live = &live; } // Create the interference graph using virtual copies - build_ifg_virtual( ); // Include stack slots this time + build_ifg_virtual(); // Include stack slots this time // Aggressive (but pessimistic) copy coalescing. // This pass works on virtual copies. Any virtual copies which are not @@ -296,8 +430,8 @@ void PhaseChaitin::Register_Allocate() { // given Node and search them for an instance, i.e., time O(#MaxLRG)). _ifg->SquareUp(); - PhaseAggressiveCoalesce coalesce( *this ); - coalesce.coalesce_driver( ); + PhaseAggressiveCoalesce coalesce(*this); + coalesce.coalesce_driver(); // Insert un-coalesced copies. Visit all Phis. Where inputs to a Phi do // not match the Phi itself, insert a copy. coalesce.insert_copies(_matcher); @@ -310,28 +444,36 @@ void PhaseChaitin::Register_Allocate() { _live = NULL; rm.reset_to_mark(); // Reclaim working storage IndexSet::reset_memory(C, &live_arena); - ifg.init(_maxlrg); + ifg.init(_lrg_map.max_lrg_id()); gather_lrg_masks( true ); - live.compute( _maxlrg ); + live.compute(_lrg_map.max_lrg_id()); _live = &live; } // Build physical interference graph uint must_spill = 0; - must_spill = build_ifg_physical( &live_arena ); + must_spill = build_ifg_physical(&live_arena); // If we have a guaranteed spill, might as well spill now - if( must_spill ) { - if( !_maxlrg ) return; + if (must_spill) { + if(!_lrg_map.max_lrg_id()) { + return; + } // Bail out if unique gets too large (ie - unique > MaxNodeLimit) C->check_node_count(10*must_spill, "out of nodes before split"); - if (C->failing()) return; - _maxlrg = Split(_maxlrg, &split_arena); // Split spilling LRG everywhere + if (C->failing()) { + return; + } + + uint new_max_lrg_id = Split(_lrg_map.max_lrg_id(), &split_arena); // Split spilling LRG everywhere + _lrg_map.set_max_lrg_id(new_max_lrg_id); // Bail out if unique gets too large (ie - unique > MaxNodeLimit - 2*NodeLimitFudgeFactor) // or we failed to split C->check_node_count(2*NodeLimitFudgeFactor, "out of nodes after physical split"); - if (C->failing()) return; + if (C->failing()) { + return; + } - NOT_PRODUCT( C->verify_graph_edges(); ) + NOT_PRODUCT(C->verify_graph_edges();) compact(); // Compact LRGs; return new lower max lrg @@ -340,23 +482,23 @@ void PhaseChaitin::Register_Allocate() { _live = NULL; rm.reset_to_mark(); // Reclaim working storage IndexSet::reset_memory(C, &live_arena); - ifg.init(_maxlrg); // Build a new interference graph + ifg.init(_lrg_map.max_lrg_id()); // Build a new interference graph gather_lrg_masks( true ); // Collect intersect mask - live.compute( _maxlrg ); // Compute LIVE + live.compute(_lrg_map.max_lrg_id()); // Compute LIVE _live = &live; } - build_ifg_physical( &live_arena ); + build_ifg_physical(&live_arena); _ifg->SquareUp(); _ifg->Compute_Effective_Degree(); // Only do conservative coalescing if requested - if( OptoCoalesce ) { + if (OptoCoalesce) { // Conservative (and pessimistic) copy coalescing of those spills - PhaseConservativeCoalesce coalesce( *this ); + PhaseConservativeCoalesce coalesce(*this); // If max live ranges greater than cutoff, don't color the stack. // This cutoff can be larger than below since it is only done once. - coalesce.coalesce_driver( ); + coalesce.coalesce_driver(); } - compress_uf_map_for_nodes(); + _lrg_map.compress_uf_map_for_nodes(); #ifdef ASSERT verify(&live_arena, true); @@ -390,13 +532,18 @@ void PhaseChaitin::Register_Allocate() { } } - if( !_maxlrg ) return; - _maxlrg = Split(_maxlrg, &split_arena); // Split spilling LRG everywhere + if (!_lrg_map.max_lrg_id()) { + return; + } + uint new_max_lrg_id = Split(_lrg_map.max_lrg_id(), &split_arena); // Split spilling LRG everywhere + _lrg_map.set_max_lrg_id(new_max_lrg_id); // Bail out if unique gets too large (ie - unique > MaxNodeLimit - 2*NodeLimitFudgeFactor) - C->check_node_count(2*NodeLimitFudgeFactor, "out of nodes after split"); - if (C->failing()) return; + C->check_node_count(2 * NodeLimitFudgeFactor, "out of nodes after split"); + if (C->failing()) { + return; + } - compact(); // Compact LRGs; return new lower max lrg + compact(); // Compact LRGs; return new lower max lrg // Nuke the live-ness and interference graph and LiveRanGe info { @@ -404,26 +551,26 @@ void PhaseChaitin::Register_Allocate() { _live = NULL; rm.reset_to_mark(); // Reclaim working storage IndexSet::reset_memory(C, &live_arena); - ifg.init(_maxlrg); + ifg.init(_lrg_map.max_lrg_id()); // Create LiveRanGe array. // Intersect register masks for all USEs and DEFs - gather_lrg_masks( true ); - live.compute( _maxlrg ); + gather_lrg_masks(true); + live.compute(_lrg_map.max_lrg_id()); _live = &live; } - must_spill = build_ifg_physical( &live_arena ); + must_spill = build_ifg_physical(&live_arena); _ifg->SquareUp(); _ifg->Compute_Effective_Degree(); // Only do conservative coalescing if requested - if( OptoCoalesce ) { + if (OptoCoalesce) { // Conservative (and pessimistic) copy coalescing - PhaseConservativeCoalesce coalesce( *this ); + PhaseConservativeCoalesce coalesce(*this); // Check for few live ranges determines how aggressive coalesce is. - coalesce.coalesce_driver( ); + coalesce.coalesce_driver(); } - compress_uf_map_for_nodes(); + _lrg_map.compress_uf_map_for_nodes(); #ifdef ASSERT verify(&live_arena, true); #endif @@ -435,7 +582,7 @@ void PhaseChaitin::Register_Allocate() { // Select colors by re-inserting LRGs back into the IFG in reverse order. // Return whether or not something spills. - spills = Select( ); + spills = Select(); } // Count number of Simplify-Select trips per coloring success. @@ -452,9 +599,12 @@ void PhaseChaitin::Register_Allocate() { // max_reg is past the largest *register* used. // Convert that to a frame_slot number. - if( _max_reg <= _matcher._new_SP ) + if (_max_reg <= _matcher._new_SP) { _framesize = C->out_preserve_stack_slots(); - else _framesize = _max_reg -_matcher._new_SP; + } + else { + _framesize = _max_reg -_matcher._new_SP; + } assert((int)(_matcher._new_SP+_framesize) >= (int)_matcher._out_arg_limit, "framesize must be large enough"); // This frame must preserve the required fp alignment @@ -462,8 +612,9 @@ void PhaseChaitin::Register_Allocate() { assert( _framesize >= 0 && _framesize <= 1000000, "sanity check" ); #ifndef PRODUCT _total_framesize += _framesize; - if( (int)_framesize > _max_framesize ) + if ((int)_framesize > _max_framesize) { _max_framesize = _framesize; + } #endif // Convert CISC spills @@ -475,15 +626,17 @@ void PhaseChaitin::Register_Allocate() { log->elem("regalloc attempts='%d' success='%d'", _trip_cnt, !C->failing()); } - if (C->failing()) return; + if (C->failing()) { + return; + } - NOT_PRODUCT( C->verify_graph_edges(); ) + NOT_PRODUCT(C->verify_graph_edges();) // Move important info out of the live_arena to longer lasting storage. - alloc_node_regs(_names.Size()); - for (uint i=0; i < _names.Size(); i++) { - if (_names[i]) { // Live range associated with Node? - LRG &lrg = lrgs(_names[i]); + alloc_node_regs(_lrg_map.size()); + for (uint i=0; i < _lrg_map.size(); i++) { + if (_lrg_map.live_range_id(i)) { // Live range associated with Node? + LRG &lrg = lrgs(_lrg_map.live_range_id(i)); if (!lrg.alive()) { set_bad(i); } else if (lrg.num_regs() == 1) { @@ -537,11 +690,11 @@ void PhaseChaitin::de_ssa() { Node *n = b->_nodes[j]; // Pre-color to the zero live range, or pick virtual register const RegMask &rm = n->out_RegMask(); - _names.map( n->_idx, rm.is_NotEmpty() ? lr_counter++ : 0 ); + _lrg_map.map(n->_idx, rm.is_NotEmpty() ? lr_counter++ : 0); } } // Reset the Union-Find mapping to be identity - reset_uf_map(lr_counter); + _lrg_map.reset_uf_map(lr_counter); } @@ -551,7 +704,7 @@ void PhaseChaitin::de_ssa() { void PhaseChaitin::gather_lrg_masks( bool after_aggressive ) { // Nail down the frame pointer live range - uint fp_lrg = n2lidx(_cfg._root->in(1)->in(TypeFunc::FramePtr)); + uint fp_lrg = _lrg_map.live_range_id(_cfg._root->in(1)->in(TypeFunc::FramePtr)); lrgs(fp_lrg)._cost += 1e12; // Cost is infinite // For all blocks @@ -566,14 +719,14 @@ void PhaseChaitin::gather_lrg_masks( bool after_aggressive ) { uint idx = n->is_Copy(); // Get virtual register number, same as LiveRanGe index - uint vreg = n2lidx(n); + uint vreg = _lrg_map.live_range_id(n); LRG &lrg = lrgs(vreg); if( vreg ) { // No vreg means un-allocable (e.g. memory) // Collect has-copy bit if( idx ) { lrg._has_copy = 1; - uint clidx = n2lidx(n->in(idx)); + uint clidx = _lrg_map.live_range_id(n->in(idx)); LRG ©_src = lrgs(clidx); copy_src._has_copy = 1; } @@ -773,8 +926,10 @@ void PhaseChaitin::gather_lrg_masks( bool after_aggressive ) { } // Prepare register mask for each input for( uint k = input_edge_start; k < cnt; k++ ) { - uint vreg = n2lidx(n->in(k)); - if( !vreg ) continue; + uint vreg = _lrg_map.live_range_id(n->in(k)); + if (!vreg) { + continue; + } // If this instruction is CISC Spillable, add the flags // bit to its appropriate input @@ -857,7 +1012,7 @@ void PhaseChaitin::gather_lrg_masks( bool after_aggressive ) { } // end for all blocks // Final per-liverange setup - for (uint i2=0; i2<_maxlrg; i2++) { + for (uint i2 = 0; i2 < _lrg_map.max_lrg_id(); i2++) { LRG &lrg = lrgs(i2); assert(!lrg._is_vector || !lrg._fat_proj, "sanity"); if (lrg.num_regs() > 1 && !lrg._fat_proj) { @@ -879,7 +1034,7 @@ void PhaseChaitin::gather_lrg_masks( bool after_aggressive ) { // The bit is checked in Simplify. void PhaseChaitin::set_was_low() { #ifdef ASSERT - for( uint i = 1; i < _maxlrg; i++ ) { + for (uint i = 1; i < _lrg_map.max_lrg_id(); i++) { int size = lrgs(i).num_regs(); uint old_was_lo = lrgs(i)._was_lo; lrgs(i)._was_lo = 0; @@ -913,7 +1068,7 @@ void PhaseChaitin::set_was_low() { // Compute cost/area ratio, in case we spill. Build the lo-degree list. void PhaseChaitin::cache_lrg_info( ) { - for( uint i = 1; i < _maxlrg; i++ ) { + for (uint i = 1; i < _lrg_map.max_lrg_id(); i++) { LRG &lrg = lrgs(i); // Check for being of low degree: means we can be trivially colored. @@ -949,10 +1104,10 @@ void PhaseChaitin::Pre_Simplify( ) { // Warm up the lo-degree no-copy list int lo_no_copy = 0; - for( uint i = 1; i < _maxlrg; i++ ) { - if( (lrgs(i).lo_degree() && !lrgs(i)._has_copy) || + for (uint i = 1; i < _lrg_map.max_lrg_id(); i++) { + if ((lrgs(i).lo_degree() && !lrgs(i)._has_copy) || !lrgs(i).alive() || - lrgs(i)._must_spill ) { + lrgs(i)._must_spill) { lrgs(i)._next = lo_no_copy; lo_no_copy = i; } @@ -1163,7 +1318,7 @@ static bool is_legal_reg(LRG &lrg, OptoReg::Name reg, int chunk) { OptoReg::Name PhaseChaitin::bias_color( LRG &lrg, int chunk ) { // Check for "at_risk" LRG's - uint risk_lrg = Find(lrg._risk_bias); + uint risk_lrg = _lrg_map.find(lrg._risk_bias); if( risk_lrg != 0 ) { // Walk the colored neighbors of the "at_risk" candidate // Choose a color which is both legal and already taken by a neighbor @@ -1179,7 +1334,7 @@ OptoReg::Name PhaseChaitin::bias_color( LRG &lrg, int chunk ) { } } - uint copy_lrg = Find(lrg._copy_bias); + uint copy_lrg = _lrg_map.find(lrg._copy_bias); if( copy_lrg != 0 ) { // If he has a color, if( !(*(_ifg->_yanked))[copy_lrg] ) { @@ -1423,10 +1578,10 @@ uint PhaseChaitin::Select( ) { void PhaseChaitin::copy_was_spilled( Node *src, Node *dst ) { if( _spilled_once.test(src->_idx) ) { _spilled_once.set(dst->_idx); - lrgs(Find(dst))._was_spilled1 = 1; + lrgs(_lrg_map.find(dst))._was_spilled1 = 1; if( _spilled_twice.test(src->_idx) ) { _spilled_twice.set(dst->_idx); - lrgs(Find(dst))._was_spilled2 = 1; + lrgs(_lrg_map.find(dst))._was_spilled2 = 1; } } } @@ -1471,7 +1626,7 @@ void PhaseChaitin::fixup_spills() { MachNode *mach = n->as_Mach(); inp = mach->operand_index(inp); Node *src = n->in(inp); // Value to load or store - LRG &lrg_cisc = lrgs( Find_const(src) ); + LRG &lrg_cisc = lrgs(_lrg_map.find_const(src)); OptoReg::Name src_reg = lrg_cisc.reg(); // Doubles record the HIGH register of an adjacent pair. src_reg = OptoReg::add(src_reg,1-lrg_cisc.num_regs()); @@ -1554,9 +1709,9 @@ Node *PhaseChaitin::find_base_for_derived( Node **derived_base_map, Node *derive Block *startb = _cfg._bbs[C->top()->_idx]; startb->_nodes.insert(startb->find_node(C->top()), base ); _cfg._bbs.map( base->_idx, startb ); - assert (n2lidx(base) == 0, "should not have LRG yet"); + assert(_lrg_map.live_range_id(base) == 0, "should not have LRG yet"); } - if (n2lidx(base) == 0) { + if (_lrg_map.live_range_id(base) == 0) { new_lrg(base, maxlrg++); } assert(base->in(0) == _cfg._root && @@ -1566,7 +1721,7 @@ Node *PhaseChaitin::find_base_for_derived( Node **derived_base_map, Node *derive } // Check for AddP-related opcodes - if( !derived->is_Phi() ) { + if (!derived->is_Phi()) { assert(derived->as_Mach()->ideal_Opcode() == Op_AddP, err_msg_res("but is: %s", derived->Name())); Node *base = derived->in(AddPNode::Base); derived_base_map[derived->_idx] = base; @@ -1629,9 +1784,9 @@ Node *PhaseChaitin::find_base_for_derived( Node **derived_base_map, Node *derive // base pointer that is live across the Safepoint for oopmap building. The // edge pairs get added in after sfpt->jvmtail()->oopoff(), but are in the // required edge set. -bool PhaseChaitin::stretch_base_pointer_live_ranges( ResourceArea *a ) { +bool PhaseChaitin::stretch_base_pointer_live_ranges(ResourceArea *a) { int must_recompute_live = false; - uint maxlrg = _maxlrg; + uint maxlrg = _lrg_map.max_lrg_id(); Node **derived_base_map = (Node**)a->Amalloc(sizeof(Node*)*C->unique()); memset( derived_base_map, 0, sizeof(Node*)*C->unique() ); @@ -1669,15 +1824,18 @@ bool PhaseChaitin::stretch_base_pointer_live_ranges( ResourceArea *a ) { } // Get value being defined - uint lidx = n2lidx(n); - if( lidx && lidx < _maxlrg /* Ignore the occasional brand-new live range */) { + uint lidx = _lrg_map.live_range_id(n); + // Ignore the occasional brand-new live range + if (lidx && lidx < _lrg_map.max_lrg_id()) { // Remove from live-out set liveout.remove(lidx); // Copies do not define a new value and so do not interfere. // Remove the copies source from the liveout set before interfering. uint idx = n->is_Copy(); - if( idx ) liveout.remove( n2lidx(n->in(idx)) ); + if (idx) { + liveout.remove(_lrg_map.live_range_id(n->in(idx))); + } } // Found a safepoint? @@ -1695,21 +1853,21 @@ bool PhaseChaitin::stretch_base_pointer_live_ranges( ResourceArea *a ) { derived->bottom_type()->make_ptr()->is_ptr()->_offset == 0, "sanity"); // If its an OOP with a non-zero offset, then it is derived. if( tj && tj->_offset != 0 && tj->isa_oop_ptr() ) { - Node *base = find_base_for_derived( derived_base_map, derived, maxlrg ); - assert( base->_idx < _names.Size(), "" ); + Node *base = find_base_for_derived(derived_base_map, derived, maxlrg); + assert(base->_idx < _lrg_map.size(), ""); // Add reaching DEFs of derived pointer and base pointer as a // pair of inputs - n->add_req( derived ); - n->add_req( base ); + n->add_req(derived); + n->add_req(base); // See if the base pointer is already live to this point. // Since I'm working on the SSA form, live-ness amounts to // reaching def's. So if I find the base's live range then // I know the base's def reaches here. - if( (n2lidx(base) >= _maxlrg ||// (Brand new base (hence not live) or - !liveout.member( n2lidx(base) ) ) && // not live) AND - (n2lidx(base) > 0) && // not a constant - _cfg._bbs[base->_idx] != b ) { // base not def'd in blk) + if ((_lrg_map.live_range_id(base) >= _lrg_map.max_lrg_id() || // (Brand new base (hence not live) or + !liveout.member(_lrg_map.live_range_id(base))) && // not live) AND + (_lrg_map.live_range_id(base) > 0) && // not a constant + _cfg._bbs[base->_idx] != b) { // base not def'd in blk) // Base pointer is not currently live. Since I stretched // the base pointer to here and it crosses basic-block // boundaries, the global live info is now incorrect. @@ -1721,11 +1879,12 @@ bool PhaseChaitin::stretch_base_pointer_live_ranges( ResourceArea *a ) { } // End of if found a GC point // Make all inputs live - if( !n->is_Phi() ) { // Phi function uses come from prior block - for( uint k = 1; k < n->req(); k++ ) { - uint lidx = n2lidx(n->in(k)); - if( lidx < _maxlrg ) - liveout.insert( lidx ); + if (!n->is_Phi()) { // Phi function uses come from prior block + for (uint k = 1; k < n->req(); k++) { + uint lidx = _lrg_map.live_range_id(n->in(k)); + if (lidx < _lrg_map.max_lrg_id()) { + liveout.insert(lidx); + } } } @@ -1733,11 +1892,12 @@ bool PhaseChaitin::stretch_base_pointer_live_ranges( ResourceArea *a ) { liveout.clear(); // Free the memory used by liveout. } // End of forall blocks - _maxlrg = maxlrg; + _lrg_map.set_max_lrg_id(maxlrg); // If I created a new live range I need to recompute live - if( maxlrg != _ifg->_maxlrg ) + if (maxlrg != _ifg->_maxlrg) { must_recompute_live = true; + } return must_recompute_live != 0; } @@ -1745,16 +1905,17 @@ bool PhaseChaitin::stretch_base_pointer_live_ranges( ResourceArea *a ) { //------------------------------add_reference---------------------------------- // Extend the node to LRG mapping -void PhaseChaitin::add_reference( const Node *node, const Node *old_node ) { - _names.extend( node->_idx, n2lidx(old_node) ); + +void PhaseChaitin::add_reference(const Node *node, const Node *old_node) { + _lrg_map.extend(node->_idx, _lrg_map.live_range_id(old_node)); } //------------------------------dump------------------------------------------- #ifndef PRODUCT -void PhaseChaitin::dump( const Node *n ) const { - uint r = (n->_idx < _names.Size() ) ? Find_const(n) : 0; +void PhaseChaitin::dump(const Node *n) const { + uint r = (n->_idx < _lrg_map.size()) ? _lrg_map.find_const(n) : 0; tty->print("L%d",r); - if( r && n->Opcode() != Op_Phi ) { + if (r && n->Opcode() != Op_Phi) { if( _node_regs ) { // Got a post-allocation copy of allocation? tty->print("["); OptoReg::Name second = get_reg_second(n); @@ -1775,11 +1936,13 @@ void PhaseChaitin::dump( const Node *n ) const { tty->print("/N%d\t",n->_idx); tty->print("%s === ", n->Name()); uint k; - for( k = 0; k < n->req(); k++) { + for (k = 0; k < n->req(); k++) { Node *m = n->in(k); - if( !m ) tty->print("_ "); + if (!m) { + tty->print("_ "); + } else { - uint r = (m->_idx < _names.Size() ) ? Find_const(m) : 0; + uint r = (m->_idx < _lrg_map.size()) ? _lrg_map.find_const(m) : 0; tty->print("L%d",r); // Data MultiNode's can have projections with no real registers. // Don't die while dumping them. @@ -1810,8 +1973,10 @@ void PhaseChaitin::dump( const Node *n ) const { if( k < n->len() && n->in(k) ) tty->print("| "); for( ; k < n->len(); k++ ) { Node *m = n->in(k); - if( !m ) break; - uint r = (m->_idx < _names.Size() ) ? Find_const(m) : 0; + if(!m) { + break; + } + uint r = (m->_idx < _lrg_map.size()) ? _lrg_map.find_const(m) : 0; tty->print("L%d",r); tty->print("/N%d ",m->_idx); } @@ -1839,7 +2004,7 @@ void PhaseChaitin::dump( const Block * b ) const { tty->print("{"); uint i; while ((i = elements.next()) != 0) { - tty->print("L%d ", Find_const(i)); + tty->print("L%d ", _lrg_map.find_const(i)); } tty->print_cr("}"); } @@ -1863,10 +2028,14 @@ void PhaseChaitin::dump() const { // Dump LRG array tty->print("--- Live RanGe Array ---\n"); - for(uint i2 = 1; i2 < _maxlrg; i2++ ) { + for (uint i2 = 1; i2 < _lrg_map.max_lrg_id(); i2++) { tty->print("L%d: ",i2); - if( i2 < _ifg->_maxlrg ) lrgs(i2).dump( ); - else tty->print_cr("new LRG"); + if (i2 < _ifg->_maxlrg) { + lrgs(i2).dump(); + } + else { + tty->print_cr("new LRG"); + } } tty->print_cr(""); @@ -1939,7 +2108,7 @@ char *PhaseChaitin::dump_register( const Node *n, char *buf ) const { // Post allocation, use direct mappings, no LRG info available print_reg( get_reg_first(n), this, buf ); } else { - uint lidx = Find_const(n); // Grab LRG number + uint lidx = _lrg_map.find_const(n); // Grab LRG number if( !_ifg ) { sprintf(buf,"L%d",lidx); // No register binding yet } else if( !lidx ) { // Special, not allocated value @@ -1968,7 +2137,7 @@ void PhaseChaitin::dump_for_spill_split_recycle() const { if( WizardMode && (PrintCompilation || PrintOpto) ) { // Display which live ranges need to be split and the allocator's state tty->print_cr("Graph-Coloring Iteration %d will split the following live ranges", _trip_cnt); - for( uint bidx = 1; bidx < _maxlrg; bidx++ ) { + for (uint bidx = 1; bidx < _lrg_map.max_lrg_id(); bidx++) { if( lrgs(bidx).alive() && lrgs(bidx).reg() >= LRG::SPILL_REG ) { tty->print("L%d: ", bidx); lrgs(bidx).dump(); @@ -2099,14 +2268,17 @@ void PhaseChaitin::dump_bb( uint pre_order ) const { void PhaseChaitin::dump_lrg( uint lidx, bool defs_only ) const { tty->print_cr("---dump of L%d---",lidx); - if( _ifg ) { - if( lidx >= _maxlrg ) { + if (_ifg) { + if (lidx >= _lrg_map.max_lrg_id()) { tty->print("Attempt to print live range index beyond max live range.\n"); return; } tty->print("L%d: ",lidx); - if( lidx < _ifg->_maxlrg ) lrgs(lidx).dump( ); - else tty->print_cr("new LRG"); + if (lidx < _ifg->_maxlrg) { + lrgs(lidx).dump(); + } else { + tty->print_cr("new LRG"); + } } if( _ifg && lidx < _ifg->_maxlrg) { tty->print("Neighbors: %d - ", _ifg->neighbor_cnt(lidx)); @@ -2121,8 +2293,8 @@ void PhaseChaitin::dump_lrg( uint lidx, bool defs_only ) const { // For all instructions for( uint j = 0; j < b->_nodes.size(); j++ ) { Node *n = b->_nodes[j]; - if( Find_const(n) == lidx ) { - if( !dump_once++ ) { + if (_lrg_map.find_const(n) == lidx) { + if (!dump_once++) { tty->cr(); b->dump_head( &_cfg._bbs ); } @@ -2133,11 +2305,13 @@ void PhaseChaitin::dump_lrg( uint lidx, bool defs_only ) const { uint cnt = n->req(); for( uint k = 1; k < cnt; k++ ) { Node *m = n->in(k); - if (!m) continue; // be robust in the dumper - if( Find_const(m) == lidx ) { - if( !dump_once++ ) { + if (!m) { + continue; // be robust in the dumper + } + if (_lrg_map.find_const(m) == lidx) { + if (!dump_once++) { tty->cr(); - b->dump_head( &_cfg._bbs ); + b->dump_head(&_cfg._bbs); } dump(n); } diff --git a/hotspot/src/share/vm/opto/chaitin.hpp b/hotspot/src/share/vm/opto/chaitin.hpp index fc8010b851e..3455005f330 100644 --- a/hotspot/src/share/vm/opto/chaitin.hpp +++ b/hotspot/src/share/vm/opto/chaitin.hpp @@ -265,18 +265,118 @@ public: int effective_degree( uint lidx ) const; }; -// TEMPORARILY REPLACED WITH COMMAND LINE FLAG +// The LiveRangeMap class is responsible for storing node to live range id mapping. +// Each node is mapped to a live range id (a virtual register). Nodes that are +// not considered for register allocation are given live range id 0. +class LiveRangeMap VALUE_OBJ_CLASS_SPEC { -//// !!!!! Magic Constants need to move into ad file -#ifdef SPARC -//#define FLOAT_PRESSURE 30 /* SFLT_REG_mask.Size() - 1 */ -//#define INT_PRESSURE 23 /* NOTEMP_I_REG_mask.Size() - 1 */ -#define FLOAT_INCREMENT(regs) regs -#else -//#define FLOAT_PRESSURE 6 -//#define INT_PRESSURE 6 -#define FLOAT_INCREMENT(regs) 1 -#endif +private: + + uint _max_lrg_id; + + // Union-find map. Declared as a short for speed. + // Indexed by live-range number, it returns the compacted live-range number + LRG_List _uf_map; + + // Map from Nodes to live ranges + LRG_List _names; + + // Straight out of Tarjan's union-find algorithm + uint find_compress(const Node *node) { + uint lrg_id = find_compress(_names[node->_idx]); + _names.map(node->_idx, lrg_id); + return lrg_id; + } + + uint find_compress(uint lrg); + +public: + + const LRG_List& names() { + return _names; + } + + uint max_lrg_id() const { + return _max_lrg_id; + } + + void set_max_lrg_id(uint max_lrg_id) { + _max_lrg_id = max_lrg_id; + } + + uint size() const { + return _names.Size(); + } + + uint live_range_id(uint idx) const { + return _names[idx]; + } + + uint live_range_id(const Node *node) const { + return _names[node->_idx]; + } + + uint uf_live_range_id(uint lrg_id) const { + return _uf_map[lrg_id]; + } + + void map(uint idx, uint lrg_id) { + _names.map(idx, lrg_id); + } + + void uf_map(uint dst_lrg_id, uint src_lrg_id) { + _uf_map.map(dst_lrg_id, src_lrg_id); + } + + void extend(uint idx, uint lrg_id) { + _names.extend(idx, lrg_id); + } + + void uf_extend(uint dst_lrg_id, uint src_lrg_id) { + _uf_map.extend(dst_lrg_id, src_lrg_id); + } + + LiveRangeMap(uint unique) + : _names(unique) + , _uf_map(unique) + , _max_lrg_id(0) {} + + uint find_id( const Node *n ) { + uint retval = live_range_id(n); + assert(retval == find(n),"Invalid node to lidx mapping"); + return retval; + } + + // Reset the Union-Find map to identity + void reset_uf_map(uint max_lrg_id); + + // Make all Nodes map directly to their final live range; no need for + // the Union-Find mapping after this call. + void compress_uf_map_for_nodes(); + + uint find(uint lidx) { + uint uf_lidx = _uf_map[lidx]; + return (uf_lidx == lidx) ? uf_lidx : find_compress(lidx); + } + + // Convert a Node into a Live Range Index - a lidx + uint find(const Node *node) { + uint lidx = live_range_id(node); + uint uf_lidx = _uf_map[lidx]; + return (uf_lidx == lidx) ? uf_lidx : find_compress(node); + } + + // Like Find above, but no path compress, so bad asymptotic behavior + uint find_const(uint lrg) const; + + // Like Find above, but no path compress, so bad asymptotic behavior + uint find_const(const Node *node) const { + if(node->_idx >= _names.Size()) { + return 0; // not mapped, usual for debug dump + } + return find_const(_names[node->_idx]); + } +}; //------------------------------Chaitin---------------------------------------- // Briggs-Chaitin style allocation, mostly. @@ -286,7 +386,6 @@ class PhaseChaitin : public PhaseRegAlloc { int _trip_cnt; int _alternate; - uint _maxlrg; // Max live range number LRG &lrgs(uint idx) const { return _ifg->lrgs(idx); } PhaseLive *_live; // Liveness, used in the interference graph PhaseIFG *_ifg; // Interference graph (for original chunk) @@ -294,16 +393,6 @@ class PhaseChaitin : public PhaseRegAlloc { VectorSet _spilled_once; // Nodes that have been spilled VectorSet _spilled_twice; // Nodes that have been spilled twice - LRG_List _names; // Map from Nodes to Live RanGes - - // Union-find map. Declared as a short for speed. - // Indexed by live-range number, it returns the compacted live-range number - LRG_List _uf_map; - // Reset the Union-Find map to identity - void reset_uf_map( uint maxlrg ); - // Remove the need for the Union-Find mapping - void compress_uf_map_for_nodes( ); - // Combine the Live Range Indices for these 2 Nodes into a single live // range. Future requests for any Node in either live range will // return the live range index for the combined live range. @@ -322,7 +411,34 @@ class PhaseChaitin : public PhaseRegAlloc { // Helper functions for Split() uint split_DEF( Node *def, Block *b, int loc, uint max, Node **Reachblock, Node **debug_defs, GrowableArray splits, int slidx ); uint split_USE( Node *def, Block *b, Node *use, uint useidx, uint max, bool def_down, bool cisc_sp, GrowableArray splits, int slidx ); - int clone_projs( Block *b, uint idx, Node *con, Node *copy, uint &maxlrg ); + + bool clone_projs(Block *b, uint idx, Node *con, Node *copy, LiveRangeMap &lrg_map) { + bool found_projs = clone_projs_shared(b, idx, con, copy, lrg_map.max_lrg_id()); + + if(found_projs) { + uint max_lrg_id = lrg_map.max_lrg_id(); + lrg_map.set_max_lrg_id(max_lrg_id + 1); + } + + return found_projs; + } + + //------------------------------clone_projs------------------------------------ + // After cloning some rematerialized instruction, clone any MachProj's that + // follow it. Example: Intel zero is XOR, kills flags. Sparc FP constants + // use G3 as an address temp. + bool clone_projs(Block *b, uint idx, Node *con, Node *copy, uint &max_lrg_id) { + bool found_projs = clone_projs_shared(b, idx, con, copy, max_lrg_id); + + if(found_projs) { + max_lrg_id++; + } + + return found_projs; + } + + bool clone_projs_shared(Block *b, uint idx, Node *con, Node *copy, uint max_lrg_id); + Node *split_Rematerialize(Node *def, Block *b, uint insidx, uint &maxlrg, GrowableArray splits, int slidx, uint *lrg2reach, Node **Reachblock, bool walkThru); // True if lidx is used before any real register is def'd in the block @@ -349,20 +465,11 @@ public: PhaseChaitin( uint unique, PhaseCFG &cfg, Matcher &matcher ); ~PhaseChaitin() {} - // Convert a Node into a Live Range Index - a lidx - uint Find( const Node *n ) { - uint lidx = n2lidx(n); - uint uf_lidx = _uf_map[lidx]; - return (uf_lidx == lidx) ? uf_lidx : Find_compress(n); - } - uint Find_const( uint lrg ) const; - uint Find_const( const Node *n ) const; + LiveRangeMap _lrg_map; // Do all the real work of allocate void Register_Allocate(); - uint n2lidx( const Node *n ) const { return _names[n->_idx]; } - float high_frequency_lrg() const { return _high_frequency_lrg; } #ifndef PRODUCT @@ -374,18 +481,6 @@ private: // all inputs to a PhiNode, effectively coalescing live ranges. Insert // copies as needed. void de_ssa(); - uint Find_compress( const Node *n ); - uint Find( uint lidx ) { - uint uf_lidx = _uf_map[lidx]; - return (uf_lidx == lidx) ? uf_lidx : Find_compress(lidx); - } - uint Find_compress( uint lidx ); - - uint Find_id( const Node *n ) { - uint retval = n2lidx(n); - assert(retval == Find(n),"Invalid node to lidx mapping"); - return retval; - } // Add edge between reg and everything in the vector. // Same as _ifg->add_vector(reg,live) EXCEPT use the RegMask diff --git a/hotspot/src/share/vm/opto/coalesce.cpp b/hotspot/src/share/vm/opto/coalesce.cpp index 0811ea061fe..74618fb410c 100644 --- a/hotspot/src/share/vm/opto/coalesce.cpp +++ b/hotspot/src/share/vm/opto/coalesce.cpp @@ -34,160 +34,12 @@ #include "opto/matcher.hpp" #include "opto/regmask.hpp" -//============================================================================= -//------------------------------reset_uf_map----------------------------------- -void PhaseChaitin::reset_uf_map( uint maxlrg ) { - _maxlrg = maxlrg; - // Force the Union-Find mapping to be at least this large - _uf_map.extend(_maxlrg,0); - // Initialize it to be the ID mapping. - for( uint i=0; i<_maxlrg; i++ ) - _uf_map.map(i,i); -} - -//------------------------------compress_uf_map-------------------------------- -// Make all Nodes map directly to their final live range; no need for -// the Union-Find mapping after this call. -void PhaseChaitin::compress_uf_map_for_nodes( ) { - // For all Nodes, compress mapping - uint unique = _names.Size(); - for( uint i=0; i_idx]); - _names.map(n->_idx,lrg); - return lrg; -} - -//------------------------------Find_const------------------------------------- -// Like Find above, but no path compress, so bad asymptotic behavior -uint PhaseChaitin::Find_const( uint lrg ) const { - if( !lrg ) return lrg; // Ignore the zero LRG - // Off the end? This happens during debugging dumps when you got - // brand new live ranges but have not told the allocator yet. - if( lrg >= _maxlrg ) return lrg; - uint next = _uf_map[lrg]; - while( next != lrg ) { // Scan chain of equivalences - assert( next < lrg, "always union smaller" ); - lrg = next; // until find a fixed-point - next = _uf_map[lrg]; - } - return next; -} - -//------------------------------Find------------------------------------------- -// Like Find above, but no path compress, so bad asymptotic behavior -uint PhaseChaitin::Find_const( const Node *n ) const { - if( n->_idx >= _names.Size() ) return 0; // not mapped, usual for debug dump - return Find_const( _names[n->_idx] ); -} - -//------------------------------Union------------------------------------------ -// union 2 sets together. -void PhaseChaitin::Union( const Node *src_n, const Node *dst_n ) { - uint src = Find(src_n); - uint dst = Find(dst_n); - assert( src, "" ); - assert( dst, "" ); - assert( src < _maxlrg, "oob" ); - assert( dst < _maxlrg, "oob" ); - assert( src < dst, "always union smaller" ); - _uf_map.map(dst,src); -} - -//------------------------------new_lrg---------------------------------------- -void PhaseChaitin::new_lrg( const Node *x, uint lrg ) { - // Make the Node->LRG mapping - _names.extend(x->_idx,lrg); - // Make the Union-Find mapping an identity function - _uf_map.extend(lrg,lrg); -} - -//------------------------------clone_projs------------------------------------ -// After cloning some rematerialized instruction, clone any MachProj's that -// follow it. Example: Intel zero is XOR, kills flags. Sparc FP constants -// use G3 as an address temp. -int PhaseChaitin::clone_projs( Block *b, uint idx, Node *con, Node *copy, uint &maxlrg ) { - Block *bcon = _cfg._bbs[con->_idx]; - uint cindex = bcon->find_node(con); - Node *con_next = bcon->_nodes[cindex+1]; - if( con_next->in(0) != con || !con_next->is_MachProj() ) - return false; // No MachProj's follow - - // Copy kills after the cloned constant - Node *kills = con_next->clone(); - kills->set_req( 0, copy ); - b->_nodes.insert( idx, kills ); - _cfg._bbs.map( kills->_idx, b ); - new_lrg( kills, maxlrg++ ); - return true; -} - -//------------------------------compact---------------------------------------- -// Renumber the live ranges to compact them. Makes the IFG smaller. -void PhaseChaitin::compact() { - // Current the _uf_map contains a series of short chains which are headed - // by a self-cycle. All the chains run from big numbers to little numbers. - // The Find() call chases the chains & shortens them for the next Find call. - // We are going to change this structure slightly. Numbers above a moving - // wave 'i' are unchanged. Numbers below 'j' point directly to their - // compacted live range with no further chaining. There are no chains or - // cycles below 'i', so the Find call no longer works. - uint j=1; - uint i; - for( i=1; i < _maxlrg; i++ ) { - uint lr = _uf_map[i]; - // Ignore unallocated live ranges - if( !lr ) continue; - assert( lr <= i, "" ); - _uf_map.map(i, ( lr == i ) ? j++ : _uf_map[lr]); - } - if( false ) // PrintOptoCompactLiveRanges - printf("Compacted %d LRs from %d\n",i-j,i); - // Now change the Node->LR mapping to reflect the compacted names - uint unique = _names.Size(); - for( i=0; iprint("L%d/N%d ",r,n->_idx); } @@ -235,9 +87,9 @@ void PhaseCoalesce::dump() const { //------------------------------combine_these_two------------------------------ // Combine the live ranges def'd by these 2 Nodes. N2 is an input to N1. -void PhaseCoalesce::combine_these_two( Node *n1, Node *n2 ) { - uint lr1 = _phc.Find(n1); - uint lr2 = _phc.Find(n2); +void PhaseCoalesce::combine_these_two(Node *n1, Node *n2) { + uint lr1 = _phc._lrg_map.find(n1); + uint lr2 = _phc._lrg_map.find(n2); if( lr1 != lr2 && // Different live ranges already AND !_phc._ifg->test_edge_sq( lr1, lr2 ) ) { // Do not interfere LRG *lrg1 = &_phc.lrgs(lr1); @@ -306,14 +158,18 @@ void PhaseAggressiveCoalesce::insert_copy_with_overlap( Block *b, Node *copy, ui // I am about to clobber the dst_name, so the copy must be inserted // after the last use. Last use is really first-use on a backwards scan. uint i = b->end_idx()-1; - while( 1 ) { + while(1) { Node *n = b->_nodes[i]; // Check for end of virtual copies; this is also the end of the // parallel renaming effort. - if( n->_idx < _unique ) break; + if (n->_idx < _unique) { + break; + } uint idx = n->is_Copy(); assert( idx || n->is_Con() || n->is_MachProj(), "Only copies during parallel renaming" ); - if( idx && _phc.Find(n->in(idx)) == dst_name ) break; + if (idx && _phc._lrg_map.find(n->in(idx)) == dst_name) { + break; + } i--; } uint last_use_idx = i; @@ -324,24 +180,29 @@ void PhaseAggressiveCoalesce::insert_copy_with_overlap( Block *b, Node *copy, ui // There can be only 1 kill that exits any block and that is // the last kill. Thus it is the first kill on a backwards scan. i = b->end_idx()-1; - while( 1 ) { + while (1) { Node *n = b->_nodes[i]; // Check for end of virtual copies; this is also the end of the // parallel renaming effort. - if( n->_idx < _unique ) break; + if (n->_idx < _unique) { + break; + } assert( n->is_Copy() || n->is_Con() || n->is_MachProj(), "Only copies during parallel renaming" ); - if( _phc.Find(n) == src_name ) { + if (_phc._lrg_map.find(n) == src_name) { kill_src_idx = i; break; } i--; } // Need a temp? Last use of dst comes after the kill of src? - if( last_use_idx >= kill_src_idx ) { + if (last_use_idx >= kill_src_idx) { // Need to break a cycle with a temp uint idx = copy->is_Copy(); Node *tmp = copy->clone(); - _phc.new_lrg(tmp,_phc._maxlrg++); + uint max_lrg_id = _phc._lrg_map.max_lrg_id(); + _phc.new_lrg(tmp, max_lrg_id); + _phc._lrg_map.set_max_lrg_id(max_lrg_id + 1); + // Insert new temp between copy and source tmp ->set_req(idx,copy->in(idx)); copy->set_req(idx,tmp); @@ -359,14 +220,14 @@ void PhaseAggressiveCoalesce::insert_copy_with_overlap( Block *b, Node *copy, ui void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { // We do LRGs compressing and fix a liveout data only here since the other // place in Split() is guarded by the assert which we never hit. - _phc.compress_uf_map_for_nodes(); + _phc._lrg_map.compress_uf_map_for_nodes(); // Fix block's liveout data for compressed live ranges. - for(uint lrg = 1; lrg < _phc._maxlrg; lrg++ ) { - uint compressed_lrg = _phc.Find(lrg); - if( lrg != compressed_lrg ) { - for( uint bidx = 0; bidx < _phc._cfg._num_blocks; bidx++ ) { + for (uint lrg = 1; lrg < _phc._lrg_map.max_lrg_id(); lrg++) { + uint compressed_lrg = _phc._lrg_map.find(lrg); + if (lrg != compressed_lrg) { + for (uint bidx = 0; bidx < _phc._cfg._num_blocks; bidx++) { IndexSet *liveout = _phc._live->live(_phc._cfg._blocks[bidx]); - if( liveout->member(lrg) ) { + if (liveout->member(lrg)) { liveout->remove(lrg); liveout->insert(compressed_lrg); } @@ -392,8 +253,9 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { uint cidx = copy->is_Copy(); if( cidx ) { Node *def = copy->in(cidx); - if( _phc.Find(copy) == _phc.Find(def) ) - n->set_req(k,def); + if (_phc._lrg_map.find(copy) == _phc._lrg_map.find(def)) { + n->set_req(k, def); + } } } @@ -401,7 +263,7 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { uint cidx = n->is_Copy(); if( cidx ) { Node *def = n->in(cidx); - if( _phc.Find(n) == _phc.Find(def) ) { + if (_phc._lrg_map.find(n) == _phc._lrg_map.find(def)) { n->replace_by(def); n->set_req(cidx,NULL); b->_nodes.remove(l); @@ -410,16 +272,18 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { } } - if( n->is_Phi() ) { + if (n->is_Phi()) { // Get the chosen name for the Phi - uint phi_name = _phc.Find( n ); + uint phi_name = _phc._lrg_map.find(n); // Ignore the pre-allocated specials - if( !phi_name ) continue; + if (!phi_name) { + continue; + } // Check for mismatch inputs to Phi - for( uint j = 1; jin(j); - uint src_name = _phc.Find(m); - if( src_name != phi_name ) { + uint src_name = _phc._lrg_map.find(m); + if (src_name != phi_name) { Block *pred = _phc._cfg._bbs[b->pred(j)->_idx]; Node *copy; assert(!m->is_Con() || m->is_Mach(), "all Con must be Mach"); @@ -430,18 +294,18 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { // Insert the copy in the predecessor basic block pred->add_inst(copy); // Copy any flags as well - _phc.clone_projs( pred, pred->end_idx(), m, copy, _phc._maxlrg ); + _phc.clone_projs(pred, pred->end_idx(), m, copy, _phc._lrg_map); } else { const RegMask *rm = C->matcher()->idealreg2spillmask[m->ideal_reg()]; - copy = new (C) MachSpillCopyNode(m,*rm,*rm); + copy = new (C) MachSpillCopyNode(m, *rm, *rm); // Find a good place to insert. Kinda tricky, use a subroutine insert_copy_with_overlap(pred,copy,phi_name,src_name); } // Insert the copy in the use-def chain - n->set_req( j, copy ); + n->set_req(j, copy); _phc._cfg._bbs.map( copy->_idx, pred ); // Extend ("register allocate") the names array for the copy. - _phc._names.extend( copy->_idx, phi_name ); + _phc._lrg_map.extend(copy->_idx, phi_name); } // End of if Phi names do not match } // End of for all inputs to Phi } else { // End of if Phi @@ -450,39 +314,40 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { uint idx; if( n->is_Mach() && (idx=n->as_Mach()->two_adr()) ) { // Get the chosen name for the Node - uint name = _phc.Find( n ); - assert( name, "no 2-address specials" ); + uint name = _phc._lrg_map.find(n); + assert (name, "no 2-address specials"); // Check for name mis-match on the 2-address input Node *m = n->in(idx); - if( _phc.Find(m) != name ) { + if (_phc._lrg_map.find(m) != name) { Node *copy; assert(!m->is_Con() || m->is_Mach(), "all Con must be Mach"); // At this point it is unsafe to extend live ranges (6550579). // Rematerialize only constants as we do for Phi above. - if( m->is_Mach() && m->as_Mach()->is_Con() && - m->as_Mach()->rematerialize() ) { + if(m->is_Mach() && m->as_Mach()->is_Con() && + m->as_Mach()->rematerialize()) { copy = m->clone(); // Insert the copy in the basic block, just before us - b->_nodes.insert( l++, copy ); - if( _phc.clone_projs( b, l, m, copy, _phc._maxlrg ) ) + b->_nodes.insert(l++, copy); + if(_phc.clone_projs(b, l, m, copy, _phc._lrg_map)) { l++; + } } else { const RegMask *rm = C->matcher()->idealreg2spillmask[m->ideal_reg()]; - copy = new (C) MachSpillCopyNode( m, *rm, *rm ); + copy = new (C) MachSpillCopyNode(m, *rm, *rm); // Insert the copy in the basic block, just before us - b->_nodes.insert( l++, copy ); + b->_nodes.insert(l++, copy); } // Insert the copy in the use-def chain - n->set_req(idx, copy ); + n->set_req(idx, copy); // Extend ("register allocate") the names array for the copy. - _phc._names.extend( copy->_idx, name ); + _phc._lrg_map.extend(copy->_idx, name); _phc._cfg._bbs.map( copy->_idx, b ); } } // End of is two-adr // Insert a copy at a debug use for a lrg which has high frequency - if( b->_freq < OPTO_DEBUG_SPLIT_FREQ || b->is_uncommon(_phc._cfg._bbs) ) { + if (b->_freq < OPTO_DEBUG_SPLIT_FREQ || b->is_uncommon(_phc._cfg._bbs)) { // Walk the debug inputs to the node and check for lrg freq JVMState* jvms = n->jvms(); uint debug_start = jvms ? jvms->debug_start() : 999999; @@ -490,9 +355,11 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { for(uint inpidx = debug_start; inpidx < debug_end; inpidx++) { // Do not split monitors; they are only needed for debug table // entries and need no code. - if( jvms->is_monitor_use(inpidx) ) continue; + if (jvms->is_monitor_use(inpidx)) { + continue; + } Node *inp = n->in(inpidx); - uint nidx = _phc.n2lidx(inp); + uint nidx = _phc._lrg_map.live_range_id(inp); LRG &lrg = lrgs(nidx); // If this lrg has a high frequency use/def @@ -519,8 +386,10 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) { // Insert the copy in the basic block, just before us b->_nodes.insert( l++, copy ); // Extend ("register allocate") the names array for the copy. - _phc.new_lrg( copy, _phc._maxlrg++ ); - _phc._cfg._bbs.map( copy->_idx, b ); + uint max_lrg_id = _phc._lrg_map.max_lrg_id(); + _phc.new_lrg(copy, max_lrg_id); + _phc._lrg_map.set_max_lrg_id(max_lrg_id + 1); + _phc._cfg._bbs.map(copy->_idx, b); //tty->print_cr("Split a debug use in Aggressive Coalesce"); } // End of if high frequency use/def } // End of for all debug inputs @@ -583,17 +452,17 @@ void PhaseAggressiveCoalesce::coalesce( Block *b ) { uint idx; // 2-address instructions have a virtual Copy matching their input // to their output - if( n->is_Mach() && (idx = n->as_Mach()->two_adr()) ) { + if (n->is_Mach() && (idx = n->as_Mach()->two_adr())) { MachNode *mach = n->as_Mach(); - combine_these_two( mach, mach->in(idx) ); + combine_these_two(mach, mach->in(idx)); } } // End of for all instructions in block } //============================================================================= //------------------------------PhaseConservativeCoalesce---------------------- -PhaseConservativeCoalesce::PhaseConservativeCoalesce( PhaseChaitin &chaitin ) : PhaseCoalesce(chaitin) { - _ulr.initialize(_phc._maxlrg); +PhaseConservativeCoalesce::PhaseConservativeCoalesce(PhaseChaitin &chaitin) : PhaseCoalesce(chaitin) { + _ulr.initialize(_phc._lrg_map.max_lrg_id()); } //------------------------------verify----------------------------------------- @@ -673,10 +542,14 @@ uint PhaseConservativeCoalesce::compute_separating_interferences(Node *dst_copy, // Else work back one in copy chain prev_copy = prev_copy->in(prev_copy->is_Copy()); } else { // Else collect interferences - uint lidx = _phc.Find(x); + uint lidx = _phc._lrg_map.find(x); // Found another def of live-range being stretched? - if( lidx == lr1 ) return max_juint; - if( lidx == lr2 ) return max_juint; + if(lidx == lr1) { + return max_juint; + } + if(lidx == lr2) { + return max_juint; + } // If we attempt to coalesce across a bound def if( lrgs(lidx).is_bound() ) { @@ -751,33 +624,43 @@ static void record_bias( const PhaseIFG *ifg, int lr1, int lr2 ) { // See if I can coalesce a series of multiple copies together. I need the // final dest copy and the original src copy. They can be the same Node. // Compute the compatible register masks. -bool PhaseConservativeCoalesce::copy_copy( Node *dst_copy, Node *src_copy, Block *b, uint bindex ) { +bool PhaseConservativeCoalesce::copy_copy(Node *dst_copy, Node *src_copy, Block *b, uint bindex) { - if( !dst_copy->is_SpillCopy() ) return false; - if( !src_copy->is_SpillCopy() ) return false; + if (!dst_copy->is_SpillCopy()) { + return false; + } + if (!src_copy->is_SpillCopy()) { + return false; + } Node *src_def = src_copy->in(src_copy->is_Copy()); - uint lr1 = _phc.Find(dst_copy); - uint lr2 = _phc.Find(src_def ); + uint lr1 = _phc._lrg_map.find(dst_copy); + uint lr2 = _phc._lrg_map.find(src_def); // Same live ranges already? - if( lr1 == lr2 ) return false; + if (lr1 == lr2) { + return false; + } // Interfere? - if( _phc._ifg->test_edge_sq( lr1, lr2 ) ) return false; + if (_phc._ifg->test_edge_sq(lr1, lr2)) { + return false; + } // Not an oop->int cast; oop->oop, int->int, AND int->oop are OK. - if( !lrgs(lr1)._is_oop && lrgs(lr2)._is_oop ) // not an oop->int cast + if (!lrgs(lr1)._is_oop && lrgs(lr2)._is_oop) { // not an oop->int cast return false; + } // Coalescing between an aligned live range and a mis-aligned live range? // No, no! Alignment changes how we count degree. - if( lrgs(lr1)._fat_proj != lrgs(lr2)._fat_proj ) + if (lrgs(lr1)._fat_proj != lrgs(lr2)._fat_proj) { return false; + } // Sort; use smaller live-range number Node *lr1_node = dst_copy; Node *lr2_node = src_def; - if( lr1 > lr2 ) { + if (lr1 > lr2) { uint tmp = lr1; lr1 = lr2; lr2 = tmp; lr1_node = src_def; lr2_node = dst_copy; } @@ -916,17 +799,5 @@ void PhaseConservativeCoalesce::coalesce( Block *b ) { PhaseChaitin::_conserv_coalesce++; // Collect stats on success continue; } - - /* do not attempt pairs. About 1/2 of all pairs can be removed by - post-alloc. The other set are too few to bother. - Node *copy2 = copy1->in(idx1); - uint idx2 = copy2->is_Copy(); - if( !idx2 ) continue; - if( copy_copy(copy1,copy2,b,i) ) { - i--; // Retry, same location in block - PhaseChaitin::_conserv_coalesce_pair++; // Collect stats on success - continue; - } - */ } } diff --git a/hotspot/src/share/vm/opto/coalesce.hpp b/hotspot/src/share/vm/opto/coalesce.hpp index 904ce7f679f..a6359af101c 100644 --- a/hotspot/src/share/vm/opto/coalesce.hpp +++ b/hotspot/src/share/vm/opto/coalesce.hpp @@ -41,23 +41,25 @@ protected: public: // Coalesce copies - PhaseCoalesce( PhaseChaitin &chaitin ) : Phase(Coalesce), _phc(chaitin) { } + PhaseCoalesce(PhaseChaitin &phc) + : Phase(Coalesce) + , _phc(phc) {} virtual void verify() = 0; // Coalesce copies - void coalesce_driver( ); + void coalesce_driver(); // Coalesce copies in this block - virtual void coalesce( Block *b ) = 0; + virtual void coalesce(Block *b) = 0; // Attempt to coalesce live ranges defined by these 2 - void combine_these_two( Node *n1, Node *n2 ); + void combine_these_two(Node *n1, Node *n2); - LRG &lrgs( uint lidx ) { return _phc.lrgs(lidx); } + LRG &lrgs(uint lidx) { return _phc.lrgs(lidx); } #ifndef PRODUCT // Dump internally name - void dump( Node *n ) const; + void dump(Node *n) const; // Dump whole shebang void dump() const; #endif diff --git a/hotspot/src/share/vm/opto/compile.cpp b/hotspot/src/share/vm/opto/compile.cpp index 37b4b4cd5c6..dd32b77f7b7 100644 --- a/hotspot/src/share/vm/opto/compile.cpp +++ b/hotspot/src/share/vm/opto/compile.cpp @@ -2127,22 +2127,19 @@ void Compile::Code_Gen() { } NOT_PRODUCT( verify_graph_edges(); ) - PhaseChaitin regalloc(unique(),cfg,m); + PhaseChaitin regalloc(unique(), cfg, m); _regalloc = ®alloc; { TracePhase t2("regalloc", &_t_registerAllocation, true); - // Perform any platform dependent preallocation actions. This is used, - // for example, to avoid taking an implicit null pointer exception - // using the frame pointer on win95. - _regalloc->pd_preallocate_hook(); - // Perform register allocation. After Chaitin, use-def chains are // no longer accurate (at spill code) and so must be ignored. // Node->LRG->reg mappings are still accurate. _regalloc->Register_Allocate(); // Bail out if the allocator builds too many nodes - if (failing()) return; + if (failing()) { + return; + } } // Prior to register allocation we kept empty basic blocks in case the @@ -2160,9 +2157,6 @@ void Compile::Code_Gen() { cfg.fixup_flow(); } - // Perform any platform dependent postallocation verifications. - debug_only( _regalloc->pd_postallocate_verify_hook(); ) - // Apply peephole optimizations if( OptoPeephole ) { NOT_PRODUCT( TracePhase t2("peephole", &_t_peephole, TimeCompiler); ) diff --git a/hotspot/src/share/vm/opto/idealGraphPrinter.cpp b/hotspot/src/share/vm/opto/idealGraphPrinter.cpp index 1f811b8f4b8..e6909054324 100644 --- a/hotspot/src/share/vm/opto/idealGraphPrinter.cpp +++ b/hotspot/src/share/vm/opto/idealGraphPrinter.cpp @@ -616,7 +616,7 @@ void IdealGraphPrinter::visit_node(Node *n, bool edges, VectorSet* temp_set) { buffer[0] = 0; _chaitin->dump_register(node, buffer); print_prop("reg", buffer); - print_prop("lrg", _chaitin->n2lidx(node)); + print_prop("lrg", _chaitin->_lrg_map.live_range_id(node)); } node->_in_dump_cnt--; diff --git a/hotspot/src/share/vm/opto/ifg.cpp b/hotspot/src/share/vm/opto/ifg.cpp index c40265214dc..96c0957cffb 100644 --- a/hotspot/src/share/vm/opto/ifg.cpp +++ b/hotspot/src/share/vm/opto/ifg.cpp @@ -286,15 +286,14 @@ void PhaseIFG::verify( const PhaseChaitin *pc ) const { uint idx; uint last = 0; while ((idx = elements.next()) != 0) { - assert( idx != i, "Must have empty diagonal"); - assert( pc->Find_const(idx) == idx, "Must not need Find" ); - assert( _adjs[idx].member(i), "IFG not square" ); - assert( !(*_yanked)[idx], "No yanked neighbors" ); - assert( last < idx, "not sorted increasing"); + assert(idx != i, "Must have empty diagonal"); + assert(pc->_lrg_map.find_const(idx) == idx, "Must not need Find"); + assert(_adjs[idx].member(i), "IFG not square"); + assert(!(*_yanked)[idx], "No yanked neighbors"); + assert(last < idx, "not sorted increasing"); last = idx; } - assert( !lrgs(i)._degree_valid || - effective_degree(i) == lrgs(i).degree(), "degree is valid but wrong" ); + assert(!lrgs(i)._degree_valid || effective_degree(i) == lrgs(i).degree(), "degree is valid but wrong"); } } #endif @@ -342,10 +341,10 @@ void PhaseChaitin::build_ifg_virtual( ) { Node *n = b->_nodes[j-1]; // Get value being defined - uint r = n2lidx(n); + uint r = _lrg_map.live_range_id(n); // Some special values do not allocate - if( r ) { + if (r) { // Remove from live-out set liveout->remove(r); @@ -353,16 +352,19 @@ void PhaseChaitin::build_ifg_virtual( ) { // Copies do not define a new value and so do not interfere. // Remove the copies source from the liveout set before interfering. uint idx = n->is_Copy(); - if( idx ) liveout->remove( n2lidx(n->in(idx)) ); + if (idx) { + liveout->remove(_lrg_map.live_range_id(n->in(idx))); + } // Interfere with everything live - interfere_with_live( r, liveout ); + interfere_with_live(r, liveout); } // Make all inputs live - if( !n->is_Phi() ) { // Phi function uses come from prior block - for( uint k = 1; k < n->req(); k++ ) - liveout->insert( n2lidx(n->in(k)) ); + if (!n->is_Phi()) { // Phi function uses come from prior block + for(uint k = 1; k < n->req(); k++) { + liveout->insert(_lrg_map.live_range_id(n->in(k))); + } } // 2-address instructions always have the defined value live @@ -394,11 +396,12 @@ void PhaseChaitin::build_ifg_virtual( ) { n->set_req( 2, tmp ); } // Defined value interferes with all inputs - uint lidx = n2lidx(n->in(idx)); - for( uint k = 1; k < n->req(); k++ ) { - uint kidx = n2lidx(n->in(k)); - if( kidx != lidx ) - _ifg->add_edge( r, kidx ); + uint lidx = _lrg_map.live_range_id(n->in(idx)); + for (uint k = 1; k < n->req(); k++) { + uint kidx = _lrg_map.live_range_id(n->in(k)); + if (kidx != lidx) { + _ifg->add_edge(r, kidx); + } } } } // End of forall instructions in block @@ -542,10 +545,10 @@ uint PhaseChaitin::build_ifg_physical( ResourceArea *a ) { Node *n = b->_nodes[j - 1]; // Get value being defined - uint r = n2lidx(n); + uint r = _lrg_map.live_range_id(n); // Some special values do not allocate - if( r ) { + if(r) { // A DEF normally costs block frequency; rematerialized values are // removed from the DEF sight, so LOWER costs here. lrgs(r)._cost += n->rematerialize() ? 0 : b->_freq; @@ -556,9 +559,11 @@ uint PhaseChaitin::build_ifg_physical( ResourceArea *a ) { Node *def = n->in(0); if( !n->is_Proj() || // Could also be a flags-projection of a dead ADD or such. - (n2lidx(def) && !liveout.member(n2lidx(def)) ) ) { + (_lrg_map.live_range_id(def) && !liveout.member(_lrg_map.live_range_id(def)))) { b->_nodes.remove(j - 1); - if( lrgs(r)._def == n ) lrgs(r)._def = 0; + if (lrgs(r)._def == n) { + lrgs(r)._def = 0; + } n->disconnect_inputs(NULL, C); _cfg._bbs.map(n->_idx,NULL); n->replace_by(C->top()); @@ -570,7 +575,7 @@ uint PhaseChaitin::build_ifg_physical( ResourceArea *a ) { // Fat-projections kill many registers which cannot be used to // hold live ranges. - if( lrgs(r)._fat_proj ) { + if (lrgs(r)._fat_proj) { // Count the int-only registers RegMask itmp = lrgs(r).mask(); itmp.AND(*Matcher::idealreg2regmask[Op_RegI]); @@ -636,12 +641,12 @@ uint PhaseChaitin::build_ifg_physical( ResourceArea *a ) { // Copies do not define a new value and so do not interfere. // Remove the copies source from the liveout set before interfering. uint idx = n->is_Copy(); - if( idx ) { - uint x = n2lidx(n->in(idx)); - if( liveout.remove( x ) ) { + if (idx) { + uint x = _lrg_map.live_range_id(n->in(idx)); + if (liveout.remove(x)) { lrgs(x)._area -= cost; // Adjust register pressure. - lower_pressure( &lrgs(x), j-1, b, pressure, hrp_index ); + lower_pressure(&lrgs(x), j-1, b, pressure, hrp_index); assert( pressure[0] == count_int_pressure (&liveout), "" ); assert( pressure[1] == count_float_pressure(&liveout), "" ); } @@ -727,18 +732,21 @@ uint PhaseChaitin::build_ifg_physical( ResourceArea *a ) { // the flags and assumes it's dead. This keeps the (useless) // flag-setting behavior alive while also keeping the (useful) // memory update effect. - for( uint k = ((n->Opcode() == Op_SCMemProj) ? 0:1); k < n->req(); k++ ) { + for (uint k = ((n->Opcode() == Op_SCMemProj) ? 0:1); k < n->req(); k++) { Node *def = n->in(k); - uint x = n2lidx(def); - if( !x ) continue; + uint x = _lrg_map.live_range_id(def); + if (!x) { + continue; + } LRG &lrg = lrgs(x); // No use-side cost for spilling debug info - if( k < debug_start ) + if (k < debug_start) { // A USE costs twice block frequency (once for the Load, once // for a Load-delay). Rematerialized uses only cost once. lrg._cost += (def->rematerialize() ? b->_freq : (b->_freq + b->_freq)); + } // It is live now - if( liveout.insert( x ) ) { + if (liveout.insert(x)) { // Newly live things assumed live from here to top of block lrg._area += cost; // Adjust register pressure diff --git a/hotspot/src/share/vm/opto/live.cpp b/hotspot/src/share/vm/opto/live.cpp index 5da41891583..773dd1ea2e6 100644 --- a/hotspot/src/share/vm/opto/live.cpp +++ b/hotspot/src/share/vm/opto/live.cpp @@ -44,7 +44,7 @@ // block is put on the worklist. // The locally live-in stuff is computed once and added to predecessor // live-out sets. This separate compilation is done in the outer loop below. -PhaseLive::PhaseLive( const PhaseCFG &cfg, LRG_List &names, Arena *arena ) : Phase(LIVE), _cfg(cfg), _names(names), _arena(arena), _live(0) { +PhaseLive::PhaseLive( const PhaseCFG &cfg, const LRG_List &names, Arena *arena ) : Phase(LIVE), _cfg(cfg), _names(names), _arena(arena), _live(0) { } void PhaseLive::compute(uint maxlrg) { diff --git a/hotspot/src/share/vm/opto/live.hpp b/hotspot/src/share/vm/opto/live.hpp index 8a266c19067..c2ebe758cf8 100644 --- a/hotspot/src/share/vm/opto/live.hpp +++ b/hotspot/src/share/vm/opto/live.hpp @@ -80,7 +80,7 @@ class PhaseLive : public Phase { Block_List *_worklist; // Worklist for iterative solution const PhaseCFG &_cfg; // Basic blocks - LRG_List &_names; // Mapping from Nodes to live ranges + const LRG_List &_names; // Mapping from Nodes to live ranges uint _maxlrg; // Largest live-range number Arena *_arena; @@ -91,7 +91,7 @@ class PhaseLive : public Phase { void add_liveout( Block *p, IndexSet *lo, VectorSet &first_pass ); public: - PhaseLive( const PhaseCFG &cfg, LRG_List &names, Arena *arena ); + PhaseLive(const PhaseCFG &cfg, const LRG_List &names, Arena *arena); ~PhaseLive() {} // Compute liveness info void compute(uint maxlrg); diff --git a/hotspot/src/share/vm/opto/postaloc.cpp b/hotspot/src/share/vm/opto/postaloc.cpp index a27145b5c7b..c1b3fdbd231 100644 --- a/hotspot/src/share/vm/opto/postaloc.cpp +++ b/hotspot/src/share/vm/opto/postaloc.cpp @@ -56,7 +56,7 @@ bool PhaseChaitin::may_be_copy_of_callee( Node *def ) const { int i; for( i=0; i < limit; i++ ) { if( def->is_Proj() && def->in(0)->is_Start() && - _matcher.is_save_on_entry(lrgs(n2lidx(def)).reg()) ) + _matcher.is_save_on_entry(lrgs(_lrg_map.live_range_id(def)).reg())) return true; // Direct use of callee-save proj if( def->is_Copy() ) // Copies carry value through def = def->in(def->is_Copy()); @@ -83,7 +83,7 @@ int PhaseChaitin::yank( Node *old, Block *current_block, Node_List *value, Node_ // Count 1 if deleting an instruction from the current block if( oldb == current_block ) blk_adjust++; _cfg._bbs.map(old->_idx,NULL); - OptoReg::Name old_reg = lrgs(n2lidx(old)).reg(); + OptoReg::Name old_reg = lrgs(_lrg_map.live_range_id(old)).reg(); if( regnd && (*regnd)[old_reg]==old ) { // Instruction is currently available? value->map(old_reg,NULL); // Yank from value/regnd maps regnd->map(old_reg,NULL); // This register's value is now unknown @@ -164,7 +164,7 @@ int PhaseChaitin::use_prior_register( Node *n, uint idx, Node *def, Block *curre // Not every pair of physical registers are assignment compatible, // e.g. on sparc floating point registers are not assignable to integer // registers. - const LRG &def_lrg = lrgs(n2lidx(def)); + const LRG &def_lrg = lrgs(_lrg_map.live_range_id(def)); OptoReg::Name def_reg = def_lrg.reg(); const RegMask &use_mask = n->in_RegMask(idx); bool can_use = ( RegMask::can_represent(def_reg) ? (use_mask.Member(def_reg) != 0) @@ -209,11 +209,12 @@ int PhaseChaitin::use_prior_register( Node *n, uint idx, Node *def, Block *curre // Skip through any number of copies (that don't mod oop-i-ness) Node *PhaseChaitin::skip_copies( Node *c ) { int idx = c->is_Copy(); - uint is_oop = lrgs(n2lidx(c))._is_oop; + uint is_oop = lrgs(_lrg_map.live_range_id(c))._is_oop; while (idx != 0) { guarantee(c->in(idx) != NULL, "must not resurrect dead copy"); - if (lrgs(n2lidx(c->in(idx)))._is_oop != is_oop) + if (lrgs(_lrg_map.live_range_id(c->in(idx)))._is_oop != is_oop) { break; // casting copy, not the same value + } c = c->in(idx); idx = c->is_Copy(); } @@ -225,8 +226,8 @@ Node *PhaseChaitin::skip_copies( Node *c ) { int PhaseChaitin::elide_copy( Node *n, int k, Block *current_block, Node_List &value, Node_List ®nd, bool can_change_regs ) { int blk_adjust = 0; - uint nk_idx = n2lidx(n->in(k)); - OptoReg::Name nk_reg = lrgs(nk_idx ).reg(); + uint nk_idx = _lrg_map.live_range_id(n->in(k)); + OptoReg::Name nk_reg = lrgs(nk_idx).reg(); // Remove obvious same-register copies Node *x = n->in(k); @@ -234,9 +235,13 @@ int PhaseChaitin::elide_copy( Node *n, int k, Block *current_block, Node_List &v while( (idx=x->is_Copy()) != 0 ) { Node *copy = x->in(idx); guarantee(copy != NULL, "must not resurrect dead copy"); - if( lrgs(n2lidx(copy)).reg() != nk_reg ) break; + if(lrgs(_lrg_map.live_range_id(copy)).reg() != nk_reg) { + break; + } blk_adjust += use_prior_register(n,k,copy,current_block,value,regnd); - if( n->in(k) != copy ) break; // Failed for some cutout? + if (n->in(k) != copy) { + break; // Failed for some cutout? + } x = copy; // Progress, try again } @@ -256,7 +261,7 @@ int PhaseChaitin::elide_copy( Node *n, int k, Block *current_block, Node_List &v if (val == x && nk_idx != 0 && regnd[nk_reg] != NULL && regnd[nk_reg] != x && - n2lidx(x) == n2lidx(regnd[nk_reg])) { + _lrg_map.live_range_id(x) == _lrg_map.live_range_id(regnd[nk_reg])) { // When rematerialzing nodes and stretching lifetimes, the // allocator will reuse the original def for multidef LRG instead // of the current reaching def because it can't know it's safe to @@ -270,7 +275,7 @@ int PhaseChaitin::elide_copy( Node *n, int k, Block *current_block, Node_List &v if (val == x) return blk_adjust; // No progress? int n_regs = RegMask::num_registers(val->ideal_reg()); - uint val_idx = n2lidx(val); + uint val_idx = _lrg_map.live_range_id(val); OptoReg::Name val_reg = lrgs(val_idx).reg(); // See if it happens to already be in the correct register! @@ -499,12 +504,12 @@ void PhaseChaitin::post_allocate_copy_removal() { for( j = 1; j < phi_dex; j++ ) { uint k; Node *phi = b->_nodes[j]; - uint pidx = n2lidx(phi); - OptoReg::Name preg = lrgs(n2lidx(phi)).reg(); + uint pidx = _lrg_map.live_range_id(phi); + OptoReg::Name preg = lrgs(_lrg_map.live_range_id(phi)).reg(); // Remove copies remaining on edges. Check for junk phi. Node *u = NULL; - for( k=1; kreq(); k++ ) { + for (k = 1; k < phi->req(); k++) { Node *x = phi->in(k); if( phi != x && u != x ) // Found a different input u = u ? NodeSentinel : x; // Capture unique input, or NodeSentinel for 2nd input @@ -555,10 +560,10 @@ void PhaseChaitin::post_allocate_copy_removal() { // alive and well at the use (or else the allocator fubar'd). Take // advantage of this info to set a reaching def for the use-reg. uint k; - for( k = 1; k < n->req(); k++ ) { + for (k = 1; k < n->req(); k++) { Node *def = n->in(k); // n->in(k) is a USE; def is the DEF for this USE guarantee(def != NULL, "no disconnected nodes at this point"); - uint useidx = n2lidx(def); // useidx is the live range index for this USE + uint useidx = _lrg_map.live_range_id(def); // useidx is the live range index for this USE if( useidx ) { OptoReg::Name ureg = lrgs(useidx).reg(); @@ -566,7 +571,7 @@ void PhaseChaitin::post_allocate_copy_removal() { int idx; // Skip occasional useless copy while( (idx=def->is_Copy()) != 0 && def->in(idx) != NULL && // NULL should not happen - ureg == lrgs(n2lidx(def->in(idx))).reg() ) + ureg == lrgs(_lrg_map.live_range_id(def->in(idx))).reg()) def = def->in(idx); Node *valdef = skip_copies(def); // tighten up val through non-useless copies value.map(ureg,valdef); // record improved reaching-def info @@ -594,8 +599,10 @@ void PhaseChaitin::post_allocate_copy_removal() { j -= elide_copy( n, k, b, value, regnd, two_adr!=k ); // Unallocated Nodes define no registers - uint lidx = n2lidx(n); - if( !lidx ) continue; + uint lidx = _lrg_map.live_range_id(n); + if (!lidx) { + continue; + } // Update the register defined by this instruction OptoReg::Name nreg = lrgs(lidx).reg(); diff --git a/hotspot/src/share/vm/opto/reg_split.cpp b/hotspot/src/share/vm/opto/reg_split.cpp index 1695dee6008..edd614987ea 100644 --- a/hotspot/src/share/vm/opto/reg_split.cpp +++ b/hotspot/src/share/vm/opto/reg_split.cpp @@ -318,9 +318,13 @@ Node *PhaseChaitin::split_Rematerialize( Node *def, Block *b, uint insidx, uint for( uint i = 1; i < def->req(); i++ ) { Node *in = def->in(i); // Check for single-def (LRG cannot redefined) - uint lidx = n2lidx(in); - if( lidx >= _maxlrg ) continue; // Value is a recent spill-copy - if (lrgs(lidx).is_singledef()) continue; + uint lidx = _lrg_map.live_range_id(in); + if (lidx >= _lrg_map.max_lrg_id()) { + continue; // Value is a recent spill-copy + } + if (lrgs(lidx).is_singledef()) { + continue; + } Block *b_def = _cfg._bbs[def->_idx]; int idx_def = b_def->find_node(def); @@ -344,26 +348,28 @@ Node *PhaseChaitin::split_Rematerialize( Node *def, Block *b, uint insidx, uint if( spill->req() > 1 ) { for( uint i = 1; i < spill->req(); i++ ) { Node *in = spill->in(i); - uint lidx = Find_id(in); + uint lidx = _lrg_map.find_id(in); // Walk backwards thru spill copy node intermediates if (walkThru) { - while ( in->is_SpillCopy() && lidx >= _maxlrg ) { + while (in->is_SpillCopy() && lidx >= _lrg_map.max_lrg_id()) { in = in->in(1); - lidx = Find_id(in); + lidx = _lrg_map.find_id(in); } - if (lidx < _maxlrg && lrgs(lidx).is_multidef()) { + if (lidx < _lrg_map.max_lrg_id() && lrgs(lidx).is_multidef()) { // walkThru found a multidef LRG, which is unsafe to use, so // just keep the original def used in the clone. in = spill->in(i); - lidx = Find_id(in); + lidx = _lrg_map.find_id(in); } } - if( lidx < _maxlrg && lrgs(lidx).reg() >= LRG::SPILL_REG ) { + if (lidx < _lrg_map.max_lrg_id() && lrgs(lidx).reg() >= LRG::SPILL_REG) { Node *rdef = Reachblock[lrg2reach[lidx]]; - if( rdef ) spill->set_req(i,rdef); + if (rdef) { + spill->set_req(i, rdef); + } } } } @@ -382,7 +388,7 @@ Node *PhaseChaitin::split_Rematerialize( Node *def, Block *b, uint insidx, uint #endif // See if the cloned def kills any flags, and copy those kills as well uint i = insidx+1; - if( clone_projs( b, i, def, spill, maxlrg ) ) { + if( clone_projs( b, i, def, spill, maxlrg) ) { // Adjust the point where we go hi-pressure if( i <= b->_ihrp_index ) b->_ihrp_index++; if( i <= b->_fhrp_index ) b->_fhrp_index++; @@ -424,17 +430,25 @@ bool PhaseChaitin::is_high_pressure( Block *b, LRG *lrg, uint insidx ) { //------------------------------prompt_use--------------------------------- // True if lidx is used before any real register is def'd in the block bool PhaseChaitin::prompt_use( Block *b, uint lidx ) { - if( lrgs(lidx)._was_spilled2 ) return false; + if (lrgs(lidx)._was_spilled2) { + return false; + } // Scan block for 1st use. for( uint i = 1; i <= b->end_idx(); i++ ) { Node *n = b->_nodes[i]; // Ignore PHI use, these can be up or down - if( n->is_Phi() ) continue; - for( uint j = 1; j < n->req(); j++ ) - if( Find_id(n->in(j)) == lidx ) + if (n->is_Phi()) { + continue; + } + for (uint j = 1; j < n->req(); j++) { + if (_lrg_map.find_id(n->in(j)) == lidx) { return true; // Found 1st use! - if( n->out_RegMask().is_NotEmpty() ) return false; + } + } + if (n->out_RegMask().is_NotEmpty()) { + return false; + } } return false; } @@ -464,23 +478,23 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { bool u1, u2, u3; Block *b, *pred; PhiNode *phi; - GrowableArray lidxs(split_arena, _maxlrg, 0, 0); + GrowableArray lidxs(split_arena, maxlrg, 0, 0); // Array of counters to count splits per live range - GrowableArray splits(split_arena, _maxlrg, 0, 0); + GrowableArray splits(split_arena, maxlrg, 0, 0); #define NEW_SPLIT_ARRAY(type, size)\ (type*) split_arena->allocate_bytes((size) * sizeof(type)) //----------Setup Code---------- // Create a convenient mapping from lrg numbers to reaches/leaves indices - uint *lrg2reach = NEW_SPLIT_ARRAY( uint, _maxlrg ); + uint *lrg2reach = NEW_SPLIT_ARRAY(uint, maxlrg); // Keep track of DEFS & Phis for later passes defs = new Node_List(); phis = new Node_List(); // Gather info on which LRG's are spilling, and build maps - for( bidx = 1; bidx < _maxlrg; bidx++ ) { - if( lrgs(bidx).alive() && lrgs(bidx).reg() >= LRG::SPILL_REG ) { + for (bidx = 1; bidx < maxlrg; bidx++) { + if (lrgs(bidx).alive() && lrgs(bidx).reg() >= LRG::SPILL_REG) { assert(!lrgs(bidx).mask().is_AllStack(),"AllStack should color"); lrg2reach[bidx] = spill_cnt; spill_cnt++; @@ -629,7 +643,7 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { break; } // must be looking at a phi - if( Find_id(n1) == lidxs.at(slidx) ) { + if (_lrg_map.find_id(n1) == lidxs.at(slidx)) { // found the necessary phi needs_phi = false; has_phi = true; @@ -651,11 +665,11 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { Reachblock[slidx] = phi; // add node to block & node_to_block mapping - insert_proj( b, insidx++, phi, maxlrg++ ); + insert_proj(b, insidx++, phi, maxlrg++); non_phi++; // Reset new phi's mapping to be the spilling live range - _names.map(phi->_idx, lidx); - assert(Find_id(phi) == lidx,"Bad update on Union-Find mapping"); + _lrg_map.map(phi->_idx, lidx); + assert(_lrg_map.find_id(phi) == lidx, "Bad update on Union-Find mapping"); } // end if not found correct phi // Here you have either found or created the Phi, so record it assert(phi != NULL,"Must have a Phi Node here"); @@ -721,12 +735,12 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { for( insidx = 1; insidx <= b->end_idx(); insidx++ ) { Node *n = b->_nodes[insidx]; // Find the defining Node's live range index - uint defidx = Find_id(n); + uint defidx = _lrg_map.find_id(n); uint cnt = n->req(); - if( n->is_Phi() ) { + if (n->is_Phi()) { // Skip phi nodes after removing dead copies. - if( defidx < _maxlrg ) { + if (defidx < _lrg_map.max_lrg_id()) { // Check for useless Phis. These appear if we spill, then // coalesce away copies. Dont touch Phis in spilling live // ranges; they are busy getting modifed in this pass. @@ -744,8 +758,8 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { } } assert( u, "at least 1 valid input expected" ); - if( i >= cnt ) { // Found one unique input - assert(Find_id(n) == Find_id(u), "should be the same lrg"); + if (i >= cnt) { // Found one unique input + assert(_lrg_map.find_id(n) == _lrg_map.find_id(u), "should be the same lrg"); n->replace_by(u); // Then replace with unique input n->disconnect_inputs(NULL, C); b->_nodes.remove(insidx); @@ -793,16 +807,24 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { while( insert_point > 0 ) { Node *n = b->_nodes[insert_point]; // Hit top of block? Quit going backwards - if( n->is_Phi() ) break; + if (n->is_Phi()) { + break; + } // Found a def? Better split after it. - if( n2lidx(n) == lidx ) break; + if (_lrg_map.live_range_id(n) == lidx) { + break; + } // Look for a use uint i; - for( i = 1; i < n->req(); i++ ) - if( n2lidx(n->in(i)) == lidx ) + for( i = 1; i < n->req(); i++ ) { + if (_lrg_map.live_range_id(n->in(i)) == lidx) { break; + } + } // Found a use? Better split after it. - if( i < n->req() ) break; + if (i < n->req()) { + break; + } insert_point--; } uint orig_eidx = b->end_idx(); @@ -812,8 +834,9 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { return 0; } // Spill of NULL check mem op goes into the following block. - if (b->end_idx() > orig_eidx) + if (b->end_idx() > orig_eidx) { insidx++; + } } // This is a new DEF, so update UP UPblock[slidx] = false; @@ -832,13 +855,13 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { } // end if crossing HRP Boundry // If the LRG index is oob, then this is a new spillcopy, skip it. - if( defidx >= _maxlrg ) { + if (defidx >= _lrg_map.max_lrg_id()) { continue; } LRG &deflrg = lrgs(defidx); uint copyidx = n->is_Copy(); // Remove coalesced copy from CFG - if( copyidx && defidx == n2lidx(n->in(copyidx)) ) { + if (copyidx && defidx == _lrg_map.live_range_id(n->in(copyidx))) { n->replace_by( n->in(copyidx) ); n->set_req( copyidx, NULL ); b->_nodes.remove(insidx--); @@ -864,13 +887,13 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { // If inpidx > old_last, then one of these new inputs is being // handled. Skip the derived part of the pair, but process // the base like any other input. - if( inpidx > old_last && ((inpidx - oopoff) & 1) == DERIVED ) { + if (inpidx > old_last && ((inpidx - oopoff) & 1) == DERIVED) { continue; // skip derived_debug added below } // Get lidx of input - uint useidx = Find_id(n->in(inpidx)); + uint useidx = _lrg_map.find_id(n->in(inpidx)); // Not a brand-new split, and it is a spill use - if( useidx < _maxlrg && lrgs(useidx).reg() >= LRG::SPILL_REG ) { + if (useidx < _lrg_map.max_lrg_id() && lrgs(useidx).reg() >= LRG::SPILL_REG) { // Check for valid reaching DEF slidx = lrg2reach[useidx]; Node *def = Reachblock[slidx]; @@ -886,7 +909,7 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { if (def == NULL || C->check_node_count(NodeLimitFudgeFactor, out_of_nodes)) { return 0; } - _names.extend(def->_idx,0); + _lrg_map.extend(def->_idx, 0); _cfg._bbs.map(def->_idx,b); n->set_req(inpidx, def); continue; @@ -1186,10 +1209,10 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { // ********** Split Left Over Mem-Mem Moves ********** // Check for mem-mem copies and split them now. Do not do this // to copies about to be spilled; they will be Split shortly. - if( copyidx ) { + if (copyidx) { Node *use = n->in(copyidx); - uint useidx = Find_id(use); - if( useidx < _maxlrg && // This is not a new split + uint useidx = _lrg_map.find_id(use); + if (useidx < _lrg_map.max_lrg_id() && // This is not a new split OptoReg::is_stack(deflrg.reg()) && deflrg.reg() < LRG::SPILL_REG ) { // And DEF is from stack LRG &uselrg = lrgs(useidx); @@ -1228,7 +1251,7 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { uint member; IndexSetIterator isi(liveout); while ((member = isi.next()) != 0) { - assert(defidx != Find_const(member), "Live out member has not been compressed"); + assert(defidx != _lrg_map.find_const(member), "Live out member has not been compressed"); } #endif Reachblock[slidx] = NULL; @@ -1261,7 +1284,7 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { assert(phi->is_Phi(),"This list must only contain Phi Nodes"); Block *b = _cfg._bbs[phi->_idx]; // Grab the live range number - uint lidx = Find_id(phi); + uint lidx = _lrg_map.find_id(phi); uint slidx = lrg2reach[lidx]; // Update node to lidx map new_lrg(phi, maxlrg++); @@ -1296,11 +1319,13 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { int insert = pred->end_idx(); while (insert >= 1 && pred->_nodes[insert - 1]->is_SpillCopy() && - Find(pred->_nodes[insert - 1]) >= lrgs_before_phi_split) { + _lrg_map.find(pred->_nodes[insert - 1]) >= lrgs_before_phi_split) { insert--; } - def = split_Rematerialize( def, pred, insert, maxlrg, splits, slidx, lrg2reach, Reachblock, false ); - if( !def ) return 0; // Bail out + def = split_Rematerialize(def, pred, insert, maxlrg, splits, slidx, lrg2reach, Reachblock, false); + if (!def) { + return 0; // Bail out + } } // Update the Phi's input edge array phi->set_req(i,def); @@ -1316,7 +1341,7 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { } // End for all inputs to the Phi } // End for all Phi Nodes // Update _maxlrg to save Union asserts - _maxlrg = maxlrg; + _lrg_map.set_max_lrg_id(maxlrg); //----------PASS 3---------- @@ -1328,47 +1353,51 @@ uint PhaseChaitin::Split(uint maxlrg, ResourceArea* split_arena) { for( uint i = 1; i < phi->req(); i++ ) { // Grab the input node Node *n = phi->in(i); - assert( n, "" ); - uint lidx = Find(n); - uint pidx = Find(phi); - if( lidx < pidx ) + assert(n, "node should exist"); + uint lidx = _lrg_map.find(n); + uint pidx = _lrg_map.find(phi); + if (lidx < pidx) { Union(n, phi); - else if( lidx > pidx ) + } + else if(lidx > pidx) { Union(phi, n); + } } // End for all inputs to the Phi Node } // End for all Phi Nodes // Now union all two address instructions - for( insidx = 0; insidx < defs->size(); insidx++ ) { + for (insidx = 0; insidx < defs->size(); insidx++) { // Grab the def n1 = defs->at(insidx); // Set new lidx for DEF & handle 2-addr instructions - if( n1->is_Mach() && ((twoidx = n1->as_Mach()->two_adr()) != 0) ) { - assert( Find(n1->in(twoidx)) < maxlrg,"Assigning bad live range index"); + if (n1->is_Mach() && ((twoidx = n1->as_Mach()->two_adr()) != 0)) { + assert(_lrg_map.find(n1->in(twoidx)) < maxlrg,"Assigning bad live range index"); // Union the input and output live ranges - uint lr1 = Find(n1); - uint lr2 = Find(n1->in(twoidx)); - if( lr1 < lr2 ) + uint lr1 = _lrg_map.find(n1); + uint lr2 = _lrg_map.find(n1->in(twoidx)); + if (lr1 < lr2) { Union(n1, n1->in(twoidx)); - else if( lr1 > lr2 ) + } + else if (lr1 > lr2) { Union(n1->in(twoidx), n1); + } } // End if two address } // End for all defs // DEBUG #ifdef ASSERT // Validate all live range index assignments - for( bidx = 0; bidx < _cfg._num_blocks; bidx++ ) { + for (bidx = 0; bidx < _cfg._num_blocks; bidx++) { b = _cfg._blocks[bidx]; - for( insidx = 0; insidx <= b->end_idx(); insidx++ ) { + for (insidx = 0; insidx <= b->end_idx(); insidx++) { Node *n = b->_nodes[insidx]; - uint defidx = Find(n); - assert(defidx < _maxlrg,"Bad live range index in Split"); + uint defidx = _lrg_map.find(n); + assert(defidx < _lrg_map.max_lrg_id(), "Bad live range index in Split"); assert(defidx < maxlrg,"Bad live range index in Split"); } } // Issue a warning if splitting made no progress int noprogress = 0; - for( slidx = 0; slidx < spill_cnt; slidx++ ) { - if( PrintOpto && WizardMode && splits.at(slidx) == 0 ) { + for (slidx = 0; slidx < spill_cnt; slidx++) { + if (PrintOpto && WizardMode && splits.at(slidx) == 0) { tty->print_cr("Failed to split live range %d", lidxs.at(slidx)); //BREAKPOINT; } diff --git a/hotspot/src/share/vm/opto/regalloc.hpp b/hotspot/src/share/vm/opto/regalloc.hpp index d0a993e57c4..9bea94be5de 100644 --- a/hotspot/src/share/vm/opto/regalloc.hpp +++ b/hotspot/src/share/vm/opto/regalloc.hpp @@ -113,7 +113,7 @@ public: OptoReg::Name offset2reg( int stk_offset ) const; // Get the register encoding associated with the Node - int get_encode( const Node *n ) const { + int get_encode(const Node *n) const { assert( n->_idx < _node_regs_max_index, "Exceeded _node_regs array"); OptoReg::Name first = _node_regs[n->_idx].first(); OptoReg::Name second = _node_regs[n->_idx].second(); @@ -122,15 +122,6 @@ public: return Matcher::_regEncode[first]; } - // Platform dependent hook for actions prior to allocation - void pd_preallocate_hook(); - -#ifdef ASSERT - // Platform dependent hook for verification after allocation. Will - // only get called when compiling with asserts. - void pd_postallocate_verify_hook(); -#endif - #ifndef PRODUCT static int _total_framesize; static int _max_framesize; diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index b00f6825ddd..fff9a6180ae 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -1115,7 +1115,6 @@ typedef BinaryTreeDictionary MetablockTreeDictionary; c2_nonstatic_field(PhaseChaitin, _lo_stk_degree, uint) \ c2_nonstatic_field(PhaseChaitin, _hi_degree, uint) \ c2_nonstatic_field(PhaseChaitin, _simplified, uint) \ - c2_nonstatic_field(PhaseChaitin, _maxlrg, uint) \ \ c2_nonstatic_field(Block, _nodes, Node_List) \ c2_nonstatic_field(Block, _succs, Block_Array) \ From 33e3f6b59bc4fe0b908e150639661ffc7defe02a Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Tue, 16 Apr 2013 10:04:01 -0700 Subject: [PATCH 13/50] 8011971: WB API doesn't accept j.l.reflect.Constructor Reviewed-by: kvn, vlivanov --- hotspot/src/share/vm/prims/whitebox.cpp | 24 +- .../whitebox/ClearMethodStateTest.java | 53 ++-- .../whitebox/CompilerWhiteBoxTest.java | 262 +++++++++++++++--- .../compiler/whitebox/DeoptimizeAllTest.java | 24 +- .../whitebox/DeoptimizeMethodTest.java | 26 +- .../EnqueueMethodForCompilationTest.java | 64 +++-- .../whitebox/IsMethodCompilableTest.java | 73 +++-- .../whitebox/MakeMethodNotCompilableTest.java | 83 +++++- .../whitebox/SetDontInlineMethodTest.java | 36 ++- .../whitebox/SetForceInlineMethodTest.java | 36 ++- .../whitebox/sun/hotspot/WhiteBox.java | 29 +- 11 files changed, 535 insertions(+), 175 deletions(-) diff --git a/hotspot/src/share/vm/prims/whitebox.cpp b/hotspot/src/share/vm/prims/whitebox.cpp index 1dfcd3d39a4..36733b2b646 100644 --- a/hotspot/src/share/vm/prims/whitebox.cpp +++ b/hotspot/src/share/vm/prims/whitebox.cpp @@ -237,10 +237,10 @@ WB_ENTRY(jint, WB_GetMethodCompilationLevel(JNIEnv* env, jobject o, jobject meth WB_END -WB_ENTRY(void, WB_MakeMethodNotCompilable(JNIEnv* env, jobject o, jobject method)) +WB_ENTRY(void, WB_MakeMethodNotCompilable(JNIEnv* env, jobject o, jobject method, jint comp_level)) jmethodID jmid = reflected_method_to_jmid(thread, env, method); methodHandle mh(THREAD, Method::checked_resolve_jmethod_id(jmid)); - mh->set_not_compilable(); + mh->set_not_compilable(comp_level, true /* report */, "WhiteBox"); WB_END WB_ENTRY(jboolean, WB_TestSetDontInlineMethod(JNIEnv* env, jobject o, jobject method, jboolean value)) @@ -398,28 +398,28 @@ static JNINativeMethod methods[] = { {CC"NMTWaitForDataMerge", CC"()Z", (void*)&WB_NMTWaitForDataMerge}, #endif // INCLUDE_NMT {CC"deoptimizeAll", CC"()V", (void*)&WB_DeoptimizeAll }, - {CC"deoptimizeMethod", CC"(Ljava/lang/reflect/Method;)I", + {CC"deoptimizeMethod", CC"(Ljava/lang/reflect/Executable;)I", (void*)&WB_DeoptimizeMethod }, - {CC"isMethodCompiled", CC"(Ljava/lang/reflect/Method;)Z", + {CC"isMethodCompiled", CC"(Ljava/lang/reflect/Executable;)Z", (void*)&WB_IsMethodCompiled }, - {CC"isMethodCompilable", CC"(Ljava/lang/reflect/Method;I)Z", + {CC"isMethodCompilable", CC"(Ljava/lang/reflect/Executable;I)Z", (void*)&WB_IsMethodCompilable}, {CC"isMethodQueuedForCompilation", - CC"(Ljava/lang/reflect/Method;)Z", (void*)&WB_IsMethodQueuedForCompilation}, + CC"(Ljava/lang/reflect/Executable;)Z", (void*)&WB_IsMethodQueuedForCompilation}, {CC"makeMethodNotCompilable", - CC"(Ljava/lang/reflect/Method;)V", (void*)&WB_MakeMethodNotCompilable}, + CC"(Ljava/lang/reflect/Executable;I)V", (void*)&WB_MakeMethodNotCompilable}, {CC"testSetDontInlineMethod", - CC"(Ljava/lang/reflect/Method;Z)Z", (void*)&WB_TestSetDontInlineMethod}, + CC"(Ljava/lang/reflect/Executable;Z)Z", (void*)&WB_TestSetDontInlineMethod}, {CC"getMethodCompilationLevel", - CC"(Ljava/lang/reflect/Method;)I", (void*)&WB_GetMethodCompilationLevel}, + CC"(Ljava/lang/reflect/Executable;)I", (void*)&WB_GetMethodCompilationLevel}, {CC"getCompileQueuesSize", CC"()I", (void*)&WB_GetCompileQueuesSize}, {CC"testSetForceInlineMethod", - CC"(Ljava/lang/reflect/Method;Z)Z", (void*)&WB_TestSetForceInlineMethod}, + CC"(Ljava/lang/reflect/Executable;Z)Z", (void*)&WB_TestSetForceInlineMethod}, {CC"enqueueMethodForCompilation", - CC"(Ljava/lang/reflect/Method;I)Z", (void*)&WB_EnqueueMethodForCompilation}, + CC"(Ljava/lang/reflect/Executable;I)Z", (void*)&WB_EnqueueMethodForCompilation}, {CC"clearMethodState", - CC"(Ljava/lang/reflect/Method;)V", (void*)&WB_ClearMethodState}, + CC"(Ljava/lang/reflect/Executable;)V", (void*)&WB_ClearMethodState}, {CC"isInStringTable", CC"(Ljava/lang/String;)Z", (void*)&WB_IsInStringTable }, {CC"fullGC", CC"()V", (void*)&WB_FullGC }, }; diff --git a/hotspot/test/compiler/whitebox/ClearMethodStateTest.java b/hotspot/test/compiler/whitebox/ClearMethodStateTest.java index a117e1b3821..491650d3752 100644 --- a/hotspot/test/compiler/whitebox/ClearMethodStateTest.java +++ b/hotspot/test/compiler/whitebox/ClearMethodStateTest.java @@ -27,42 +27,61 @@ * @build ClearMethodStateTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm -Xbootclasspath/a:. -Xmixed -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI ClearMethodStateTest + * @summary testing of WB::clearMethodState() * @author igor.ignatyev@oracle.com */ public class ClearMethodStateTest extends CompilerWhiteBoxTest { + public static void main(String[] args) throws Exception { - // to prevent inlining #method into #compile() and #test() - WHITE_BOX.testSetDontInlineMethod(METHOD, true); - new ClearMethodStateTest().runTest(); + for (TestCase test : TestCase.values()) { + new ClearMethodStateTest(test).runTest(); + } } + public ClearMethodStateTest(TestCase testCase) { + super(testCase); + // to prevent inlining of #method + WHITE_BOX.testSetDontInlineMethod(method, true); + } + + + /** + * Tests {@code WB::clearMethodState()} by calling it before/after + * compilation. For non-tiered, checks that counters will be rested after + * clearing of method state. + * + * @throws Exception if one of the checks fails. + */ + @Override protected void test() throws Exception { - checkNotCompiled(METHOD); + checkNotCompiled(); compile(); - checkCompiled(METHOD); - WHITE_BOX.clearMethodState(METHOD); - WHITE_BOX.deoptimizeMethod(METHOD); - checkNotCompiled(METHOD); + WHITE_BOX.clearMethodState(method); + checkCompiled(); + WHITE_BOX.clearMethodState(method); + WHITE_BOX.deoptimizeMethod(method); + checkNotCompiled(); if (!TIERED_COMPILATION) { - WHITE_BOX.clearMethodState(METHOD); + WHITE_BOX.clearMethodState(method); compile(COMPILE_THRESHOLD); - checkCompiled(METHOD); + checkCompiled(); - WHITE_BOX.deoptimizeMethod(METHOD); - checkNotCompiled(METHOD); - WHITE_BOX.clearMethodState(METHOD); + WHITE_BOX.deoptimizeMethod(method); + checkNotCompiled(); + WHITE_BOX.clearMethodState(method); + // invoke method one less time than needed to compile if (COMPILE_THRESHOLD > 1) { compile(COMPILE_THRESHOLD - 1); - checkNotCompiled(METHOD); + checkNotCompiled(); } else { - System.err.println("Warning: 'CompileThreshold' <= 1"); + System.err.println("Warning: 'CompileThreshold' <= 1"); } - method(); - checkCompiled(METHOD); + compile(1); + checkCompiled(); } else { System.err.println( "Warning: part of test is not applicable in Tiered"); diff --git a/hotspot/test/compiler/whitebox/CompilerWhiteBoxTest.java b/hotspot/test/compiler/whitebox/CompilerWhiteBoxTest.java index 07b196588c3..a69d9ef8244 100644 --- a/hotspot/test/compiler/whitebox/CompilerWhiteBoxTest.java +++ b/hotspot/test/compiler/whitebox/CompilerWhiteBoxTest.java @@ -21,68 +21,132 @@ * questions. */ +import com.sun.management.HotSpotDiagnosticMXBean; +import com.sun.management.VMOption; import sun.hotspot.WhiteBox; import sun.management.ManagementFactoryHelper; -import com.sun.management.HotSpotDiagnosticMXBean; +import java.lang.reflect.Constructor; +import java.lang.reflect.Executable; import java.lang.reflect.Method; +import java.util.Objects; +import java.util.concurrent.Callable; -/* +/** + * Abstract class for WhiteBox testing of JIT. + * * @author igor.ignatyev@oracle.com */ public abstract class CompilerWhiteBoxTest { + /** {@code CompLevel::CompLevel_none} -- Interpreter */ + protected static int COMP_LEVEL_NONE = 0; + /** {@code CompLevel::CompLevel_any}, {@code CompLevel::CompLevel_all} */ + protected static int COMP_LEVEL_ANY = -1; + /** Instance of WhiteBox */ protected static final WhiteBox WHITE_BOX = WhiteBox.getWhiteBox(); - protected static final Method METHOD = getMethod("method"); + /** Value of {@code -XX:CompileThreshold} */ protected static final int COMPILE_THRESHOLD = Integer.parseInt(getVMOption("CompileThreshold", "10000")); + /** Value of {@code -XX:BackgroundCompilation} */ protected static final boolean BACKGROUND_COMPILATION = Boolean.valueOf(getVMOption("BackgroundCompilation", "true")); + /** Value of {@code -XX:TieredCompilation} */ protected static final boolean TIERED_COMPILATION = Boolean.valueOf(getVMOption("TieredCompilation", "false")); + /** Value of {@code -XX:TieredStopAtLevel} */ + protected static final int TIERED_STOP_AT_LEVEL + = Integer.parseInt(getVMOption("TieredStopAtLevel", "0")); - protected static Method getMethod(String name) { - try { - return CompilerWhiteBoxTest.class.getDeclaredMethod(name); - } catch (NoSuchMethodException | SecurityException e) { - throw new RuntimeException( - "exception on getting method " + name, e); - } - } - + /** + * Returns value of VM option. + * + * @param name option's name + * @return value of option or {@code null}, if option doesn't exist + * @throws NullPointerException if name is null + */ protected static String getVMOption(String name) { - String result; + Objects.requireNonNull(name); HotSpotDiagnosticMXBean diagnostic = ManagementFactoryHelper.getDiagnosticMXBean(); - result = diagnostic.getVMOption(name).getValue(); - return result; + VMOption tmp; + try { + tmp = diagnostic.getVMOption(name); + } catch (IllegalArgumentException e) { + tmp = null; + } + return (tmp == null ? null : tmp.getValue()); } + /** + * Returns value of VM option or default value. + * + * @param name option's name + * @param defaultValue default value + * @return value of option or {@code defaultValue}, if option doesn't exist + * @throws NullPointerException if name is null + * @see #getVMOption(String) + */ protected static String getVMOption(String name, String defaultValue) { String result = getVMOption(name); return result == null ? defaultValue : result; } - protected final void runTest() throws RuntimeException { + /** tested method */ + protected final Executable method; + private final Callable callable; + + /** + * Constructor. + * + * @param testCase object, that contains tested method and way to invoke it. + */ + protected CompilerWhiteBoxTest(TestCase testCase) { + Objects.requireNonNull(testCase); + System.out.println("TEST CASE:" + testCase.name()); + method = testCase.executable; + callable = testCase.callable; + } + + /** + * Template method for testing. Prints tested method's info before + * {@linkplain #test()} and after {@linkplain #test()} or on thrown + * exception. + * + * @throws RuntimeException if method {@linkplain #test()} throws any + * exception + * @see #test() + */ + protected final void runTest() { if (ManagementFactoryHelper.getCompilationMXBean() == null) { System.err.println( "Warning: test is not applicable in interpreted mode"); return; } System.out.println("at test's start:"); - printInfo(METHOD); + printInfo(); try { test(); } catch (Exception e) { System.out.printf("on exception '%s':", e.getMessage()); - printInfo(METHOD); + printInfo(); e.printStackTrace(); + if (e instanceof RuntimeException) { + throw (RuntimeException) e; + } throw new RuntimeException(e); } System.out.println("at test's end:"); - printInfo(METHOD); + printInfo(); } - protected static void checkNotCompiled(Method method) { + /** + * Checks, that {@linkplain #method} is not compiled. + * + * @throws RuntimeException if {@linkplain #method} is in compiler queue or + * is compiled, or if {@linkplain #method} has zero + * compilation level. + */ + protected final void checkNotCompiled() { if (WHITE_BOX.isMethodQueuedForCompilation(method)) { throw new RuntimeException(method + " must not be in queue"); } @@ -94,10 +158,16 @@ public abstract class CompilerWhiteBoxTest { } } - protected static void checkCompiled(Method method) - throws InterruptedException { + /** + * Checks, that {@linkplain #method} is compiled. + * + * @throws RuntimeException if {@linkplain #method} isn't in compiler queue + * and isn't compiled, or if {@linkplain #method} + * has nonzero compilation level + */ + protected final void checkCompiled() { final long start = System.currentTimeMillis(); - waitBackgroundCompilation(method); + waitBackgroundCompilation(); if (WHITE_BOX.isMethodQueuedForCompilation(method)) { System.err.printf("Warning: %s is still in queue after %dms%n", method, System.currentTimeMillis() - start); @@ -111,23 +181,30 @@ public abstract class CompilerWhiteBoxTest { } } - protected static void waitBackgroundCompilation(Method method) - throws InterruptedException { + /** + * Waits for completion of background compilation of {@linkplain #method}. + */ + protected final void waitBackgroundCompilation() { if (!BACKGROUND_COMPILATION) { return; } final Object obj = new Object(); - synchronized (obj) { - for (int i = 0; i < 10; ++i) { - if (!WHITE_BOX.isMethodQueuedForCompilation(method)) { - break; + for (int i = 0; i < 10 + && WHITE_BOX.isMethodQueuedForCompilation(method); ++i) { + synchronized (obj) { + try { + obj.wait(1000); + } catch (InterruptedException e) { + Thread.currentThread().interrupt(); } - obj.wait(1000); } } } - protected static void printInfo(Method method) { + /** + * Prints information about {@linkplain #method}. + */ + protected final void printInfo() { System.out.printf("%n%s:%n", method); System.out.printf("\tcompilable:\t%b%n", WHITE_BOX.isMethodCompilable(method)); @@ -141,22 +218,139 @@ public abstract class CompilerWhiteBoxTest { WHITE_BOX.getCompileQueuesSize()); } + /** + * Executes testing. + */ protected abstract void test() throws Exception; + /** + * Tries to trigger compilation of {@linkplain #method} by call + * {@linkplain #callable} enough times. + * + * @return accumulated result + * @see #compile(int) + */ protected final int compile() { return compile(Math.max(COMPILE_THRESHOLD, 150000)); } + /** + * Tries to trigger compilation of {@linkplain #method} by call + * {@linkplain #callable} specified times. + * + * @param count invocation count + * @return accumulated result + */ protected final int compile(int count) { int result = 0; + Integer tmp; for (int i = 0; i < count; ++i) { - result += method(); + try { + tmp = callable.call(); + } catch (Exception e) { + tmp = null; + } + result += tmp == null ? 0 : tmp; } System.out.println("method was invoked " + count + " times"); return result; } +} - protected int method() { - return 42; +/** + * Utility structure containing tested method and object to invoke it. + */ +enum TestCase { + /** constructor test case */ + CONSTRUCTOR_TEST(Helper.CONSTRUCTOR, Helper.CONSTRUCTOR_CALLABLE), + /** method test case */ + METOD_TEST(Helper.METHOD, Helper.METHOD_CALLABLE), + /** static method test case */ + STATIC_TEST(Helper.STATIC, Helper.STATIC_CALLABLE); + + /** tested method */ + final Executable executable; + /** object to invoke {@linkplain #executable} */ + final Callable callable; + + private TestCase(Executable executable, Callable callable) { + this.executable = executable; + this.callable = callable; + } + + private static class Helper { + private static final Callable CONSTRUCTOR_CALLABLE + = new Callable() { + @Override + public Integer call() throws Exception { + return new Helper(1337).hashCode(); + } + }; + + private static final Callable METHOD_CALLABLE + = new Callable() { + private final Helper helper = new Helper(); + + @Override + public Integer call() throws Exception { + return helper.method(); + } + }; + + private static final Callable STATIC_CALLABLE + = new Callable() { + @Override + public Integer call() throws Exception { + return staticMethod(); + } + }; + + private static final Constructor CONSTRUCTOR; + private static final Method METHOD; + private static final Method STATIC; + + static { + try { + CONSTRUCTOR = Helper.class.getDeclaredConstructor(int.class); + } catch (NoSuchMethodException | SecurityException e) { + throw new RuntimeException( + "exception on getting method Helper.(int)", e); + } + try { + METHOD = Helper.class.getDeclaredMethod("method"); + } catch (NoSuchMethodException | SecurityException e) { + throw new RuntimeException( + "exception on getting method Helper.method()", e); + } + try { + STATIC = Helper.class.getDeclaredMethod("staticMethod"); + } catch (NoSuchMethodException | SecurityException e) { + throw new RuntimeException( + "exception on getting method Helper.staticMethod()", e); + } + } + + private static int staticMethod() { + return 1138; + } + + private int method() { + return 42; + } + + private final int x; + + public Helper() { + x = 0; + } + + private Helper(int x) { + this.x = x; + } + + @Override + public int hashCode() { + return x; + } } } diff --git a/hotspot/test/compiler/whitebox/DeoptimizeAllTest.java b/hotspot/test/compiler/whitebox/DeoptimizeAllTest.java index b6bdaf1f2ad..c831a23e58c 100644 --- a/hotspot/test/compiler/whitebox/DeoptimizeAllTest.java +++ b/hotspot/test/compiler/whitebox/DeoptimizeAllTest.java @@ -27,20 +27,34 @@ * @build DeoptimizeAllTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI DeoptimizeAllTest + * @summary testing of WB::deoptimizeAll() * @author igor.ignatyev@oracle.com */ public class DeoptimizeAllTest extends CompilerWhiteBoxTest { public static void main(String[] args) throws Exception { - // to prevent inlining #method into #compile() - WHITE_BOX.testSetDontInlineMethod(METHOD, true); - new DeoptimizeAllTest().runTest(); + for (TestCase test : TestCase.values()) { + new DeoptimizeAllTest(test).runTest(); + } } + public DeoptimizeAllTest(TestCase testCase) { + super(testCase); + // to prevent inlining of #method + WHITE_BOX.testSetDontInlineMethod(method, true); + } + + /** + * Tests {@code WB::deoptimizeAll()} by calling it after + * compilation and checking that method isn't compiled. + * + * @throws Exception if one of the checks fails. + */ + @Override protected void test() throws Exception { compile(); - checkCompiled(METHOD); + checkCompiled(); WHITE_BOX.deoptimizeAll(); - checkNotCompiled(METHOD); + checkNotCompiled(); } } diff --git a/hotspot/test/compiler/whitebox/DeoptimizeMethodTest.java b/hotspot/test/compiler/whitebox/DeoptimizeMethodTest.java index a5053ae9009..b6c84aeb313 100644 --- a/hotspot/test/compiler/whitebox/DeoptimizeMethodTest.java +++ b/hotspot/test/compiler/whitebox/DeoptimizeMethodTest.java @@ -27,20 +27,34 @@ * @build DeoptimizeMethodTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI DeoptimizeMethodTest + * @summary testing of WB::deoptimizeMethod() * @author igor.ignatyev@oracle.com */ public class DeoptimizeMethodTest extends CompilerWhiteBoxTest { public static void main(String[] args) throws Exception { - // to prevent inlining #method into #compile() - WHITE_BOX.testSetDontInlineMethod(METHOD, true); - new DeoptimizeMethodTest().runTest(); + for (TestCase test : TestCase.values()) { + new DeoptimizeMethodTest(test).runTest(); + } } + public DeoptimizeMethodTest(TestCase testCase) { + super(testCase); + // to prevent inlining of #method + WHITE_BOX.testSetDontInlineMethod(method, true); + } + + /** + * Tests {@code WB::deoptimizeMethod()} by calling it after + * compilation and checking that method isn't compiled. + * + * @throws Exception if one of the checks fails. + */ + @Override protected void test() throws Exception { compile(); - checkCompiled(METHOD); - WHITE_BOX.deoptimizeMethod(METHOD); - checkNotCompiled(METHOD); + checkCompiled(); + WHITE_BOX.deoptimizeMethod(method); + checkNotCompiled(); } } diff --git a/hotspot/test/compiler/whitebox/EnqueueMethodForCompilationTest.java b/hotspot/test/compiler/whitebox/EnqueueMethodForCompilationTest.java index a4464f0e4e7..f87b3235697 100644 --- a/hotspot/test/compiler/whitebox/EnqueueMethodForCompilationTest.java +++ b/hotspot/test/compiler/whitebox/EnqueueMethodForCompilationTest.java @@ -27,48 +27,60 @@ * @build EnqueueMethodForCompilationTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm -Xbootclasspath/a:. -Xmixed -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI EnqueueMethodForCompilationTest + * @summary testing of WB::enqueueMethodForCompilation() * @author igor.ignatyev@oracle.com */ public class EnqueueMethodForCompilationTest extends CompilerWhiteBoxTest { + public static void main(String[] args) throws Exception { - // to prevent inlining #method into #compile() - WHITE_BOX.testSetDontInlineMethod(METHOD, true); - new EnqueueMethodForCompilationTest().runTest(); + for (TestCase test : TestCase.values()) { + new EnqueueMethodForCompilationTest(test).runTest(); + } } + public EnqueueMethodForCompilationTest(TestCase testCase) { + super(testCase); + // to prevent inlining of #method + WHITE_BOX.testSetDontInlineMethod(method, true); + } + + @Override protected void test() throws Exception { - checkNotCompiled(METHOD); + checkNotCompiled(); - WHITE_BOX.enqueueMethodForCompilation(METHOD, 0); - if (WHITE_BOX.isMethodCompilable(METHOD, 0)) { - throw new RuntimeException(METHOD + " is compilable at level 0"); + // method can not be compiled on level 'none' + WHITE_BOX.enqueueMethodForCompilation(method, COMP_LEVEL_NONE); + if (WHITE_BOX.isMethodCompilable(method, COMP_LEVEL_NONE)) { + throw new RuntimeException(method + + " is compilable at level COMP_LEVEL_NONE"); } - checkNotCompiled(METHOD); + checkNotCompiled(); - WHITE_BOX.enqueueMethodForCompilation(METHOD, -1); - checkNotCompiled(METHOD); + // COMP_LEVEL_ANY is inapplicable as level for compilation + WHITE_BOX.enqueueMethodForCompilation(method, COMP_LEVEL_ANY); + checkNotCompiled(); - WHITE_BOX.enqueueMethodForCompilation(METHOD, 5); - if (!WHITE_BOX.isMethodCompilable(METHOD, 5)) { - checkNotCompiled(METHOD); - compile(); - checkCompiled(METHOD); + WHITE_BOX.enqueueMethodForCompilation(method, 5); + if (!WHITE_BOX.isMethodCompilable(method, 5)) { + checkNotCompiled(); + compile(); + checkCompiled(); } else { - checkCompiled(METHOD); + checkCompiled(); } - int compLevel = WHITE_BOX.getMethodCompilationLevel(METHOD); - WHITE_BOX.deoptimizeMethod(METHOD); - checkNotCompiled(METHOD); + int compLevel = WHITE_BOX.getMethodCompilationLevel(method); + WHITE_BOX.deoptimizeMethod(method); + checkNotCompiled(); - WHITE_BOX.enqueueMethodForCompilation(METHOD, compLevel); - checkCompiled(METHOD); - WHITE_BOX.deoptimizeMethod(METHOD); - checkNotCompiled(METHOD); + WHITE_BOX.enqueueMethodForCompilation(method, compLevel); + checkCompiled(); + WHITE_BOX.deoptimizeMethod(method); + checkNotCompiled(); compile(); - checkCompiled(METHOD); - WHITE_BOX.deoptimizeMethod(METHOD); - checkNotCompiled(METHOD); + checkCompiled(); + WHITE_BOX.deoptimizeMethod(method); + checkNotCompiled(); } } diff --git a/hotspot/test/compiler/whitebox/IsMethodCompilableTest.java b/hotspot/test/compiler/whitebox/IsMethodCompilableTest.java index 8f785c27272..e1cfaf4887b 100644 --- a/hotspot/test/compiler/whitebox/IsMethodCompilableTest.java +++ b/hotspot/test/compiler/whitebox/IsMethodCompilableTest.java @@ -28,9 +28,13 @@ * @build IsMethodCompilableTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm/timeout=600 -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI IsMethodCompilableTest + * @summary testing of WB::isMethodCompilable() * @author igor.ignatyev@oracle.com */ public class IsMethodCompilableTest extends CompilerWhiteBoxTest { + /** + * Value of {@code -XX:PerMethodRecompilationCutoff} + */ protected static final long PER_METHOD_RECOMPILATION_CUTOFF; static { @@ -44,14 +48,28 @@ public class IsMethodCompilableTest extends CompilerWhiteBoxTest { } public static void main(String[] args) throws Exception { - // to prevent inlining #method into #compile() - WHITE_BOX.testSetDontInlineMethod(METHOD, true); - new IsMethodCompilableTest().runTest(); + for (TestCase test : TestCase.values()) { + new IsMethodCompilableTest(test).runTest(); + } } + public IsMethodCompilableTest(TestCase testCase) { + super(testCase); + // to prevent inlining of #method + WHITE_BOX.testSetDontInlineMethod(method, true); + } + + /** + * Tests {@code WB::isMethodCompilable()} by recompilation of tested method + * 'PerMethodRecompilationCutoff' times and checks compilation status. Also + * checks that WB::clearMethodState() clears no-compilable flags. + * + * @throws Exception if one of the checks fails. + */ + @Override protected void test() throws Exception { - if (!WHITE_BOX.isMethodCompilable(METHOD)) { - throw new RuntimeException(METHOD + " must be compilable"); + if (!WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + " must be compilable"); } System.out.println("PerMethodRecompilationCutoff = " + PER_METHOD_RECOMPILATION_CUTOFF); @@ -61,46 +79,47 @@ public class IsMethodCompilableTest extends CompilerWhiteBoxTest { return; } - // deoptimze 'PerMethodRecompilationCutoff' times and clear state + // deoptimize 'PerMethodRecompilationCutoff' times and clear state for (long i = 0L, n = PER_METHOD_RECOMPILATION_CUTOFF - 1; i < n; ++i) { - compileAndDeoptimaze(); + compileAndDeoptimize(); } - if (!WHITE_BOX.isMethodCompilable(METHOD)) { - throw new RuntimeException(METHOD + " is not compilable after " + if (!WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + " is not compilable after " + (PER_METHOD_RECOMPILATION_CUTOFF - 1) + " iterations"); } - WHITE_BOX.clearMethodState(METHOD); + WHITE_BOX.clearMethodState(method); - // deoptimze 'PerMethodRecompilationCutoff' + 1 times + // deoptimize 'PerMethodRecompilationCutoff' + 1 times long i; for (i = 0L; i < PER_METHOD_RECOMPILATION_CUTOFF - && WHITE_BOX.isMethodCompilable(METHOD); ++i) { - compileAndDeoptimaze(); + && WHITE_BOX.isMethodCompilable(method); ++i) { + compileAndDeoptimize(); } if (i != PER_METHOD_RECOMPILATION_CUTOFF) { - throw new RuntimeException(METHOD + " is not compilable after " - + i + " iterations, but must only after " - + PER_METHOD_RECOMPILATION_CUTOFF); + throw new RuntimeException(method + " is not compilable after " + + i + " iterations, but must only after " + + PER_METHOD_RECOMPILATION_CUTOFF); } - if (WHITE_BOX.isMethodCompilable(METHOD)) { - throw new RuntimeException(METHOD + " is still compilable after " + if (WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + " is still compilable after " + PER_METHOD_RECOMPILATION_CUTOFF + " iterations"); } compile(); - checkNotCompiled(METHOD); + checkNotCompiled(); - WHITE_BOX.clearMethodState(METHOD); - if (!WHITE_BOX.isMethodCompilable(METHOD)) { - throw new RuntimeException(METHOD - + " is compilable after clearMethodState()"); + // WB.clearMethodState() must reset no-compilable flags + WHITE_BOX.clearMethodState(method); + if (!WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + + " is not compilable after clearMethodState()"); } compile(); - checkCompiled(METHOD); + checkCompiled(); } - private void compileAndDeoptimaze() throws Exception { + private void compileAndDeoptimize() throws Exception { compile(); - waitBackgroundCompilation(METHOD); - WHITE_BOX.deoptimizeMethod(METHOD); + waitBackgroundCompilation(); + WHITE_BOX.deoptimizeMethod(method); } } diff --git a/hotspot/test/compiler/whitebox/MakeMethodNotCompilableTest.java b/hotspot/test/compiler/whitebox/MakeMethodNotCompilableTest.java index 19aaf515a57..59676ccfb37 100644 --- a/hotspot/test/compiler/whitebox/MakeMethodNotCompilableTest.java +++ b/hotspot/test/compiler/whitebox/MakeMethodNotCompilableTest.java @@ -27,28 +27,85 @@ * @build MakeMethodNotCompilableTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI MakeMethodNotCompilableTest + * @summary testing of WB::makeMethodNotCompilable() * @author igor.ignatyev@oracle.com */ public class MakeMethodNotCompilableTest extends CompilerWhiteBoxTest { public static void main(String[] args) throws Exception { - // to prevent inlining #method into #compile() - WHITE_BOX.testSetDontInlineMethod(METHOD, true); - new MakeMethodNotCompilableTest().runTest(); + if (args.length == 0) { + for (TestCase test : TestCase.values()) { + new MakeMethodNotCompilableTest(test).runTest(); + } + } else { + for (String name : args) { + new MakeMethodNotCompilableTest( + TestCase.valueOf(name)).runTest(); + } + } } - protected void test() throws Exception { - if (!WHITE_BOX.isMethodCompilable(METHOD)) { - throw new RuntimeException(METHOD + " must be compilable"); + public MakeMethodNotCompilableTest(TestCase testCase) { + super(testCase); + // to prevent inlining of #method + WHITE_BOX.testSetDontInlineMethod(method, true); + } + + /** + * Tests {@code WB::makeMethodNotCompilable()} by calling it before + * compilation and checking that method isn't compiled. Also + * checks that WB::clearMethodState() clears no-compilable flags. For + * tiered, additional checks for all available levels are conducted. + * + * @throws Exception if one of the checks fails. + */ + @Override + protected void test() throws Exception { + checkNotCompiled(); + if (!WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + " must be compilable"); } - WHITE_BOX.makeMethodNotCompilable(METHOD); - if (WHITE_BOX.isMethodCompilable(METHOD)) { - throw new RuntimeException(METHOD + " must be not compilable"); + + if (TIERED_COMPILATION) { + for (int i = 1, n = TIERED_STOP_AT_LEVEL + 1; i < n; ++i) { + WHITE_BOX.makeMethodNotCompilable(method, i); + if (WHITE_BOX.isMethodCompilable(method, i)) { + throw new RuntimeException(method + + " must be not compilable at level" + i); + } + WHITE_BOX.enqueueMethodForCompilation(method, i); + checkNotCompiled(); + + if (!WHITE_BOX.isMethodCompilable(method)) { + System.out.println(method + + " is not compilable after level " + i); + } + } + + // WB.clearMethodState() must reset no-compilable flags + WHITE_BOX.clearMethodState(method); + if (!WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + + " is not compilable after clearMethodState()"); + } + } + WHITE_BOX.makeMethodNotCompilable(method); + if (WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + " must be not compilable"); + } + + compile(); + checkNotCompiled(); + if (WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + " must be not compilable"); + } + // WB.clearMethodState() must reset no-compilable flags + WHITE_BOX.clearMethodState(method); + if (!WHITE_BOX.isMethodCompilable(method)) { + throw new RuntimeException(method + + " is not compilable after clearMethodState()"); } compile(); - checkNotCompiled(METHOD); - if (WHITE_BOX.isMethodCompilable(METHOD)) { - throw new RuntimeException(METHOD + " must be not compilable"); - } + checkCompiled(); } } diff --git a/hotspot/test/compiler/whitebox/SetDontInlineMethodTest.java b/hotspot/test/compiler/whitebox/SetDontInlineMethodTest.java index a85421a63f9..6a8b61c373f 100644 --- a/hotspot/test/compiler/whitebox/SetDontInlineMethodTest.java +++ b/hotspot/test/compiler/whitebox/SetDontInlineMethodTest.java @@ -27,33 +27,47 @@ * @build SetDontInlineMethodTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI SetDontInlineMethodTest + * @summary testing of WB::testSetDontInlineMethod() * @author igor.ignatyev@oracle.com */ public class SetDontInlineMethodTest extends CompilerWhiteBoxTest { public static void main(String[] args) throws Exception { - new SetDontInlineMethodTest().runTest(); + for (TestCase test : TestCase.values()) { + new SetDontInlineMethodTest(test).runTest(); + } } + public SetDontInlineMethodTest(TestCase testCase) { + super(testCase); + } + + /** + * Tests {@code WB::testSetDontInlineMethod()} by sequential calling it and + * checking of return value. + * + * @throws Exception if one of the checks fails. + */ + @Override protected void test() throws Exception { - if (WHITE_BOX.testSetDontInlineMethod(METHOD, true)) { - throw new RuntimeException("on start " + METHOD + if (WHITE_BOX.testSetDontInlineMethod(method, true)) { + throw new RuntimeException("on start " + method + " must be inlineable"); } - if (!WHITE_BOX.testSetDontInlineMethod(METHOD, true)) { - throw new RuntimeException("after first change to true " + METHOD + if (!WHITE_BOX.testSetDontInlineMethod(method, true)) { + throw new RuntimeException("after first change to true " + method + " must be not inlineable"); } - if (!WHITE_BOX.testSetDontInlineMethod(METHOD, false)) { - throw new RuntimeException("after second change to true " + METHOD + if (!WHITE_BOX.testSetDontInlineMethod(method, false)) { + throw new RuntimeException("after second change to true " + method + " must be still not inlineable"); } - if (WHITE_BOX.testSetDontInlineMethod(METHOD, false)) { - throw new RuntimeException("after first change to false" + METHOD + if (WHITE_BOX.testSetDontInlineMethod(method, false)) { + throw new RuntimeException("after first change to false" + method + " must be inlineable"); } - if (WHITE_BOX.testSetDontInlineMethod(METHOD, false)) { - throw new RuntimeException("after second change to false " + METHOD + if (WHITE_BOX.testSetDontInlineMethod(method, false)) { + throw new RuntimeException("after second change to false " + method + " must be inlineable"); } } diff --git a/hotspot/test/compiler/whitebox/SetForceInlineMethodTest.java b/hotspot/test/compiler/whitebox/SetForceInlineMethodTest.java index cb4a7b02044..ca3e54389bb 100644 --- a/hotspot/test/compiler/whitebox/SetForceInlineMethodTest.java +++ b/hotspot/test/compiler/whitebox/SetForceInlineMethodTest.java @@ -27,33 +27,47 @@ * @build SetForceInlineMethodTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI SetForceInlineMethodTest + * @summary testing of WB::testSetForceInlineMethod() * @author igor.ignatyev@oracle.com */ public class SetForceInlineMethodTest extends CompilerWhiteBoxTest { public static void main(String[] args) throws Exception { - new SetForceInlineMethodTest().runTest(); + for (TestCase test : TestCase.values()) { + new SetForceInlineMethodTest(test).runTest(); + } } + public SetForceInlineMethodTest(TestCase testCase) { + super(testCase); + } + + /** + * Tests {@code WB::testSetForceInlineMethod()} by sequential calling it and + * checking of return value. + * + * @throws Exception if one of the checks fails. + */ + @Override protected void test() throws Exception { - if (WHITE_BOX.testSetForceInlineMethod(METHOD, true)) { - throw new RuntimeException("on start " + METHOD + if (WHITE_BOX.testSetForceInlineMethod(method, true)) { + throw new RuntimeException("on start " + method + " must be not force inlineable"); } - if (!WHITE_BOX.testSetForceInlineMethod(METHOD, true)) { - throw new RuntimeException("after first change to true " + METHOD + if (!WHITE_BOX.testSetForceInlineMethod(method, true)) { + throw new RuntimeException("after first change to true " + method + " must be force inlineable"); } - if (!WHITE_BOX.testSetForceInlineMethod(METHOD, false)) { - throw new RuntimeException("after second change to true " + METHOD + if (!WHITE_BOX.testSetForceInlineMethod(method, false)) { + throw new RuntimeException("after second change to true " + method + " must be still force inlineable"); } - if (WHITE_BOX.testSetForceInlineMethod(METHOD, false)) { - throw new RuntimeException("after first change to false" + METHOD + if (WHITE_BOX.testSetForceInlineMethod(method, false)) { + throw new RuntimeException("after first change to false" + method + " must be not force inlineable"); } - if (WHITE_BOX.testSetForceInlineMethod(METHOD, false)) { - throw new RuntimeException("after second change to false " + METHOD + if (WHITE_BOX.testSetForceInlineMethod(method, false)) { + throw new RuntimeException("after second change to false " + method + " must be not force inlineable"); } } diff --git a/hotspot/test/testlibrary/whitebox/sun/hotspot/WhiteBox.java b/hotspot/test/testlibrary/whitebox/sun/hotspot/WhiteBox.java index 56e609254b4..e294b2344fa 100644 --- a/hotspot/test/testlibrary/whitebox/sun/hotspot/WhiteBox.java +++ b/hotspot/test/testlibrary/whitebox/sun/hotspot/WhiteBox.java @@ -24,7 +24,7 @@ package sun.hotspot; -import java.lang.reflect.Method; +import java.lang.reflect.Executable; import java.security.BasicPermission; import sun.hotspot.parser.DiagnosticCommand; @@ -90,22 +90,25 @@ public class WhiteBox { // Compiler public native void deoptimizeAll(); - public native boolean isMethodCompiled(Method method); - public boolean isMethodCompilable(Method method) { + public native boolean isMethodCompiled(Executable method); + public boolean isMethodCompilable(Executable method) { return isMethodCompilable(method, -1 /*any*/); } - public native boolean isMethodCompilable(Method method, int compLevel); - public native boolean isMethodQueuedForCompilation(Method method); - public native int deoptimizeMethod(Method method); - public native void makeMethodNotCompilable(Method method); - public native int getMethodCompilationLevel(Method method); - public native boolean testSetDontInlineMethod(Method method, boolean value); + public native boolean isMethodCompilable(Executable method, int compLevel); + public native boolean isMethodQueuedForCompilation(Executable method); + public native int deoptimizeMethod(Executable method); + public void makeMethodNotCompilable(Executable method) { + makeMethodNotCompilable(method, -1 /*any*/); + } + public native void makeMethodNotCompilable(Executable method, int compLevel); + public native int getMethodCompilationLevel(Executable method); + public native boolean testSetDontInlineMethod(Executable method, boolean value); public native int getCompileQueuesSize(); - public native boolean testSetForceInlineMethod(Method method, boolean value); - public native boolean enqueueMethodForCompilation(Method method, int compLevel); - public native void clearMethodState(Method method); + public native boolean testSetForceInlineMethod(Executable method, boolean value); + public native boolean enqueueMethodForCompilation(Executable method, int compLevel); + public native void clearMethodState(Executable method); - //Intered strings + // Intered strings public native boolean isInStringTable(String str); // force Full GC From 92ef5fe748ef3156a17fce189270ce451d9abbbc Mon Sep 17 00:00:00 2001 From: Nils Eliasson Date: Thu, 11 Apr 2013 13:57:44 +0200 Subject: [PATCH 14/50] 8006952: Slow VM due to excessive code cache freelist iteration Remove continous free block requirement Reviewed-by: kvn --- hotspot/src/share/vm/code/codeBlob.cpp | 4 +- hotspot/src/share/vm/code/codeCache.cpp | 32 ++---- hotspot/src/share/vm/code/codeCache.hpp | 10 +- hotspot/src/share/vm/code/nmethod.cpp | 77 ++++++++------- .../src/share/vm/compiler/compileBroker.cpp | 2 +- hotspot/src/share/vm/memory/heap.cpp | 97 ++++++++++--------- hotspot/src/share/vm/memory/heap.hpp | 34 +++---- hotspot/src/share/vm/opto/output.cpp | 21 +--- 8 files changed, 123 insertions(+), 154 deletions(-) diff --git a/hotspot/src/share/vm/code/codeBlob.cpp b/hotspot/src/share/vm/code/codeBlob.cpp index 6120d3535ae..a855ade0f5f 100644 --- a/hotspot/src/share/vm/code/codeBlob.cpp +++ b/hotspot/src/share/vm/code/codeBlob.cpp @@ -348,14 +348,14 @@ RuntimeStub* RuntimeStub::new_runtime_stub(const char* stub_name, void* RuntimeStub::operator new(size_t s, unsigned size) { - void* p = CodeCache::allocate(size); + void* p = CodeCache::allocate(size, true); if (!p) fatal("Initial size of CodeCache is too small"); return p; } // operator new shared by all singletons: void* SingletonBlob::operator new(size_t s, unsigned size) { - void* p = CodeCache::allocate(size); + void* p = CodeCache::allocate(size, true); if (!p) fatal("Initial size of CodeCache is too small"); return p; } diff --git a/hotspot/src/share/vm/code/codeCache.cpp b/hotspot/src/share/vm/code/codeCache.cpp index d5b8f8f9a78..7d2bb575d9f 100644 --- a/hotspot/src/share/vm/code/codeCache.cpp +++ b/hotspot/src/share/vm/code/codeCache.cpp @@ -172,7 +172,7 @@ nmethod* CodeCache::next_nmethod (CodeBlob* cb) { static size_t maxCodeCacheUsed = 0; -CodeBlob* CodeCache::allocate(int size) { +CodeBlob* CodeCache::allocate(int size, bool is_critical) { // Do not seize the CodeCache lock here--if the caller has not // already done so, we are going to lose bigtime, since the code // cache will contain a garbage CodeBlob until the caller can @@ -183,7 +183,7 @@ CodeBlob* CodeCache::allocate(int size) { CodeBlob* cb = NULL; _number_of_blobs++; while (true) { - cb = (CodeBlob*)_heap->allocate(size); + cb = (CodeBlob*)_heap->allocate(size, is_critical); if (cb != NULL) break; if (!_heap->expand_by(CodeCacheExpansionSize)) { // Expansion failed @@ -192,8 +192,8 @@ CodeBlob* CodeCache::allocate(int size) { if (PrintCodeCacheExtension) { ResourceMark rm; tty->print_cr("code cache extended to [" INTPTR_FORMAT ", " INTPTR_FORMAT "] (%d bytes)", - (intptr_t)_heap->begin(), (intptr_t)_heap->end(), - (address)_heap->end() - (address)_heap->begin()); + (intptr_t)_heap->low_boundary(), (intptr_t)_heap->high(), + (address)_heap->high() - (address)_heap->low_boundary()); } } maxCodeCacheUsed = MAX2(maxCodeCacheUsed, ((address)_heap->high_boundary() - @@ -608,13 +608,13 @@ void CodeCache::verify_oops() { address CodeCache::first_address() { assert_locked_or_safepoint(CodeCache_lock); - return (address)_heap->begin(); + return (address)_heap->low_boundary(); } address CodeCache::last_address() { assert_locked_or_safepoint(CodeCache_lock); - return (address)_heap->end(); + return (address)_heap->high(); } @@ -996,10 +996,9 @@ void CodeCache::print() { void CodeCache::print_summary(outputStream* st, bool detailed) { size_t total = (_heap->high_boundary() - _heap->low_boundary()); st->print_cr("CodeCache: size=" SIZE_FORMAT "Kb used=" SIZE_FORMAT - "Kb max_used=" SIZE_FORMAT "Kb free=" SIZE_FORMAT - "Kb max_free_chunk=" SIZE_FORMAT "Kb", + "Kb max_used=" SIZE_FORMAT "Kb free=" SIZE_FORMAT "Kb", total/K, (total - unallocated_capacity())/K, - maxCodeCacheUsed/K, unallocated_capacity()/K, largest_free_block()/K); + maxCodeCacheUsed/K, unallocated_capacity()/K); if (detailed) { st->print_cr(" bounds [" INTPTR_FORMAT ", " INTPTR_FORMAT ", " INTPTR_FORMAT "]", @@ -1018,19 +1017,8 @@ void CodeCache::print_summary(outputStream* st, bool detailed) { void CodeCache::log_state(outputStream* st) { st->print(" total_blobs='" UINT32_FORMAT "' nmethods='" UINT32_FORMAT "'" - " adapters='" UINT32_FORMAT "' free_code_cache='" SIZE_FORMAT "'" - " largest_free_block='" SIZE_FORMAT "'", + " adapters='" UINT32_FORMAT "' free_code_cache='" SIZE_FORMAT "'", nof_blobs(), nof_nmethods(), nof_adapters(), - unallocated_capacity(), largest_free_block()); + unallocated_capacity()); } -size_t CodeCache::largest_free_block() { - // This is called both with and without CodeCache_lock held so - // handle both cases. - if (CodeCache_lock->owned_by_self()) { - return _heap->largest_free_block(); - } else { - MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag); - return _heap->largest_free_block(); - } -} diff --git a/hotspot/src/share/vm/code/codeCache.hpp b/hotspot/src/share/vm/code/codeCache.hpp index e19aec61b79..9bb0b839e14 100644 --- a/hotspot/src/share/vm/code/codeCache.hpp +++ b/hotspot/src/share/vm/code/codeCache.hpp @@ -70,7 +70,7 @@ class CodeCache : AllStatic { static void initialize(); // Allocation/administration - static CodeBlob* allocate(int size); // allocates a new CodeBlob + static CodeBlob* allocate(int size, bool is_critical = false); // allocates a new CodeBlob static void commit(CodeBlob* cb); // called when the allocated CodeBlob has been filled static int alignment_unit(); // guaranteed alignment of all CodeBlobs static int alignment_offset(); // guaranteed offset of first CodeBlob byte within alignment unit (i.e., allocation header) @@ -156,19 +156,13 @@ class CodeCache : AllStatic { static address low_bound() { return (address) _heap->low_boundary(); } static address high_bound() { return (address) _heap->high_boundary(); } - static bool has_space(int size) { - // Always leave some room in the CodeCache for I2C/C2I adapters - return largest_free_block() > (CodeCacheMinimumFreeSpace + size); - } - // Profiling static address first_address(); // first address used for CodeBlobs static address last_address(); // last address used for CodeBlobs static size_t capacity() { return _heap->capacity(); } static size_t max_capacity() { return _heap->max_capacity(); } static size_t unallocated_capacity() { return _heap->unallocated_capacity(); } - static size_t largest_free_block(); - static bool needs_flushing() { return largest_free_block() < CodeCacheFlushingMinimumFreeSpace; } + static bool needs_flushing() { return unallocated_capacity() < CodeCacheFlushingMinimumFreeSpace; } static bool needs_cache_clean() { return _needs_cache_clean; } static void set_needs_cache_clean(bool v) { _needs_cache_clean = v; } diff --git a/hotspot/src/share/vm/code/nmethod.cpp b/hotspot/src/share/vm/code/nmethod.cpp index 55a2c05f5ff..60bc88b7734 100644 --- a/hotspot/src/share/vm/code/nmethod.cpp +++ b/hotspot/src/share/vm/code/nmethod.cpp @@ -501,18 +501,17 @@ nmethod* nmethod::new_native_nmethod(methodHandle method, { MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag); int native_nmethod_size = allocation_size(code_buffer, sizeof(nmethod)); - if (CodeCache::has_space(native_nmethod_size)) { - CodeOffsets offsets; - offsets.set_value(CodeOffsets::Verified_Entry, vep_offset); - offsets.set_value(CodeOffsets::Frame_Complete, frame_complete); - nm = new (native_nmethod_size) nmethod(method(), native_nmethod_size, - compile_id, &offsets, - code_buffer, frame_size, - basic_lock_owner_sp_offset, - basic_lock_sp_offset, oop_maps); - NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_native_nmethod(nm)); - if (PrintAssembly && nm != NULL) - Disassembler::decode(nm); + CodeOffsets offsets; + offsets.set_value(CodeOffsets::Verified_Entry, vep_offset); + offsets.set_value(CodeOffsets::Frame_Complete, frame_complete); + nm = new (native_nmethod_size) nmethod(method(), native_nmethod_size, + compile_id, &offsets, + code_buffer, frame_size, + basic_lock_owner_sp_offset, + basic_lock_sp_offset, oop_maps); + NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_native_nmethod(nm)); + if (PrintAssembly && nm != NULL) { + Disassembler::decode(nm); } } // verify nmethod @@ -538,18 +537,17 @@ nmethod* nmethod::new_dtrace_nmethod(methodHandle method, { MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag); int nmethod_size = allocation_size(code_buffer, sizeof(nmethod)); - if (CodeCache::has_space(nmethod_size)) { - CodeOffsets offsets; - offsets.set_value(CodeOffsets::Verified_Entry, vep_offset); - offsets.set_value(CodeOffsets::Dtrace_trap, trap_offset); - offsets.set_value(CodeOffsets::Frame_Complete, frame_complete); + CodeOffsets offsets; + offsets.set_value(CodeOffsets::Verified_Entry, vep_offset); + offsets.set_value(CodeOffsets::Dtrace_trap, trap_offset); + offsets.set_value(CodeOffsets::Frame_Complete, frame_complete); - nm = new (nmethod_size) nmethod(method(), nmethod_size, - &offsets, code_buffer, frame_size); + nm = new (nmethod_size) nmethod(method(), nmethod_size, + &offsets, code_buffer, frame_size); - NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_nmethod(nm)); - if (PrintAssembly && nm != NULL) - Disassembler::decode(nm); + NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_nmethod(nm)); + if (PrintAssembly && nm != NULL) { + Disassembler::decode(nm); } } // verify nmethod @@ -591,16 +589,16 @@ nmethod* nmethod::new_nmethod(methodHandle method, + round_to(handler_table->size_in_bytes(), oopSize) + round_to(nul_chk_table->size_in_bytes(), oopSize) + round_to(debug_info->data_size() , oopSize); - if (CodeCache::has_space(nmethod_size)) { - nm = new (nmethod_size) - nmethod(method(), nmethod_size, compile_id, entry_bci, offsets, - orig_pc_offset, debug_info, dependencies, code_buffer, frame_size, - oop_maps, - handler_table, - nul_chk_table, - compiler, - comp_level); - } + + nm = new (nmethod_size) + nmethod(method(), nmethod_size, compile_id, entry_bci, offsets, + orig_pc_offset, debug_info, dependencies, code_buffer, frame_size, + oop_maps, + handler_table, + nul_chk_table, + compiler, + comp_level); + if (nm != NULL) { // To make dependency checking during class loading fast, record // the nmethod dependencies in the classes it is dependent on. @@ -612,15 +610,18 @@ nmethod* nmethod::new_nmethod(methodHandle method, // classes the slow way is too slow. for (Dependencies::DepStream deps(nm); deps.next(); ) { Klass* klass = deps.context_type(); - if (klass == NULL) continue; // ignore things like evol_method + if (klass == NULL) { + continue; // ignore things like evol_method + } // record this nmethod as dependent on this klass InstanceKlass::cast(klass)->add_dependent_nmethod(nm); } } NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_nmethod(nm)); - if (PrintAssembly && nm != NULL) + if (PrintAssembly && nm != NULL) { Disassembler::decode(nm); + } } // verify nmethod @@ -798,13 +799,11 @@ nmethod::nmethod( } #endif // def HAVE_DTRACE_H -void* nmethod::operator new(size_t size, int nmethod_size) { - void* alloc = CodeCache::allocate(nmethod_size); - guarantee(alloc != NULL, "CodeCache should have enough space"); - return alloc; +void* nmethod::operator new(size_t size, int nmethod_size) throw () { + // Not critical, may return null if there is too little continuous memory + return CodeCache::allocate(nmethod_size); } - nmethod::nmethod( Method* method, int nmethod_size, diff --git a/hotspot/src/share/vm/compiler/compileBroker.cpp b/hotspot/src/share/vm/compiler/compileBroker.cpp index de3df50bdf4..411f02b6771 100644 --- a/hotspot/src/share/vm/compiler/compileBroker.cpp +++ b/hotspot/src/share/vm/compiler/compileBroker.cpp @@ -1581,7 +1581,7 @@ void CompileBroker::compiler_thread_loop() { // We need this HandleMark to avoid leaking VM handles. HandleMark hm(thread); - if (CodeCache::largest_free_block() < CodeCacheMinimumFreeSpace) { + if (CodeCache::unallocated_capacity() < CodeCacheMinimumFreeSpace) { // the code cache is really full handle_full_code_cache(); } else if (UseCodeCacheFlushing && CodeCache::needs_flushing()) { diff --git a/hotspot/src/share/vm/memory/heap.cpp b/hotspot/src/share/vm/memory/heap.cpp index bf41864c6f3..727690b5c7f 100644 --- a/hotspot/src/share/vm/memory/heap.cpp +++ b/hotspot/src/share/vm/memory/heap.cpp @@ -42,7 +42,7 @@ CodeHeap::CodeHeap() { _log2_segment_size = 0; _next_segment = 0; _freelist = NULL; - _free_segments = 0; + _freelist_segments = 0; } @@ -115,8 +115,8 @@ bool CodeHeap::reserve(size_t reserved_size, size_t committed_size, } on_code_mapping(_memory.low(), _memory.committed_size()); - _number_of_committed_segments = number_of_segments(_memory.committed_size()); - _number_of_reserved_segments = number_of_segments(_memory.reserved_size()); + _number_of_committed_segments = size_to_segments(_memory.committed_size()); + _number_of_reserved_segments = size_to_segments(_memory.reserved_size()); assert(_number_of_reserved_segments >= _number_of_committed_segments, "just checking"); // reserve space for _segmap @@ -149,8 +149,8 @@ bool CodeHeap::expand_by(size_t size) { if (!_memory.expand_by(dm)) return false; on_code_mapping(base, dm); size_t i = _number_of_committed_segments; - _number_of_committed_segments = number_of_segments(_memory.committed_size()); - assert(_number_of_reserved_segments == number_of_segments(_memory.reserved_size()), "number of reserved segments should not change"); + _number_of_committed_segments = size_to_segments(_memory.committed_size()); + assert(_number_of_reserved_segments == size_to_segments(_memory.reserved_size()), "number of reserved segments should not change"); assert(_number_of_reserved_segments >= _number_of_committed_segments, "just checking"); // expand _segmap space size_t ds = align_to_page_size(_number_of_committed_segments) - _segmap.committed_size(); @@ -176,33 +176,44 @@ void CodeHeap::clear() { } -void* CodeHeap::allocate(size_t size) { - size_t length = number_of_segments(size + sizeof(HeapBlock)); - assert(length *_segment_size >= sizeof(FreeBlock), "not enough room for FreeList"); +void* CodeHeap::allocate(size_t instance_size, bool is_critical) { + size_t number_of_segments = size_to_segments(instance_size + sizeof(HeapBlock)); + assert(segments_to_size(number_of_segments) >= sizeof(FreeBlock), "not enough room for FreeList"); // First check if we can satify request from freelist debug_only(verify()); - HeapBlock* block = search_freelist(length); + HeapBlock* block = search_freelist(number_of_segments, is_critical); debug_only(if (VerifyCodeCacheOften) verify()); if (block != NULL) { - assert(block->length() >= length && block->length() < length + CodeCacheMinBlockLength, "sanity check"); + assert(block->length() >= number_of_segments && block->length() < number_of_segments + CodeCacheMinBlockLength, "sanity check"); assert(!block->free(), "must be marked free"); #ifdef ASSERT - memset((void *)block->allocated_space(), badCodeHeapNewVal, size); + memset((void *)block->allocated_space(), badCodeHeapNewVal, instance_size); #endif return block->allocated_space(); } - if (length < CodeCacheMinBlockLength) { - length = CodeCacheMinBlockLength; + // Ensure minimum size for allocation to the heap. + if (number_of_segments < CodeCacheMinBlockLength) { + number_of_segments = CodeCacheMinBlockLength; } - if (_next_segment + length <= _number_of_committed_segments) { - mark_segmap_as_used(_next_segment, _next_segment + length); + + if (!is_critical) { + // Make sure the allocation fits in the unallocated heap without using + // the CodeCacheMimimumFreeSpace that is reserved for critical allocations. + if (segments_to_size(number_of_segments) > (heap_unallocated_capacity() - CodeCacheMinimumFreeSpace)) { + // Fail allocation + return NULL; + } + } + + if (_next_segment + number_of_segments <= _number_of_committed_segments) { + mark_segmap_as_used(_next_segment, _next_segment + number_of_segments); HeapBlock* b = block_at(_next_segment); - b->initialize(length); - _next_segment += length; + b->initialize(number_of_segments); + _next_segment += number_of_segments; #ifdef ASSERT - memset((void *)b->allocated_space(), badCodeHeapNewVal, size); + memset((void *)b->allocated_space(), badCodeHeapNewVal, instance_size); #endif return b->allocated_space(); } else { @@ -219,7 +230,7 @@ void CodeHeap::deallocate(void* p) { #ifdef ASSERT memset((void *)b->allocated_space(), badCodeHeapFreeVal, - size(b->length()) - sizeof(HeapBlock)); + segments_to_size(b->length()) - sizeof(HeapBlock)); #endif add_to_freelist(b); @@ -299,32 +310,14 @@ size_t CodeHeap::max_capacity() const { } size_t CodeHeap::allocated_capacity() const { - // Start with the committed size in _memory; - size_t l = _memory.committed_size(); - - // Subtract the committed, but unused, segments - l -= size(_number_of_committed_segments - _next_segment); - - // Subtract the size of the freelist - l -= size(_free_segments); - - return l; + // size of used heap - size on freelist + return segments_to_size(_next_segment - _freelist_segments); } -size_t CodeHeap::largest_free_block() const { - // First check unused space excluding free blocks. - size_t free_sz = size(_free_segments); - size_t unused = max_capacity() - allocated_capacity() - free_sz; - if (unused >= free_sz) - return unused; - - // Now check largest free block. - size_t len = 0; - for (FreeBlock* b = _freelist; b != NULL; b = b->link()) { - if (b->length() > len) - len = b->length(); - } - return MAX2(unused, size(len)); +// Returns size of the unallocated heap block +size_t CodeHeap::heap_unallocated_capacity() const { + // Total number of segments - number currently used + return segments_to_size(_number_of_reserved_segments - _next_segment); } // Free list management @@ -365,7 +358,7 @@ void CodeHeap::add_to_freelist(HeapBlock *a) { assert(b != _freelist, "cannot be removed twice"); // Mark as free and update free space count - _free_segments += b->length(); + _freelist_segments += b->length(); b->set_free(); // First element in list? @@ -400,7 +393,7 @@ void CodeHeap::add_to_freelist(HeapBlock *a) { // Search freelist for an entry on the list with the best fit // Return NULL if no one was found -FreeBlock* CodeHeap::search_freelist(size_t length) { +FreeBlock* CodeHeap::search_freelist(size_t length, bool is_critical) { FreeBlock *best_block = NULL; FreeBlock *best_prev = NULL; size_t best_length = 0; @@ -411,6 +404,16 @@ FreeBlock* CodeHeap::search_freelist(size_t length) { while(cur != NULL) { size_t l = cur->length(); if (l >= length && (best_block == NULL || best_length > l)) { + + // Non critical allocations are not allowed to use the last part of the code heap. + if (!is_critical) { + // Make sure the end of the allocation doesn't cross into the last part of the code heap + if (((size_t)cur + length) > ((size_t)high_boundary() - CodeCacheMinimumFreeSpace)) { + // the freelist is sorted by address - if one fails, all consecutive will also fail. + break; + } + } + // Remember best block, its previous element, and its length best_block = cur; best_prev = prev; @@ -452,7 +455,7 @@ FreeBlock* CodeHeap::search_freelist(size_t length) { } best_block->set_used(); - _free_segments -= length; + _freelist_segments -= length; return best_block; } @@ -478,7 +481,7 @@ void CodeHeap::verify() { } // Verify that freelist contains the right amount of free space - // guarantee(len == _free_segments, "wrong freelist"); + // guarantee(len == _freelist_segments, "wrong freelist"); // Verify that the number of free blocks is not out of hand. static int free_block_threshold = 10000; diff --git a/hotspot/src/share/vm/memory/heap.hpp b/hotspot/src/share/vm/memory/heap.hpp index f1aa3ffdc33..725592e67be 100644 --- a/hotspot/src/share/vm/memory/heap.hpp +++ b/hotspot/src/share/vm/memory/heap.hpp @@ -91,11 +91,11 @@ class CodeHeap : public CHeapObj { size_t _next_segment; FreeBlock* _freelist; - size_t _free_segments; // No. of segments in freelist + size_t _freelist_segments; // No. of segments in freelist // Helper functions - size_t number_of_segments(size_t size) const { return (size + _segment_size - 1) >> _log2_segment_size; } - size_t size(size_t number_of_segments) const { return number_of_segments << _log2_segment_size; } + size_t size_to_segments(size_t size) const { return (size + _segment_size - 1) >> _log2_segment_size; } + size_t segments_to_size(size_t number_of_segments) const { return number_of_segments << _log2_segment_size; } size_t segment_for(void* p) const { return ((char*)p - _memory.low()) >> _log2_segment_size; } HeapBlock* block_at(size_t i) const { return (HeapBlock*)(_memory.low() + (i << _log2_segment_size)); } @@ -110,7 +110,7 @@ class CodeHeap : public CHeapObj { // Toplevel freelist management void add_to_freelist(HeapBlock *b); - FreeBlock* search_freelist(size_t length); + FreeBlock* search_freelist(size_t length, bool is_critical); // Iteration helpers void* next_free(HeapBlock* b) const; @@ -132,22 +132,19 @@ class CodeHeap : public CHeapObj { void clear(); // clears all heap contents // Memory allocation - void* allocate (size_t size); // allocates a block of size or returns NULL + void* allocate (size_t size, bool is_critical); // allocates a block of size or returns NULL void deallocate(void* p); // deallocates a block // Attributes - void* begin() const { return _memory.low (); } - void* end() const { return _memory.high(); } - bool contains(void* p) const { return begin() <= p && p < end(); } - void* find_start(void* p) const; // returns the block containing p or NULL - size_t alignment_unit() const; // alignment of any block - size_t alignment_offset() const; // offset of first byte of any block, within the enclosing alignment unit - static size_t header_size(); // returns the header size for each heap block + char* low_boundary() const { return _memory.low_boundary (); } + char* high() const { return _memory.high(); } + char* high_boundary() const { return _memory.high_boundary(); } - // Returns reserved area high and low addresses - char *low_boundary() const { return _memory.low_boundary (); } - char *high() const { return _memory.high(); } - char *high_boundary() const { return _memory.high_boundary(); } + bool contains(const void* p) const { return low_boundary() <= p && p < high(); } + void* find_start(void* p) const; // returns the block containing p or NULL + size_t alignment_unit() const; // alignment of any block + size_t alignment_offset() const; // offset of first byte of any block, within the enclosing alignment unit + static size_t header_size(); // returns the header size for each heap block // Iteration @@ -161,8 +158,11 @@ class CodeHeap : public CHeapObj { size_t max_capacity() const; size_t allocated_capacity() const; size_t unallocated_capacity() const { return max_capacity() - allocated_capacity(); } - size_t largest_free_block() const; +private: + size_t heap_unallocated_capacity() const; + +public: // Debugging void verify(); void print() PRODUCT_RETURN; diff --git a/hotspot/src/share/vm/opto/output.cpp b/hotspot/src/share/vm/opto/output.cpp index 178f3b717eb..8c42920995e 100644 --- a/hotspot/src/share/vm/opto/output.cpp +++ b/hotspot/src/share/vm/opto/output.cpp @@ -1044,21 +1044,6 @@ void NonSafepointEmitter::emit_non_safepoint() { debug_info->end_non_safepoint(pc_offset); } - - -// helper for fill_buffer bailout logic -static void turn_off_compiler(Compile* C) { - if (CodeCache::largest_free_block() >= CodeCacheMinimumFreeSpace*10) { - // Do not turn off compilation if a single giant method has - // blown the code cache size. - C->record_failure("excessive request to CodeCache"); - } else { - // Let CompilerBroker disable further compilations. - C->record_failure("CodeCache is full"); - } -} - - //------------------------------init_buffer------------------------------------ CodeBuffer* Compile::init_buffer(uint* blk_starts) { @@ -1158,7 +1143,7 @@ CodeBuffer* Compile::init_buffer(uint* blk_starts) { // Have we run out of code space? if ((cb->blob() == NULL) || (!CompileBroker::should_compile_new_jobs())) { - turn_off_compiler(this); + C->record_failure("CodeCache is full"); return NULL; } // Configure the code buffer. @@ -1476,7 +1461,7 @@ void Compile::fill_buffer(CodeBuffer* cb, uint* blk_starts) { // Verify that there is sufficient space remaining cb->insts()->maybe_expand_to_ensure_remaining(MAX_inst_size); if ((cb->blob() == NULL) || (!CompileBroker::should_compile_new_jobs())) { - turn_off_compiler(this); + C->record_failure("CodeCache is full"); return; } @@ -1633,7 +1618,7 @@ void Compile::fill_buffer(CodeBuffer* cb, uint* blk_starts) { // One last check for failed CodeBuffer::expand: if ((cb->blob() == NULL) || (!CompileBroker::should_compile_new_jobs())) { - turn_off_compiler(this); + C->record_failure("CodeCache is full"); return; } From 9ce964ad3894cbb6d93cf18c3a5fadbcc872954f Mon Sep 17 00:00:00 2001 From: Jiangli Zhou Date: Thu, 11 Apr 2013 23:06:33 -0400 Subject: [PATCH 15/50] 8012052: java/lang/invoke/6987555/Test6987555.java crashes with assert(mcs != NULL) failed: MethodCounters cannot be NULL Skip counter decay if the MethodCounters is NULL in NonTieredCompPolicy::delay_compilation(). Reviewed-by: kvn, dholmes --- hotspot/src/share/vm/runtime/compilationPolicy.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/runtime/compilationPolicy.cpp b/hotspot/src/share/vm/runtime/compilationPolicy.cpp index cec42ae9195..3d670d6a297 100644 --- a/hotspot/src/share/vm/runtime/compilationPolicy.cpp +++ b/hotspot/src/share/vm/runtime/compilationPolicy.cpp @@ -297,9 +297,10 @@ void NonTieredCompPolicy::reprofile(ScopeDesc* trap_scope, bool is_osr) { // that it's recommended to delay the complation of this method. void NonTieredCompPolicy::delay_compilation(Method* method) { MethodCounters* mcs = method->method_counters(); - assert(mcs != NULL, "MethodCounters cannot be NULL"); - mcs->invocation_counter()->decay(); - mcs->backedge_counter()->decay(); + if (mcs != NULL) { + mcs->invocation_counter()->decay(); + mcs->backedge_counter()->decay(); + } } void NonTieredCompPolicy::disable_compilation(Method* method) { From 6aa1ba2f503e87931dfdf9c39ec297b4d83a6d78 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Thu, 11 Apr 2013 21:54:46 -0700 Subject: [PATCH 16/50] 8011949: new hotspot build - hs25-b29 Reviewed-by: jcoomes --- hotspot/make/hotspot_version | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/make/hotspot_version b/hotspot/make/hotspot_version index 865a90932d1..2f5b12ddbc2 100644 --- a/hotspot/make/hotspot_version +++ b/hotspot/make/hotspot_version @@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2013 HS_MAJOR_VER=25 HS_MINOR_VER=0 -HS_BUILD_NUMBER=28 +HS_BUILD_NUMBER=29 JDK_MAJOR_VER=1 JDK_MINOR_VER=8 From bad6728ea40d6e49e291d85b0635f45ffb93855e Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Tue, 16 Apr 2013 17:06:39 +0200 Subject: [PATCH 17/50] 8011901: Unsafe.getAndAddLong(obj, off, delta) does not work properly with long deltas Instruct xaddL_no_res shouldn't allow 64 bit constants. Reviewed-by: kvn --- hotspot/src/cpu/x86/vm/x86_64.ad | 8 +-- .../test/compiler/8011901/Test8011901.java | 68 +++++++++++++++++++ 2 files changed, 69 insertions(+), 7 deletions(-) create mode 100644 hotspot/test/compiler/8011901/Test8011901.java diff --git a/hotspot/src/cpu/x86/vm/x86_64.ad b/hotspot/src/cpu/x86/vm/x86_64.ad index 2953b8bb41d..170e2ff1100 100644 --- a/hotspot/src/cpu/x86/vm/x86_64.ad +++ b/hotspot/src/cpu/x86/vm/x86_64.ad @@ -2222,12 +2222,6 @@ encode %{ $$$emit32$src$$constant; %} - enc_class Con64(immL src) - %{ - // Output immediate - emit_d64($src$$constant); - %} - enc_class Con32F_as_bits(immF src) %{ // Output Float immediate bits @@ -7608,7 +7602,7 @@ instruct xaddI( memory mem, rRegI newval, rFlagsReg cr) %{ ins_pipe( pipe_cmpxchg ); %} -instruct xaddL_no_res( memory mem, Universe dummy, immL add, rFlagsReg cr) %{ +instruct xaddL_no_res( memory mem, Universe dummy, immL32 add, rFlagsReg cr) %{ predicate(n->as_LoadStore()->result_not_used()); match(Set dummy (GetAndAddL mem add)); effect(KILL cr); diff --git a/hotspot/test/compiler/8011901/Test8011901.java b/hotspot/test/compiler/8011901/Test8011901.java new file mode 100644 index 00000000000..6ff0a932118 --- /dev/null +++ b/hotspot/test/compiler/8011901/Test8011901.java @@ -0,0 +1,68 @@ +/* + * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8011901 + * @summary instruct xaddL_no_res shouldn't allow 64 bit constants. + * @run main/othervm -XX:-BackgroundCompilation Test8011901 + * + */ + +import java.lang.reflect.*; +import sun.misc.*; + +public class Test8011901 { + + private long ctl; + + private static final sun.misc.Unsafe U; + private static final long CTL; + + static { + try { + Field unsafe = sun.misc.Unsafe.class.getDeclaredField("theUnsafe"); + unsafe.setAccessible(true); + U = (sun.misc.Unsafe) unsafe.get(null); + CTL = U.objectFieldOffset(Test8011901.class.getDeclaredField("ctl")); + } catch (Exception e) { + throw new Error(e); + } + } + + public static void main(String[] args) { + for(int c = 0; c < 20000; c++) { + new Test8011901().makeTest(); + } + System.out.println("Test Passed"); + } + + public static final long EXPECTED = 1L << 42; + + public void makeTest() { + U.getAndAddLong(this, CTL, EXPECTED); + if (ctl != EXPECTED) { + throw new RuntimeException("Test failed. Expected: " + EXPECTED + ", but got = " + ctl); + } + } +} From 54b7ae1ff969d744c13ad8be24aeeddc70740f90 Mon Sep 17 00:00:00 2001 From: Harold Seigel Date: Wed, 17 Apr 2013 08:20:02 -0400 Subject: [PATCH 18/50] 8009928: PSR:PERF Increase default string table size Increase default string table size to 60013 for 64-bit platforms. Reviewed-by: coleenp, dholmes --- hotspot/src/share/vm/runtime/arguments.cpp | 2 +- hotspot/src/share/vm/utilities/globalDefinitions.hpp | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/runtime/arguments.cpp b/hotspot/src/share/vm/runtime/arguments.cpp index 6db5ff5820d..236a1272624 100644 --- a/hotspot/src/share/vm/runtime/arguments.cpp +++ b/hotspot/src/share/vm/runtime/arguments.cpp @@ -1901,7 +1901,7 @@ bool Arguments::check_vm_args_consistency() { // Divide by bucket size to prevent a large size from causing rollover when // calculating amount of memory needed to be allocated for the String table. - status = status && verify_interval(StringTableSize, defaultStringTableSize, + status = status && verify_interval(StringTableSize, minimumStringTableSize, (max_uintx / StringTable::bucket_size()), "StringTable size"); if (MinHeapFreeRatio > MaxHeapFreeRatio) { diff --git a/hotspot/src/share/vm/utilities/globalDefinitions.hpp b/hotspot/src/share/vm/utilities/globalDefinitions.hpp index 52258981857..5609ffdf431 100644 --- a/hotspot/src/share/vm/utilities/globalDefinitions.hpp +++ b/hotspot/src/share/vm/utilities/globalDefinitions.hpp @@ -328,9 +328,10 @@ const int max_method_code_size = 64*K - 1; // JVM spec, 2nd ed. section 4.8.1 ( //---------------------------------------------------------------------------------------------------- -// Minimum StringTableSize value +// Default and minimum StringTableSize values -const int defaultStringTableSize=1009; +const int defaultStringTableSize = NOT_LP64(1009) LP64_ONLY(60013); +const int minimumStringTableSize=1009; //---------------------------------------------------------------------------------------------------- From d61a4656e4654b861514a5208cb90adbe4dc17bb Mon Sep 17 00:00:00 2001 From: Martin Doerr Date: Wed, 17 Apr 2013 10:57:02 -0700 Subject: [PATCH 19/50] 8012335: G1: Fix bug with compressed oops in template interpreter on x86 and sparc In do_oop_store the uncompressed value of the oop being stored needs to be preserved and passed to g1_write_barrier_post. This is necessary for the heap region cross check to work correctly. Reviewed-by: coleenp, johnc --- hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp | 9 ++++++++- hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp | 9 +++++++-- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp b/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp index 01d593fb034..bc4490b0b41 100644 --- a/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/templateTable_sparc.cpp @@ -63,6 +63,13 @@ static void do_oop_store(InterpreterMacroAssembler* _masm, noreg /* pre_val */, tmp, true /*preserve_o_regs*/); + // G1 barrier needs uncompressed oop for region cross check. + Register new_val = val; + if (UseCompressedOops && val != G0) { + new_val = tmp; + __ mov(val, new_val); + } + if (index == noreg ) { assert(Assembler::is_simm13(offset), "fix this code"); __ store_heap_oop(val, base, offset); @@ -79,7 +86,7 @@ static void do_oop_store(InterpreterMacroAssembler* _masm, __ add(base, index, base); } } - __ g1_write_barrier_post(base, val, tmp); + __ g1_write_barrier_post(base, new_val, tmp); } } break; diff --git a/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp b/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp index d1e22d25990..5f5d1947f91 100644 --- a/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/templateTable_x86_64.cpp @@ -158,14 +158,19 @@ static void do_oop_store(InterpreterMacroAssembler* _masm, if (val == noreg) { __ store_heap_oop_null(Address(rdx, 0)); } else { + // G1 barrier needs uncompressed oop for region cross check. + Register new_val = val; + if (UseCompressedOops) { + new_val = rbx; + __ movptr(new_val, val); + } __ store_heap_oop(Address(rdx, 0), val); __ g1_write_barrier_post(rdx /* store_adr */, - val /* new_val */, + new_val /* new_val */, r15_thread /* thread */, r8 /* tmp */, rbx /* tmp2 */); } - } break; #endif // INCLUDE_ALL_GCS From 687b6a8d440448a4f69a8ecc96d407e3d0de3cc6 Mon Sep 17 00:00:00 2001 From: Bengt Rutisson Date: Thu, 18 Apr 2013 06:50:35 +0200 Subject: [PATCH 20/50] 8012455: Missing time and date stamps for PrintGCApplicationConcurrentTime and PrintGCApplicationStoppedTime Also reviewed by: kirk@kodewerk.com, brandon@twitter.com Reviewed-by: tschatzl, stefank, johnc --- hotspot/src/share/vm/services/runtimeService.cpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/hotspot/src/share/vm/services/runtimeService.cpp b/hotspot/src/share/vm/services/runtimeService.cpp index 49997dfc5b3..fc2fdf1f6c0 100644 --- a/hotspot/src/share/vm/services/runtimeService.cpp +++ b/hotspot/src/share/vm/services/runtimeService.cpp @@ -120,6 +120,8 @@ void RuntimeService::record_safepoint_begin() { // Print the time interval in which the app was executing if (PrintGCApplicationConcurrentTime) { + gclog_or_tty->date_stamp(PrintGCDateStamps); + gclog_or_tty->stamp(PrintGCTimeStamps); gclog_or_tty->print_cr("Application time: %3.7f seconds", last_application_time_sec()); } @@ -150,6 +152,8 @@ void RuntimeService::record_safepoint_end() { // Print the time interval for which the app was stopped // during the current safepoint operation. if (PrintGCApplicationStoppedTime) { + gclog_or_tty->date_stamp(PrintGCDateStamps); + gclog_or_tty->stamp(PrintGCTimeStamps); gclog_or_tty->print_cr("Total time for which application threads " "were stopped: %3.7f seconds", last_safepoint_time_sec()); From cfaea9fe7dd5a1bbc3597b02e2c21e19c7773db1 Mon Sep 17 00:00:00 2001 From: Zhengyu Gu Date: Thu, 18 Apr 2013 10:04:44 -0400 Subject: [PATCH 21/50] 8012464: NMT: classes should not derive from _ValueObj, use VALUE_OBJ_CLASS_SPEC instead NMT value objects should use VALUE_OBJ_CLASS_SPEC instead of deriving from _ValueObj Reviewed-by: coleenp, hseigel, dholmes --- hotspot/src/share/vm/services/memBaseline.hpp | 6 +++--- hotspot/src/share/vm/services/memPtr.hpp | 2 +- hotspot/src/share/vm/services/memSnapshot.hpp | 2 +- hotspot/src/share/vm/services/memTrackWorker.hpp | 2 +- 4 files changed, 6 insertions(+), 6 deletions(-) diff --git a/hotspot/src/share/vm/services/memBaseline.hpp b/hotspot/src/share/vm/services/memBaseline.hpp index c409ec3face..fc878160ea3 100644 --- a/hotspot/src/share/vm/services/memBaseline.hpp +++ b/hotspot/src/share/vm/services/memBaseline.hpp @@ -133,7 +133,7 @@ typedef struct _memType2Name { // This class aggregates malloc'd records by memory type -class MallocMem : public _ValueObj { +class MallocMem VALUE_OBJ_CLASS_SPEC { private: MEMFLAGS _type; @@ -211,7 +211,7 @@ class ArenaMem : public MallocMem { }; // This class aggregates virtual memory by its memory type -class VMMem : public _ValueObj { +class VMMem VALUE_OBJ_CLASS_SPEC { private: MEMFLAGS _type; @@ -296,7 +296,7 @@ class BaselineComparisonReporter; * aggregates memory usage by callsites when detail tracking * is on. */ -class MemBaseline : public _ValueObj { +class MemBaseline VALUE_OBJ_CLASS_SPEC { friend class BaselineReporter; friend class BaselineComparisonReporter; diff --git a/hotspot/src/share/vm/services/memPtr.hpp b/hotspot/src/share/vm/services/memPtr.hpp index e1c852ac7ba..d98ca80c457 100644 --- a/hotspot/src/share/vm/services/memPtr.hpp +++ b/hotspot/src/share/vm/services/memPtr.hpp @@ -89,7 +89,7 @@ class SequenceGenerator : AllStatic { * the memory pointer either points to a malloc'd * memory block, or a mmap'd memory block */ -class MemPointer : public _ValueObj { +class MemPointer VALUE_OBJ_CLASS_SPEC { public: MemPointer(): _addr(0) { } MemPointer(address addr): _addr(addr) { } diff --git a/hotspot/src/share/vm/services/memSnapshot.hpp b/hotspot/src/share/vm/services/memSnapshot.hpp index 7d31c7386fe..cf6236d4202 100644 --- a/hotspot/src/share/vm/services/memSnapshot.hpp +++ b/hotspot/src/share/vm/services/memSnapshot.hpp @@ -308,7 +308,7 @@ class VMRecordIterator : public MemPointerArrayIterator { } }; -class StagingArea : public _ValueObj { +class StagingArea VALUE_OBJ_CLASS_SPEC { private: MemPointerArray* _malloc_data; MemPointerArray* _vm_data; diff --git a/hotspot/src/share/vm/services/memTrackWorker.hpp b/hotspot/src/share/vm/services/memTrackWorker.hpp index 964aad31db8..5d49ae1938e 100644 --- a/hotspot/src/share/vm/services/memTrackWorker.hpp +++ b/hotspot/src/share/vm/services/memTrackWorker.hpp @@ -32,7 +32,7 @@ // Maximum MAX_GENERATIONS generation data can be tracked. #define MAX_GENERATIONS 512 -class GenerationData : public _ValueObj { +class GenerationData VALUE_OBJ_CLASS_SPEC { private: int _number_of_classes; MemRecorder* _recorder_list; From f63b13e379fbab182f1a5c9efad8197570681a26 Mon Sep 17 00:00:00 2001 From: Bharadwaj Yadavalli Date: Thu, 18 Apr 2013 08:05:35 -0700 Subject: [PATCH 22/50] 8006267: InterfaceMethod_ref should allow invokestatic and invokespecial Lambda changes; spec 0.6.2 - Allow static invokestatic and invokespecial calls to InterfaceMethod_ref Reviewed-by: dholmes, acorn --- .../share/vm/classfile/classFileParser.cpp | 11 +++++-- .../share/vm/classfile/genericSignatures.cpp | 11 +++++-- .../src/share/vm/interpreter/linkResolver.cpp | 29 ++++++++++++++----- hotspot/src/share/vm/prims/methodHandles.cpp | 5 ++++ 4 files changed, 44 insertions(+), 12 deletions(-) diff --git a/hotspot/src/share/vm/classfile/classFileParser.cpp b/hotspot/src/share/vm/classfile/classFileParser.cpp index ad11f2005df..373ca0ae8ff 100644 --- a/hotspot/src/share/vm/classfile/classFileParser.cpp +++ b/hotspot/src/share/vm/classfile/classFileParser.cpp @@ -436,14 +436,19 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) { ref_index, CHECK_(nullHandle)); break; case JVM_REF_invokeVirtual: - case JVM_REF_invokeStatic: - case JVM_REF_invokeSpecial: case JVM_REF_newInvokeSpecial: check_property( tag.is_method(), "Invalid constant pool index %u in class file %s (not a method)", ref_index, CHECK_(nullHandle)); break; + case JVM_REF_invokeStatic: + case JVM_REF_invokeSpecial: + check_property( + tag.is_method() || tag.is_interface_method(), + "Invalid constant pool index %u in class file %s (not a method)", + ref_index, CHECK_(nullHandle)); + break; case JVM_REF_invokeInterface: check_property( tag.is_interface_method(), @@ -3837,7 +3842,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(Symbol* name, } if (TraceClassLoadingPreorder) { - tty->print("[Loading %s", name->as_klass_external_name()); + tty->print("[Loading %s", (name != NULL) ? name->as_klass_external_name() : "NoName"); if (cfs->source() != NULL) tty->print(" from %s", cfs->source()); tty->print_cr("]"); } diff --git a/hotspot/src/share/vm/classfile/genericSignatures.cpp b/hotspot/src/share/vm/classfile/genericSignatures.cpp index 3b0ffbd3349..33fbca051b7 100644 --- a/hotspot/src/share/vm/classfile/genericSignatures.cpp +++ b/hotspot/src/share/vm/classfile/genericSignatures.cpp @@ -268,8 +268,15 @@ ClassDescriptor* ClassDescriptor::parse_generic_signature( Klass* outer = SystemDictionary::find( outer_name, class_loader, protection_domain, CHECK_NULL); if (outer == NULL && !THREAD->is_Compiler_thread()) { - outer = SystemDictionary::resolve_super_or_fail(original_name, - outer_name, class_loader, protection_domain, false, CHECK_NULL); + if (outer_name == ik->super()->name()) { + outer = SystemDictionary::resolve_super_or_fail(original_name, outer_name, + class_loader, protection_domain, + false, CHECK_NULL); + } + else { + outer = SystemDictionary::resolve_or_fail(outer_name, class_loader, + protection_domain, false, CHECK_NULL); + } } InstanceKlass* outer_ik; diff --git a/hotspot/src/share/vm/interpreter/linkResolver.cpp b/hotspot/src/share/vm/interpreter/linkResolver.cpp index 9f0a1544812..b0bd678b597 100644 --- a/hotspot/src/share/vm/interpreter/linkResolver.cpp +++ b/hotspot/src/share/vm/interpreter/linkResolver.cpp @@ -1014,13 +1014,28 @@ void LinkResolver::runtime_resolve_interface_method(CallInfo& result, methodHand resolved_method->name(), resolved_method->signature())); } - // check if public - if (!sel_method->is_public()) { - ResourceMark rm(THREAD); - THROW_MSG(vmSymbols::java_lang_IllegalAccessError(), - Method::name_and_sig_as_C_string(recv_klass(), - sel_method->name(), - sel_method->signature())); + // check access + if (sel_method->method_holder()->is_interface()) { + // Method holder is an interface. Throw Illegal Access Error if sel_method + // is neither public nor private. + if (!(sel_method->is_public() || sel_method->is_private())) { + ResourceMark rm(THREAD); + THROW_MSG(vmSymbols::java_lang_IllegalAccessError(), + Method::name_and_sig_as_C_string(recv_klass(), + sel_method->name(), + sel_method->signature())); + } + } + else { + // Method holder is a class. Throw Illegal Access Error if sel_method + // is not public. + if (!sel_method->is_public()) { + ResourceMark rm(THREAD); + THROW_MSG(vmSymbols::java_lang_IllegalAccessError(), + Method::name_and_sig_as_C_string(recv_klass(), + sel_method->name(), + sel_method->signature())); + } } // check if abstract if (check_null_and_abstract && sel_method->is_abstract()) { diff --git a/hotspot/src/share/vm/prims/methodHandles.cpp b/hotspot/src/share/vm/prims/methodHandles.cpp index 54881388bd1..322404b85d5 100644 --- a/hotspot/src/share/vm/prims/methodHandles.cpp +++ b/hotspot/src/share/vm/prims/methodHandles.cpp @@ -187,6 +187,11 @@ oop MethodHandles::init_method_MemberName(oop mname_oop, Method* m, bool do_disp flags |= IS_CONSTRUCTOR | (JVM_REF_invokeSpecial << REFERENCE_KIND_SHIFT); } else if (mods.is_static()) { flags |= IS_METHOD | (JVM_REF_invokeStatic << REFERENCE_KIND_SHIFT); + // Check if this method is a lambda method that is generated as + // private static method. + if (m->is_private() && m->method_holder()->is_interface()) { + vmindex = klassItable::compute_itable_index(m); + } } else if (receiver_limit != mklass && !receiver_limit->is_subtype_of(mklass)) { return NULL; // bad receiver limit From 3f90a08c1353ec1e0dc4501c1006d7a603131f4d Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Fri, 19 Apr 2013 09:58:06 -0700 Subject: [PATCH 23/50] Added tag hs25-b29 for changeset 4beed8bc9715 --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index 6a4db95d041..77b88318538 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -334,3 +334,4 @@ a947f40fb536e5b9e0aa210cf26abb430f80887a hs25-b26 09b0d3e9ba6cdf7da07d4010d2d1df14596f6864 hs25-b27 6d88a566d369f6a1f86912cad7d0912686b2fda1 hs25-b28 86db4847f195c0ecceea646431f1ff22d56282e8 jdk8-b86 +01d5f04e64dc2d64625b2db2056f5ed4de918a45 hs25-b29 From 94d9107a7b3f68001a81dc9835c7079377dca88b Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Fri, 19 Apr 2013 10:09:11 -0700 Subject: [PATCH 24/50] 8012559: new hotspot build - hs25-b30 Reviewed-by: jcoomes --- hotspot/make/hotspot_version | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/make/hotspot_version b/hotspot/make/hotspot_version index 2f5b12ddbc2..c849744c890 100644 --- a/hotspot/make/hotspot_version +++ b/hotspot/make/hotspot_version @@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2013 HS_MAJOR_VER=25 HS_MINOR_VER=0 -HS_BUILD_NUMBER=29 +HS_BUILD_NUMBER=30 JDK_MAJOR_VER=1 JDK_MINOR_VER=8 From 735ab2cd1cfd3eecfe41646fb2e07bf9d458e68d Mon Sep 17 00:00:00 2001 From: Yumin Qi Date: Fri, 19 Apr 2013 11:08:52 -0700 Subject: [PATCH 25/50] 8010992: Remove calls to global ::operator new[] and new Disable use of global operator new and new[] which could cause unexpected exception and escape from NMT tracking. Reviewed-by: coleenp, dholmes, zgu --- hotspot/src/os/windows/vm/os_windows.cpp | 2 +- hotspot/src/share/vm/classfile/altHashing.cpp | 6 +- .../cmsCollectorPolicy.cpp | 4 +- .../gc_implementation/g1/heapRegionRemSet.cpp | 5 +- hotspot/src/share/vm/memory/allocation.cpp | 45 ++++++--- hotspot/src/share/vm/memory/allocation.hpp | 97 +++++++++++++++++-- .../src/share/vm/memory/allocation.inline.hpp | 29 ++++-- .../src/share/vm/memory/cardTableModRefBS.cpp | 43 ++++++-- .../src/share/vm/memory/cardTableModRefBS.hpp | 3 +- hotspot/src/share/vm/memory/cardTableRS.cpp | 17 +++- hotspot/src/share/vm/memory/cardTableRS.hpp | 3 +- .../src/share/vm/memory/collectorPolicy.cpp | 2 +- .../src/share/vm/opto/idealGraphPrinter.hpp | 11 +-- hotspot/src/share/vm/runtime/handles.hpp | 10 +- .../src/share/vm/runtime/reflectionUtils.hpp | 6 +- hotspot/src/share/vm/runtime/synchronizer.cpp | 3 +- hotspot/src/share/vm/runtime/thread.cpp | 8 +- hotspot/src/share/vm/runtime/vmStructs.cpp | 12 +-- hotspot/src/share/vm/utilities/events.hpp | 4 +- hotspot/src/share/vm/utilities/quickSort.cpp | 12 ++- hotspot/src/share/vm/utilities/workgroup.cpp | 5 +- hotspot/src/share/vm/utilities/workgroup.hpp | 4 +- 22 files changed, 238 insertions(+), 93 deletions(-) diff --git a/hotspot/src/os/windows/vm/os_windows.cpp b/hotspot/src/os/windows/vm/os_windows.cpp index 0a8034d3217..4434da815d0 100644 --- a/hotspot/src/os/windows/vm/os_windows.cpp +++ b/hotspot/src/os/windows/vm/os_windows.cpp @@ -3305,7 +3305,7 @@ void os::pd_start_thread(Thread* thread) { assert(ret != SYS_THREAD_ERROR, "StartThread failed"); // should propagate back } -class HighResolutionInterval { +class HighResolutionInterval : public CHeapObj { // The default timer resolution seems to be 10 milliseconds. // (Where is this written down?) // If someone wants to sleep for only a fraction of the default, diff --git a/hotspot/src/share/vm/classfile/altHashing.cpp b/hotspot/src/share/vm/classfile/altHashing.cpp index df2c53e5501..8dfc3153ca4 100644 --- a/hotspot/src/share/vm/classfile/altHashing.cpp +++ b/hotspot/src/share/vm/classfile/altHashing.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -242,8 +242,8 @@ static const juint MURMUR3_32_X86_CHECK_VALUE = 0xB0F57EE3; void AltHashing::testMurmur3_32_ByteArray() { // printf("testMurmur3_32_ByteArray\n"); - jbyte* vector = new jbyte[256]; - jbyte* hashes = new jbyte[4 * 256]; + jbyte vector[256]; + jbyte hashes[4 * 256]; for (int i = 0; i < 256; i++) { vector[i] = (jbyte) i; diff --git a/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp b/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp index e57d405e5d0..c2aafb7bc20 100644 --- a/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp +++ b/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,7 +52,7 @@ ConcurrentMarkSweepPolicy::ConcurrentMarkSweepPolicy() { } void ConcurrentMarkSweepPolicy::initialize_generations() { - _generations = new GenerationSpecPtr[number_of_generations()]; + _generations = NEW_C_HEAP_ARRAY3(GenerationSpecPtr, number_of_generations(), mtGC, 0, AllocFailStrategy::RETURN_NULL); if (_generations == NULL) vm_exit_during_initialization("Unable to allocate gen spec"); diff --git a/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp b/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp index 56e94051c3a..a1ea68998fe 100644 --- a/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp +++ b/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -282,7 +282,8 @@ OtherRegionsTable::OtherRegionsTable(HeapRegion* hr) : _fine_eviction_stride = _max_fine_entries / _fine_eviction_sample_size; } - _fine_grain_regions = new PerRegionTablePtr[_max_fine_entries]; + _fine_grain_regions = NEW_C_HEAP_ARRAY3(PerRegionTablePtr, _max_fine_entries, + mtGC, 0, AllocFailStrategy::RETURN_NULL); if (_fine_grain_regions == NULL) { vm_exit_out_of_memory(sizeof(void*)*_max_fine_entries, diff --git a/hotspot/src/share/vm/memory/allocation.cpp b/hotspot/src/share/vm/memory/allocation.cpp index f83eada8192..18f758ab921 100644 --- a/hotspot/src/share/vm/memory/allocation.cpp +++ b/hotspot/src/share/vm/memory/allocation.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -51,8 +51,12 @@ void* StackObj::operator new(size_t size) { ShouldNotCallThis(); return 0; }; void StackObj::operator delete(void* p) { ShouldNotCallThis(); }; +void* StackObj::operator new [](size_t size) { ShouldNotCallThis(); return 0; }; +void StackObj::operator delete [](void* p) { ShouldNotCallThis(); }; void* _ValueObj::operator new(size_t size) { ShouldNotCallThis(); return 0; }; void _ValueObj::operator delete(void* p) { ShouldNotCallThis(); }; +void* _ValueObj::operator new [](size_t size) { ShouldNotCallThis(); return 0; }; +void _ValueObj::operator delete [](void* p) { ShouldNotCallThis(); }; void* MetaspaceObj::operator new(size_t size, ClassLoaderData* loader_data, size_t word_size, bool read_only, TRAPS) { @@ -81,7 +85,6 @@ void MetaspaceObj::print_address_on(outputStream* st) const { st->print(" {"INTPTR_FORMAT"}", this); } - void* ResourceObj::operator new(size_t size, allocation_type type, MEMFLAGS flags) { address res; switch (type) { @@ -99,6 +102,10 @@ void* ResourceObj::operator new(size_t size, allocation_type type, MEMFLAGS flag return res; } +void* ResourceObj::operator new [](size_t size, allocation_type type, MEMFLAGS flags) { + return (address) operator new(size, type, flags); +} + void* ResourceObj::operator new(size_t size, const std::nothrow_t& nothrow_constant, allocation_type type, MEMFLAGS flags) { //should only call this with std::nothrow, use other operator new() otherwise @@ -118,6 +125,10 @@ void* ResourceObj::operator new(size_t size, const std::nothrow_t& nothrow_cons return res; } +void* ResourceObj::operator new [](size_t size, const std::nothrow_t& nothrow_constant, + allocation_type type, MEMFLAGS flags) { + return (address)operator new(size, nothrow_constant, type, flags); +} void ResourceObj::operator delete(void* p) { assert(((ResourceObj *)p)->allocated_on_C_heap(), @@ -126,6 +137,10 @@ void ResourceObj::operator delete(void* p) { FreeHeap(p); } +void ResourceObj::operator delete [](void* p) { + operator delete(p); +} + #ifdef ASSERT void ResourceObj::set_allocation_type(address res, allocation_type type) { // Set allocation type in the resource object @@ -360,7 +375,7 @@ class ChunkPoolCleaner : public PeriodicTask { void* Chunk::operator new(size_t requested_size, size_t length) { // requested_size is equal to sizeof(Chunk) but in order for the arena // allocations to come out aligned as expected the size must be aligned - // to expected arean alignment. + // to expected arena alignment. // expect requested_size but if sizeof(Chunk) doesn't match isn't proper size we must align it. assert(ARENA_ALIGN(requested_size) == aligned_overhead_size(), "Bad alignment"); size_t bytes = ARENA_ALIGN(requested_size) + length; @@ -669,19 +684,21 @@ void* Arena::internal_malloc_4(size_t x) { // a memory leak. Use CHeapObj as the base class of such objects to make it explicit // that they're allocated on the C heap. // Commented out in product version to avoid conflicts with third-party C++ native code. -// %% note this is causing a problem on solaris debug build. the global -// new is being called from jdk source and causing data corruption. -// src/share/native/sun/awt/font/fontmanager/textcache/hsMemory.cpp::hsSoftNew -// define CATCH_OPERATOR_NEW_USAGE if you want to use this. -#ifdef CATCH_OPERATOR_NEW_USAGE void* operator new(size_t size){ - static bool warned = false; - if (!warned && warn_new_operator) - warning("should not call global (default) operator new"); - warned = true; - return (void *) AllocateHeap(size, "global operator new"); + ShouldNotReachHere(); return 0; +} + +void* operator new [](size_t size){ + ShouldNotReachHere(); return 0; +} + +void* operator new(size_t size, const std::nothrow_t& nothrow_constant){ + ShouldNotReachHere(); return 0; +} + +void* operator new [](size_t size, std::nothrow_t& nothrow_constant){ + ShouldNotReachHere(); return 0; } -#endif void AllocatedObj::print() const { print_on(tty); } void AllocatedObj::print_value() const { print_value_on(tty); } diff --git a/hotspot/src/share/vm/memory/allocation.hpp b/hotspot/src/share/vm/memory/allocation.hpp index bc01b0135b0..7e5616e8560 100644 --- a/hotspot/src/share/vm/memory/allocation.hpp +++ b/hotspot/src/share/vm/memory/allocation.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -86,12 +86,24 @@ typedef AllocFailStrategy::AllocFailEnum AllocFailType; // subclasses. // // The following macros and function should be used to allocate memory -// directly in the resource area or in the C-heap: +// directly in the resource area or in the C-heap, The _OBJECT variants +// of the NEW_C_HEAP macros are used when a constructor and destructor +// must be invoked for the object(s) and the objects are not inherited +// from CHeapObj. The preferable way to allocate objects is using the +// new operator. +// +// WARNING: The array variant must only be used for a homogenous array +// where all objects are of the exact type specified. If subtypes are +// stored in the array then the incorrect destructor might be called. // // NEW_RESOURCE_ARRAY(type,size) // NEW_RESOURCE_OBJ(type) // NEW_C_HEAP_ARRAY(type,size) // NEW_C_HEAP_OBJ(type) +// NEW_C_HEAP_OBJECT(type, memflags, pc, allocfail) +// NEW_C_HEAP_OBJECT_ARRAY(type, size, memflags, pc, allocfail) +// FREE_C_HEAP_OBJECT(type, objname, memflags) +// FREE_C_HEAP_OBJECT_ARRAY(type, size, arrayname, memflags) // char* AllocateHeap(size_t size, const char* name); // void FreeHeap(void* p); // @@ -195,8 +207,11 @@ template class CHeapObj ALLOCATION_SUPER_CLASS_SPEC { _NOINLINE_ void* operator new(size_t size, address caller_pc = 0); _NOINLINE_ void* operator new (size_t size, const std::nothrow_t& nothrow_constant, address caller_pc = 0); - + _NOINLINE_ void* operator new [](size_t size, address caller_pc = 0); + _NOINLINE_ void* operator new [](size_t size, const std::nothrow_t& nothrow_constant, + address caller_pc = 0); void operator delete(void* p); + void operator delete [] (void* p); }; // Base class for objects allocated on the stack only. @@ -206,6 +221,8 @@ class StackObj ALLOCATION_SUPER_CLASS_SPEC { private: void* operator new(size_t size); void operator delete(void* p); + void* operator new [](size_t size); + void operator delete [](void* p); }; // Base class for objects used as value objects. @@ -229,7 +246,9 @@ class StackObj ALLOCATION_SUPER_CLASS_SPEC { class _ValueObj { private: void* operator new(size_t size); - void operator delete(void* p); + void operator delete(void* p); + void* operator new [](size_t size); + void operator delete [](void* p); }; @@ -510,13 +529,24 @@ class ResourceObj ALLOCATION_SUPER_CLASS_SPEC { public: void* operator new(size_t size, allocation_type type, MEMFLAGS flags); + void* operator new [](size_t size, allocation_type type, MEMFLAGS flags); void* operator new(size_t size, const std::nothrow_t& nothrow_constant, allocation_type type, MEMFLAGS flags); + void* operator new [](size_t size, const std::nothrow_t& nothrow_constant, + allocation_type type, MEMFLAGS flags); + void* operator new(size_t size, Arena *arena) { address res = (address)arena->Amalloc(size); DEBUG_ONLY(set_allocation_type(res, ARENA);) return res; } + + void* operator new [](size_t size, Arena *arena) { + address res = (address)arena->Amalloc(size); + DEBUG_ONLY(set_allocation_type(res, ARENA);) + return res; + } + void* operator new(size_t size) { address res = (address)resource_allocate_bytes(size); DEBUG_ONLY(set_allocation_type(res, RESOURCE_AREA);) @@ -529,7 +559,20 @@ class ResourceObj ALLOCATION_SUPER_CLASS_SPEC { return res; } + void* operator new [](size_t size) { + address res = (address)resource_allocate_bytes(size); + DEBUG_ONLY(set_allocation_type(res, RESOURCE_AREA);) + return res; + } + + void* operator new [](size_t size, const std::nothrow_t& nothrow_constant) { + address res = (address)resource_allocate_bytes(size, AllocFailStrategy::RETURN_NULL); + DEBUG_ONLY(if (res != NULL) set_allocation_type(res, RESOURCE_AREA);) + return res; + } + void operator delete(void* p); + void operator delete [](void* p); }; // One of the following macros must be used when allocating an array @@ -560,22 +603,60 @@ class ResourceObj ALLOCATION_SUPER_CLASS_SPEC { #define REALLOC_C_HEAP_ARRAY(type, old, size, memflags)\ (type*) (ReallocateHeap((char*)old, (size) * sizeof(type), memflags)) -#define FREE_C_HEAP_ARRAY(type,old,memflags) \ +#define FREE_C_HEAP_ARRAY(type, old, memflags) \ FreeHeap((char*)(old), memflags) +// allocate type in heap without calling ctor +// WARNING: type must not have virtual functions!!! There is no way to initialize vtable. #define NEW_C_HEAP_OBJ(type, memflags)\ NEW_C_HEAP_ARRAY(type, 1, memflags) - #define NEW_C_HEAP_ARRAY2(type, size, memflags, pc)\ (type*) (AllocateHeap((size) * sizeof(type), memflags, pc)) #define REALLOC_C_HEAP_ARRAY2(type, old, size, memflags, pc)\ (type*) (ReallocateHeap((char*)old, (size) * sizeof(type), memflags, pc)) -#define NEW_C_HEAP_OBJ2(type, memflags, pc)\ - NEW_C_HEAP_ARRAY2(type, 1, memflags, pc) +#define NEW_C_HEAP_ARRAY3(type, size, memflags, pc, allocfail) \ + (type*) AllocateHeap(size * sizeof(type), memflags, pc, allocfail); +// !!! Attention, see comments above about the usage !!! + +// allocate type in heap and call ctor +#define NEW_C_HEAP_OBJECT(objname, type, memflags, pc, allocfail)\ + { \ + objname = (type*)AllocateHeap(sizeof(type), memflags, pc, allocfail); \ + if (objname != NULL) ::new ((void *)objname) type(); \ + } + +// allocate array of type, call ctor for every element in the array +#define NEW_C_HEAP_OBJECT_ARRAY(array_name, type, size, memflags, pc, allocfail) \ + { \ + array_name = (type*)AllocateHeap(size * sizeof(type), memflags, pc, allocfail); \ + if (array_name != NULL) { \ + for (int index = 0; index < size; index++) { \ + ::new ((void*)&array_name[index]) type(); \ + } \ + } \ + } + +// deallocate type in heap, call dtor +#define FREE_C_HEAP_OBJECT(type, objname, memflags) \ + if (objname != NULL) { \ + ((type*)objname)->~type(); \ + FREE_C_HEAP_ARRAY(type, objname, memflags); \ + } + +// deallocate array of type with size, call dtor for every element in the array +#define FREE_C_HEAP_OBJECT_ARRAY(type, array_name, size, memflags) \ + { \ + if (array_name != NULL) { \ + for (int index = 0; index < size; index++) { \ + ((type*)&array_name[index])->~type(); \ + } \ + FREE_C_HEAP_ARRAY(type, array_name, memflags); \ + } \ + } extern bool warn_new_operator; diff --git a/hotspot/src/share/vm/memory/allocation.inline.hpp b/hotspot/src/share/vm/memory/allocation.inline.hpp index 79bd774e358..628b2a29e7f 100644 --- a/hotspot/src/share/vm/memory/allocation.inline.hpp +++ b/hotspot/src/share/vm/memory/allocation.inline.hpp @@ -82,30 +82,39 @@ inline void FreeHeap(void* p, MEMFLAGS memflags = mtInternal) { template void* CHeapObj::operator new(size_t size, address caller_pc){ -#ifdef ASSERT void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC)); +#ifdef ASSERT if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p); - return p; -#else - return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC)); #endif + return p; } template void* CHeapObj::operator new (size_t size, const std::nothrow_t& nothrow_constant, address caller_pc) { -#ifdef ASSERT void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC), AllocFailStrategy::RETURN_NULL); +#ifdef ASSERT if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p); - return p; -#else - return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC), - AllocFailStrategy::RETURN_NULL); #endif + return p; +} + +template void* CHeapObj::operator new [](size_t size, + address caller_pc){ + return CHeapObj::operator new(size, caller_pc); +} + +template void* CHeapObj::operator new [](size_t size, + const std::nothrow_t& nothrow_constant, address caller_pc) { + return CHeapObj::operator new(size, nothrow_constant, caller_pc); } template void CHeapObj::operator delete(void* p){ - FreeHeap(p, F); + FreeHeap(p, F); +} + +template void CHeapObj::operator delete [](void* p){ + FreeHeap(p, F); } template diff --git a/hotspot/src/share/vm/memory/cardTableModRefBS.cpp b/hotspot/src/share/vm/memory/cardTableModRefBS.cpp index 3c65d29a5f2..ad9a684d2b2 100644 --- a/hotspot/src/share/vm/memory/cardTableModRefBS.cpp +++ b/hotspot/src/share/vm/memory/cardTableModRefBS.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -78,17 +78,13 @@ CardTableModRefBS::CardTableModRefBS(MemRegion whole_heap, assert(card_size <= 512, "card_size must be less than 512"); // why? - _covered = new MemRegion[max_covered_regions]; - _committed = new MemRegion[max_covered_regions]; - if (_covered == NULL || _committed == NULL) + NEW_C_HEAP_OBJECT_ARRAY(_covered, MemRegion, max_covered_regions, mtGC, 0, AllocFailStrategy::RETURN_NULL); + NEW_C_HEAP_OBJECT_ARRAY(_committed, MemRegion, max_covered_regions, mtGC, 0, AllocFailStrategy::RETURN_NULL); + if (_covered == NULL || _committed == NULL) { vm_exit_during_initialization("couldn't alloc card table covered region set."); - int i; - for (i = 0; i < max_covered_regions; i++) { - _covered[i].set_word_size(0); - _committed[i].set_word_size(0); } - _cur_covered_regions = 0; + _cur_covered_regions = 0; const size_t rs_align = _page_size == (size_t) os::vm_page_size() ? 0 : MAX2(_page_size, (size_t) os::vm_allocation_granularity()); ReservedSpace heap_rs(_byte_map_size, rs_align, false); @@ -134,7 +130,7 @@ CardTableModRefBS::CardTableModRefBS(MemRegion whole_heap, || _lowest_non_clean_base_chunk_index == NULL || _last_LNC_resizing_collection == NULL) vm_exit_during_initialization("couldn't allocate an LNC array."); - for (i = 0; i < max_covered_regions; i++) { + for (int i = 0; i < max_covered_regions; i++) { _lowest_non_clean[i] = NULL; _lowest_non_clean_chunk_size[i] = 0; _last_LNC_resizing_collection[i] = -1; @@ -153,6 +149,33 @@ CardTableModRefBS::CardTableModRefBS(MemRegion whole_heap, } } +CardTableModRefBS::~CardTableModRefBS() { + if (_covered) { + FREE_C_HEAP_OBJECT_ARRAY(MemRegion, _covered, _max_covered_regions, mtGC); + _covered = NULL; + } + if (_committed) { + FREE_C_HEAP_OBJECT_ARRAY(MemRegion, _committed, _max_covered_regions, mtGC); + _committed = NULL; + } + if (_lowest_non_clean) { + FREE_C_HEAP_ARRAY(CardArr, _lowest_non_clean, mtGC); + _lowest_non_clean = NULL; + } + if (_lowest_non_clean_chunk_size) { + FREE_C_HEAP_ARRAY(size_t, _lowest_non_clean_chunk_size, mtGC); + _lowest_non_clean_chunk_size = NULL; + } + if (_lowest_non_clean_base_chunk_index) { + FREE_C_HEAP_ARRAY(uintptr_t, _lowest_non_clean_base_chunk_index, mtGC); + _lowest_non_clean_base_chunk_index = NULL; + } + if (_last_LNC_resizing_collection) { + FREE_C_HEAP_ARRAY(int, _last_LNC_resizing_collection, mtGC); + _last_LNC_resizing_collection = NULL; + } +} + int CardTableModRefBS::find_covering_region_by_base(HeapWord* base) { int i; for (i = 0; i < _cur_covered_regions; i++) { diff --git a/hotspot/src/share/vm/memory/cardTableModRefBS.hpp b/hotspot/src/share/vm/memory/cardTableModRefBS.hpp index 69af2daa8e1..6b5de2a4460 100644 --- a/hotspot/src/share/vm/memory/cardTableModRefBS.hpp +++ b/hotspot/src/share/vm/memory/cardTableModRefBS.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -280,6 +280,7 @@ public: } CardTableModRefBS(MemRegion whole_heap, int max_covered_regions); + ~CardTableModRefBS(); // *** Barrier set functions. diff --git a/hotspot/src/share/vm/memory/cardTableRS.cpp b/hotspot/src/share/vm/memory/cardTableRS.cpp index bd1cd9dd2cd..7c21869945b 100644 --- a/hotspot/src/share/vm/memory/cardTableRS.cpp +++ b/hotspot/src/share/vm/memory/cardTableRS.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -54,9 +54,10 @@ CardTableRS::CardTableRS(MemRegion whole_heap, _ct_bs = new CardTableModRefBSForCTRS(whole_heap, max_covered_regions); #endif set_bs(_ct_bs); - _last_cur_val_in_gen = new jbyte[GenCollectedHeap::max_gens + 1]; + _last_cur_val_in_gen = NEW_C_HEAP_ARRAY3(jbyte, GenCollectedHeap::max_gens + 1, + mtGC, 0, AllocFailStrategy::RETURN_NULL); if (_last_cur_val_in_gen == NULL) { - vm_exit_during_initialization("Could not last_cur_val_in_gen array."); + vm_exit_during_initialization("Could not create last_cur_val_in_gen array."); } for (int i = 0; i < GenCollectedHeap::max_gens + 1; i++) { _last_cur_val_in_gen[i] = clean_card_val(); @@ -64,6 +65,16 @@ CardTableRS::CardTableRS(MemRegion whole_heap, _ct_bs->set_CTRS(this); } +CardTableRS::~CardTableRS() { + if (_ct_bs) { + delete _ct_bs; + _ct_bs = NULL; + } + if (_last_cur_val_in_gen) { + FREE_C_HEAP_ARRAY(jbyte, _last_cur_val_in_gen, mtInternal); + } +} + void CardTableRS::resize_covered_region(MemRegion new_region) { _ct_bs->resize_covered_region(new_region); } diff --git a/hotspot/src/share/vm/memory/cardTableRS.hpp b/hotspot/src/share/vm/memory/cardTableRS.hpp index 7ac9e4162bd..234b3972db5 100644 --- a/hotspot/src/share/vm/memory/cardTableRS.hpp +++ b/hotspot/src/share/vm/memory/cardTableRS.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -102,6 +102,7 @@ class CardTableRS: public GenRemSet { public: CardTableRS(MemRegion whole_heap, int max_covered_regions); + ~CardTableRS(); // *** GenRemSet functions. GenRemSet::Name rs_kind() { return GenRemSet::CardTable; } diff --git a/hotspot/src/share/vm/memory/collectorPolicy.cpp b/hotspot/src/share/vm/memory/collectorPolicy.cpp index a2049597af7..5c190b3cf29 100644 --- a/hotspot/src/share/vm/memory/collectorPolicy.cpp +++ b/hotspot/src/share/vm/memory/collectorPolicy.cpp @@ -842,7 +842,7 @@ MarkSweepPolicy::MarkSweepPolicy() { } void MarkSweepPolicy::initialize_generations() { - _generations = new GenerationSpecPtr[number_of_generations()]; + _generations = NEW_C_HEAP_ARRAY3(GenerationSpecPtr, number_of_generations(), mtGC, 0, AllocFailStrategy::RETURN_NULL); if (_generations == NULL) vm_exit_during_initialization("Unable to allocate gen spec"); diff --git a/hotspot/src/share/vm/opto/idealGraphPrinter.hpp b/hotspot/src/share/vm/opto/idealGraphPrinter.hpp index 7d1863f4a2a..f2892d5a9c3 100644 --- a/hotspot/src/share/vm/opto/idealGraphPrinter.hpp +++ b/hotspot/src/share/vm/opto/idealGraphPrinter.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,9 +41,8 @@ class Node; class InlineTree; class ciMethod; -class IdealGraphPrinter -{ -private: +class IdealGraphPrinter : public CHeapObj { + private: static const char *INDENT; static const char *TOP_ELEMENT; @@ -121,7 +120,7 @@ private: IdealGraphPrinter(); ~IdealGraphPrinter(); -public: + public: static void clean_up(); static IdealGraphPrinter *printer(); @@ -135,8 +134,6 @@ public: void print_method(Compile* compile, const char *name, int level=1, bool clear_nodes = false); void print(Compile* compile, const char *name, Node *root, int level=1, bool clear_nodes = false); void print_xml(const char *name); - - }; #endif diff --git a/hotspot/src/share/vm/runtime/handles.hpp b/hotspot/src/share/vm/runtime/handles.hpp index 8c643d7c206..b15ed96476c 100644 --- a/hotspot/src/share/vm/runtime/handles.hpp +++ b/hotspot/src/share/vm/runtime/handles.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -280,10 +280,10 @@ class HandleArea: public Arena { // If h has to be preserved, it can be converted to an oop or a local JNI handle // across the HandleMark boundary. -// The base class of HandleMark should have been StackObj but we also heap allocate -// a HandleMark when a thread is created. +// The only special case for HandleMark is when a Thread is created, the first +// HandleMark of the Thread is allocated in heap. -class HandleMark { +class HandleMark : public StackObj { private: Thread *_thread; // thread that owns this mark HandleArea *_area; // saved handle area @@ -293,7 +293,6 @@ class HandleMark { // Link to previous active HandleMark in thread HandleMark* _previous_handle_mark; - void initialize(Thread* thread); // common code for constructors void set_previous_handle_mark(HandleMark* mark) { _previous_handle_mark = mark; } HandleMark* previous_handle_mark() const { return _previous_handle_mark; } @@ -303,6 +302,7 @@ class HandleMark { HandleMark(Thread* thread) { initialize(thread); } ~HandleMark(); + void initialize(Thread* thread); // common code for constructors // Functions used by HandleMarkCleaner // called in the constructor of HandleMarkCleaner void push(); diff --git a/hotspot/src/share/vm/runtime/reflectionUtils.hpp b/hotspot/src/share/vm/runtime/reflectionUtils.hpp index 7641fa76923..d51b2ab7874 100644 --- a/hotspot/src/share/vm/runtime/reflectionUtils.hpp +++ b/hotspot/src/share/vm/runtime/reflectionUtils.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -136,10 +136,10 @@ class FieldStream : public KlassStream { } }; -class FilteredField { +class FilteredField : public CHeapObj { private: Klass* _klass; - int _field_offset; + int _field_offset; public: FilteredField(Klass* klass, int field_offset) { diff --git a/hotspot/src/share/vm/runtime/synchronizer.cpp b/hotspot/src/share/vm/runtime/synchronizer.cpp index 6e28286c1a8..da4259ea204 100644 --- a/hotspot/src/share/vm/runtime/synchronizer.cpp +++ b/hotspot/src/share/vm/runtime/synchronizer.cpp @@ -1012,7 +1012,8 @@ ObjectMonitor * ATTR ObjectSynchronizer::omAlloc (Thread * Self) { // Both the local and global free lists are empty -- resort to malloc(). // In the current implementation objectMonitors are TSM - immortal. assert (_BLOCKSIZE > 1, "invariant") ; - ObjectMonitor * temp = new ObjectMonitor[_BLOCKSIZE]; + ObjectMonitor * temp; + NEW_C_HEAP_OBJECT_ARRAY(temp, ObjectMonitor, _BLOCKSIZE, mtInternal, 0, AllocFailStrategy::RETURN_NULL); // NOTE: (almost) no way to recover if allocation failed. // We might be able to induce a STW safepoint and scavenge enough diff --git a/hotspot/src/share/vm/runtime/thread.cpp b/hotspot/src/share/vm/runtime/thread.cpp index cf0297de099..15ac8e2b75d 100644 --- a/hotspot/src/share/vm/runtime/thread.cpp +++ b/hotspot/src/share/vm/runtime/thread.cpp @@ -228,8 +228,8 @@ Thread::Thread() { _oops_do_parity = 0; // the handle mark links itself to last_handle_mark - new HandleMark(this); - + HandleMark *hm = NEW_C_HEAP_OBJ(HandleMark, mtThread); + hm->initialize(this); // plain initialization debug_only(_owned_locks = NULL;) debug_only(_allow_allocation_count = 0;) @@ -352,8 +352,8 @@ Thread::~Thread() { // since the handle marks are using the handle area, we have to deallocated the root // handle mark before deallocating the thread's handle area, assert(last_handle_mark() != NULL, "check we have an element"); - delete last_handle_mark(); - assert(last_handle_mark() == NULL, "check we have reached the end"); + FREE_C_HEAP_OBJECT(HandleMark, last_handle_mark(), mtThread); + set_last_handle_mark(NULL); // It's possible we can encounter a null _ParkEvent, etc., in stillborn threads. // We NULL out the fields for good hygiene. diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index b00f6825ddd..429d9aca6f2 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -3116,15 +3116,15 @@ static int recursiveFindType(VMTypeEntry* origtypes, const char* typeName, bool // Search for the base type by peeling off const and * size_t len = strlen(typeName); if (typeName[len-1] == '*') { - char * s = new char[len]; + char * s = NEW_C_HEAP_ARRAY(char, len, mtInternal); strncpy(s, typeName, len - 1); s[len-1] = '\0'; // tty->print_cr("checking \"%s\" for \"%s\"", s, typeName); if (recursiveFindType(origtypes, s, true) == 1) { - delete [] s; + FREE_C_HEAP_ARRAY(char, s, mtInternal); return 1; } - delete [] s; + FREE_C_HEAP_ARRAY(char, s, mtInternal); } const char* start = NULL; if (strstr(typeName, "GrowableArray<") == typeName) { @@ -3135,15 +3135,15 @@ static int recursiveFindType(VMTypeEntry* origtypes, const char* typeName, bool if (start != NULL) { const char * end = strrchr(typeName, '>'); int len = end - start + 1; - char * s = new char[len]; + char * s = NEW_C_HEAP_ARRAY(char, len, mtInternal); strncpy(s, start, len - 1); s[len-1] = '\0'; // tty->print_cr("checking \"%s\" for \"%s\"", s, typeName); if (recursiveFindType(origtypes, s, true) == 1) { - delete [] s; + FREE_C_HEAP_ARRAY(char, s, mtInternal); return 1; } - delete [] s; + FREE_C_HEAP_ARRAY(char, s, mtInternal); } if (strstr(typeName, "const ") == typeName) { const char * s = typeName + strlen("const "); diff --git a/hotspot/src/share/vm/utilities/events.hpp b/hotspot/src/share/vm/utilities/events.hpp index c2e543da976..804fe77df2d 100644 --- a/hotspot/src/share/vm/utilities/events.hpp +++ b/hotspot/src/share/vm/utilities/events.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -69,7 +69,7 @@ class EventLog : public CHeapObj { // semantics aren't appropriate. The name is used as the label of the // log when it is dumped during a crash. template class EventLogBase : public EventLog { - template class EventRecord { + template class EventRecord : public CHeapObj { public: double timestamp; Thread* thread; diff --git a/hotspot/src/share/vm/utilities/quickSort.cpp b/hotspot/src/share/vm/utilities/quickSort.cpp index e3cfa1efa5e..86c33a208a2 100644 --- a/hotspot/src/share/vm/utilities/quickSort.cpp +++ b/hotspot/src/share/vm/utilities/quickSort.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,6 +30,8 @@ #include "runtime/os.hpp" #include "utilities/quickSort.hpp" +#include "memory/allocation.hpp" +#include "memory/allocation.inline.hpp" #include static int test_comparator(int a, int b) { @@ -187,8 +189,8 @@ void QuickSort::test_quick_sort() { // test sorting random arrays for (int i = 0; i < 1000; i++) { int length = os::random() % 100; - int* test_array = new int[length]; - int* expected_array = new int[length]; + int* test_array = NEW_C_HEAP_ARRAY(int, length, mtInternal); + int* expected_array = NEW_C_HEAP_ARRAY(int, length, mtInternal); for (int j = 0; j < length; j++) { // Choose random values, but get a chance of getting duplicates test_array[j] = os::random() % (length * 2); @@ -210,8 +212,8 @@ void QuickSort::test_quick_sort() { sort(test_array, length, test_even_odd_comparator, true); assert(compare_arrays(test_array, expected_array, length), "Sorting already sorted array changed order of elements - not idempotent"); - delete[] test_array; - delete[] expected_array; + FREE_C_HEAP_ARRAY(int, test_array, mtInternal); + FREE_C_HEAP_ARRAY(int, expected_array, mtInternal); } } diff --git a/hotspot/src/share/vm/utilities/workgroup.cpp b/hotspot/src/share/vm/utilities/workgroup.cpp index 3225ccacbb8..59d347b0407 100644 --- a/hotspot/src/share/vm/utilities/workgroup.cpp +++ b/hotspot/src/share/vm/utilities/workgroup.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -528,7 +528,7 @@ bool FreeIdSet::_safepoint; FreeIdSet::FreeIdSet(int sz, Monitor* mon) : _sz(sz), _mon(mon), _hd(0), _waiters(0), _index(-1), _claimed(0) { - _ids = new int[sz]; + _ids = NEW_C_HEAP_ARRAY(int, sz, mtInternal); for (int i = 0; i < sz; i++) _ids[i] = i+1; _ids[sz-1] = end_of_list; // end of list. if (_stat_init) { @@ -548,6 +548,7 @@ FreeIdSet::FreeIdSet(int sz, Monitor* mon) : FreeIdSet::~FreeIdSet() { _sets[_index] = NULL; + FREE_C_HEAP_ARRAY(int, _ids, mtInternal); } void FreeIdSet::set_safepoint(bool b) { diff --git a/hotspot/src/share/vm/utilities/workgroup.hpp b/hotspot/src/share/vm/utilities/workgroup.hpp index 6a93536246b..e1184a67972 100644 --- a/hotspot/src/share/vm/utilities/workgroup.hpp +++ b/hotspot/src/share/vm/utilities/workgroup.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -494,7 +494,7 @@ public: }; // Represents a set of free small integer ids. -class FreeIdSet { +class FreeIdSet : public CHeapObj { enum { end_of_list = -1, claimed = -2 From 87f3086e1301ca90adc96024512db338a7319d64 Mon Sep 17 00:00:00 2001 From: Serguei Spitsyn Date: Sat, 20 Apr 2013 04:07:08 -0700 Subject: [PATCH 26/50] 8008511: JSR 292: MemberName vmtarget refs to methods must be updated at class redefinition Lazily create and maintain the MemberNameTable to be able to update MemberName's Reviewed-by: coleenp, jrose, dholmes --- .../src/share/vm/classfile/javaClasses.cpp | 9 + .../src/share/vm/classfile/javaClasses.hpp | 3 + hotspot/src/share/vm/oops/instanceKlass.cpp | 17 ++ hotspot/src/share/vm/oops/instanceKlass.hpp | 7 + .../share/vm/prims/jvmtiRedefineClasses.cpp | 10 + hotspot/src/share/vm/prims/methodHandles.cpp | 197 +++++++++++++----- hotspot/src/share/vm/prims/methodHandles.hpp | 43 +++- hotspot/src/share/vm/runtime/mutexLocker.cpp | 2 + hotspot/src/share/vm/runtime/mutexLocker.hpp | 1 + 9 files changed, 231 insertions(+), 58 deletions(-) diff --git a/hotspot/src/share/vm/classfile/javaClasses.cpp b/hotspot/src/share/vm/classfile/javaClasses.cpp index fe03d3fb132..527da053af4 100644 --- a/hotspot/src/share/vm/classfile/javaClasses.cpp +++ b/hotspot/src/share/vm/classfile/javaClasses.cpp @@ -2625,6 +2625,15 @@ Metadata* java_lang_invoke_MemberName::vmtarget(oop mname) { return (Metadata*)mname->address_field(_vmtarget_offset); } +#if INCLUDE_JVMTI +// Can be executed on VM thread only +void java_lang_invoke_MemberName::adjust_vmtarget(oop mname, Metadata* ref) { + assert((is_instance(mname) && (flags(mname) & (MN_IS_METHOD | MN_IS_CONSTRUCTOR)) > 0), "wrong type"); + assert(Thread::current()->is_VM_thread(), "not VM thread"); + mname->address_field_put(_vmtarget_offset, (address)ref); +} +#endif // INCLUDE_JVMTI + void java_lang_invoke_MemberName::set_vmtarget(oop mname, Metadata* ref) { assert(is_instance(mname), "wrong type"); // check the type of the vmtarget diff --git a/hotspot/src/share/vm/classfile/javaClasses.hpp b/hotspot/src/share/vm/classfile/javaClasses.hpp index ac0f15e2cee..326f13e5301 100644 --- a/hotspot/src/share/vm/classfile/javaClasses.hpp +++ b/hotspot/src/share/vm/classfile/javaClasses.hpp @@ -1036,6 +1036,9 @@ class java_lang_invoke_MemberName: AllStatic { static Metadata* vmtarget(oop mname); static void set_vmtarget(oop mname, Metadata* target); +#if INCLUDE_JVMTI + static void adjust_vmtarget(oop mname, Metadata* target); +#endif // INCLUDE_JVMTI static intptr_t vmindex(oop mname); static void set_vmindex(oop mname, intptr_t index); diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index e3539f3eb8e..fa4a8077d5a 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -2329,6 +2329,12 @@ void InstanceKlass::release_C_heap_structures() { FreeHeap(jmeths); } + MemberNameTable* mnt = member_names(); + if (mnt != NULL) { + delete mnt; + set_member_names(NULL); + } + int* indices = methods_cached_itable_indices_acquire(); if (indices != (int*)NULL) { release_set_methods_cached_itable_indices(NULL); @@ -2757,6 +2763,17 @@ nmethod* InstanceKlass::lookup_osr_nmethod(Method* const m, int bci, int comp_le return NULL; } +void InstanceKlass::add_member_name(Handle mem_name) { + jweak mem_name_wref = JNIHandles::make_weak_global(mem_name); + MutexLocker ml(MemberNameTable_lock); + DEBUG_ONLY(No_Safepoint_Verifier nsv); + + if (_member_names == NULL) { + _member_names = new (ResourceObj::C_HEAP, mtClass) MemberNameTable(); + } + _member_names->add_member_name(mem_name_wref); +} + // ----------------------------------------------------------------------------------------------------- // Printing diff --git a/hotspot/src/share/vm/oops/instanceKlass.hpp b/hotspot/src/share/vm/oops/instanceKlass.hpp index 9d94b2436d9..8c557a9ea07 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.hpp +++ b/hotspot/src/share/vm/oops/instanceKlass.hpp @@ -90,6 +90,7 @@ class DepChange; class nmethodBucket; class PreviousVersionNode; class JvmtiCachedClassFieldMap; +class MemberNameTable; // This is used in iterators below. class FieldClosure: public StackObj { @@ -246,6 +247,7 @@ class InstanceKlass: public Klass { int _vtable_len; // length of Java vtable (in words) int _itable_len; // length of Java itable (in words) OopMapCache* volatile _oop_map_cache; // OopMapCache for all methods in the klass (allocated lazily) + MemberNameTable* _member_names; // Member names JNIid* _jni_ids; // First JNI identifier for static fields in this class jmethodID* _methods_jmethod_ids; // jmethodIDs corresponding to method_idnum, or NULL if none int* _methods_cached_itable_indices; // itable_index cache for JNI invoke corresponding to methods idnum, or NULL @@ -1028,6 +1030,11 @@ public: // jvm support jint compute_modifier_flags(TRAPS) const; + // JSR-292 support + MemberNameTable* member_names() { return _member_names; } + void set_member_names(MemberNameTable* member_names) { _member_names = member_names; } + void add_member_name(Handle member_name); + public: // JVMTI support jint jvmti_class_status() const; diff --git a/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp b/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp index 9eaa07a097c..a7bcd8bfb16 100644 --- a/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp +++ b/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp @@ -3284,6 +3284,16 @@ void VM_RedefineClasses::redefine_single_class(jclass the_jclass, // that reference methods of the evolved class. SystemDictionary::classes_do(adjust_cpool_cache_and_vtable, THREAD); + // JSR-292 support + MemberNameTable* mnt = the_class->member_names(); + if (mnt != NULL) { + bool trace_name_printed = false; + mnt->adjust_method_entries(_matching_old_methods, + _matching_new_methods, + _matching_methods_length, + &trace_name_printed); + } + // Fix Resolution Error table also to remove old constant pools SystemDictionary::delete_resolution_error(old_constants); diff --git a/hotspot/src/share/vm/prims/methodHandles.cpp b/hotspot/src/share/vm/prims/methodHandles.cpp index 322404b85d5..388723f6927 100644 --- a/hotspot/src/share/vm/prims/methodHandles.cpp +++ b/hotspot/src/share/vm/prims/methodHandles.cpp @@ -29,6 +29,7 @@ #include "interpreter/oopMapCache.hpp" #include "memory/allocation.inline.hpp" #include "memory/oopFactory.hpp" +#include "prims/jvmtiRedefineClassesTrace.hpp" #include "prims/methodHandles.hpp" #include "runtime/compilationPolicy.hpp" #include "runtime/javaCalls.hpp" @@ -124,7 +125,9 @@ Handle MethodHandles::new_MemberName(TRAPS) { return Handle(THREAD, k->allocate_instance(THREAD)); } -oop MethodHandles::init_MemberName(oop mname_oop, oop target_oop) { +oop MethodHandles::init_MemberName(Handle mname, Handle target) { + Thread* thread = Thread::current(); + oop target_oop = target(); Klass* target_klass = target_oop->klass(); if (target_klass == SystemDictionary::reflect_Field_klass()) { oop clazz = java_lang_reflect_Field::clazz(target_oop); // fd.field_holder() @@ -132,24 +135,24 @@ oop MethodHandles::init_MemberName(oop mname_oop, oop target_oop) { int mods = java_lang_reflect_Field::modifiers(target_oop); oop type = java_lang_reflect_Field::type(target_oop); oop name = java_lang_reflect_Field::name(target_oop); - Klass* k = java_lang_Class::as_Klass(clazz); - intptr_t offset = InstanceKlass::cast(k)->field_offset(slot); - return init_field_MemberName(mname_oop, k, accessFlags_from(mods), type, name, offset); + KlassHandle k(thread, java_lang_Class::as_Klass(clazz)); + intptr_t offset = InstanceKlass::cast(k())->field_offset(slot); + return init_field_MemberName(mname, k, accessFlags_from(mods), type, name, offset); } else if (target_klass == SystemDictionary::reflect_Method_klass()) { oop clazz = java_lang_reflect_Method::clazz(target_oop); int slot = java_lang_reflect_Method::slot(target_oop); - Klass* k = java_lang_Class::as_Klass(clazz); - if (k != NULL && k->oop_is_instance()) { - Method* m = InstanceKlass::cast(k)->method_with_idnum(slot); - return init_method_MemberName(mname_oop, m, true, k); + KlassHandle k(thread, java_lang_Class::as_Klass(clazz)); + if (!k.is_null() && k->oop_is_instance()) { + Method* m = InstanceKlass::cast(k())->method_with_idnum(slot); + return init_method_MemberName(mname, m, true, k); } } else if (target_klass == SystemDictionary::reflect_Constructor_klass()) { oop clazz = java_lang_reflect_Constructor::clazz(target_oop); int slot = java_lang_reflect_Constructor::slot(target_oop); - Klass* k = java_lang_Class::as_Klass(clazz); - if (k != NULL && k->oop_is_instance()) { - Method* m = InstanceKlass::cast(k)->method_with_idnum(slot); - return init_method_MemberName(mname_oop, m, false, k); + KlassHandle k(thread, java_lang_Class::as_Klass(clazz)); + if (!k.is_null() && k->oop_is_instance()) { + Method* m = InstanceKlass::cast(k())->method_with_idnum(slot); + return init_method_MemberName(mname, m, false, k); } } else if (target_klass == SystemDictionary::MemberName_klass()) { // Note: This only works if the MemberName has already been resolved. @@ -157,17 +160,18 @@ oop MethodHandles::init_MemberName(oop mname_oop, oop target_oop) { int flags = java_lang_invoke_MemberName::flags(target_oop); Metadata* vmtarget=java_lang_invoke_MemberName::vmtarget(target_oop); intptr_t vmindex = java_lang_invoke_MemberName::vmindex(target_oop); - Klass* k = java_lang_Class::as_Klass(clazz); + KlassHandle k(thread, java_lang_Class::as_Klass(clazz)); int ref_kind = (flags >> REFERENCE_KIND_SHIFT) & REFERENCE_KIND_MASK; if (vmtarget == NULL) return NULL; // not resolved if ((flags & IS_FIELD) != 0) { assert(vmtarget->is_klass(), "field vmtarget is Klass*"); int basic_mods = (ref_kind_is_static(ref_kind) ? JVM_ACC_STATIC : 0); // FIXME: how does k (receiver_limit) contribute? - return init_field_MemberName(mname_oop, (Klass*)vmtarget, accessFlags_from(basic_mods), NULL, NULL, vmindex); + KlassHandle k_vmtarget(thread, (Klass*)vmtarget); + return init_field_MemberName(mname, k_vmtarget, accessFlags_from(basic_mods), NULL, NULL, vmindex); } else if ((flags & (IS_METHOD | IS_CONSTRUCTOR)) != 0) { assert(vmtarget->is_method(), "method or constructor vmtarget is Method*"); - return init_method_MemberName(mname_oop, (Method*)vmtarget, ref_kind_does_dispatch(ref_kind), k); + return init_method_MemberName(mname, (Method*)vmtarget, ref_kind_does_dispatch(ref_kind), k); } else { return NULL; } @@ -175,8 +179,9 @@ oop MethodHandles::init_MemberName(oop mname_oop, oop target_oop) { return NULL; } -oop MethodHandles::init_method_MemberName(oop mname_oop, Method* m, bool do_dispatch, - Klass* receiver_limit) { +oop MethodHandles::init_method_MemberName(Handle mname, Method* m, bool do_dispatch, + KlassHandle receiver_limit_h) { + Klass* receiver_limit = receiver_limit_h(); AccessFlags mods = m->access_flags(); int flags = (jushort)( mods.as_short() & JVM_RECOGNIZED_METHOD_MODIFIERS ); int vmindex = Method::nonvirtual_vtable_index; // implies never any dispatch @@ -218,6 +223,7 @@ oop MethodHandles::init_method_MemberName(oop mname_oop, Method* m, bool do_disp flags |= CALLER_SENSITIVE; } + oop mname_oop = mname(); java_lang_invoke_MemberName::set_flags( mname_oop, flags); java_lang_invoke_MemberName::set_vmtarget(mname_oop, m); java_lang_invoke_MemberName::set_vmindex( mname_oop, vmindex); // vtable/itable index @@ -230,10 +236,11 @@ oop MethodHandles::init_method_MemberName(oop mname_oop, Method* m, bool do_disp // This is done eagerly, since it is readily available without // constructing any new objects. // TO DO: maybe intern mname_oop - return mname_oop; + m->method_holder()->add_member_name(mname); + return mname(); } -Handle MethodHandles::init_method_MemberName(oop mname_oop, CallInfo& info, TRAPS) { +Handle MethodHandles::init_method_MemberName(Handle mname, CallInfo& info, TRAPS) { Handle empty; if (info.resolved_appendix().not_null()) { // The resolved MemberName must not be accompanied by an appendix argument, @@ -253,19 +260,20 @@ Handle MethodHandles::init_method_MemberName(oop mname_oop, CallInfo& info, TRAP } else { vmindex = info.vtable_index(); } - oop res = init_method_MemberName(mname_oop, m(), (vmindex >= 0), defc()); + oop res = init_method_MemberName(mname, m(), (vmindex >= 0), defc()); assert(res == NULL || (java_lang_invoke_MemberName::vmindex(res) == vmindex), ""); return Handle(THREAD, res); } -oop MethodHandles::init_field_MemberName(oop mname_oop, Klass* field_holder, +oop MethodHandles::init_field_MemberName(Handle mname, KlassHandle field_holder, AccessFlags mods, oop type, oop name, intptr_t offset, bool is_setter) { int flags = (jushort)( mods.as_short() & JVM_RECOGNIZED_FIELD_MODIFIERS ); flags |= IS_FIELD | ((mods.is_static() ? JVM_REF_getStatic : JVM_REF_getField) << REFERENCE_KIND_SHIFT); if (is_setter) flags += ((JVM_REF_putField - JVM_REF_getField) << REFERENCE_KIND_SHIFT); - Metadata* vmtarget = field_holder; + Metadata* vmtarget = field_holder(); int vmindex = offset; // determines the field uniquely when combined with static bit + oop mname_oop = mname(); java_lang_invoke_MemberName::set_flags(mname_oop, flags); java_lang_invoke_MemberName::set_vmtarget(mname_oop, vmtarget); java_lang_invoke_MemberName::set_vmindex(mname_oop, vmindex); @@ -282,10 +290,11 @@ oop MethodHandles::init_field_MemberName(oop mname_oop, Klass* field_holder, // Although the fieldDescriptor::_index would also identify the field, // we do not use it, because it is harder to decode. // TO DO: maybe intern mname_oop - return mname_oop; + InstanceKlass::cast(field_holder())->add_member_name(mname); + return mname(); } -Handle MethodHandles::init_field_MemberName(oop mname_oop, FieldAccessInfo& info, TRAPS) { +Handle MethodHandles::init_field_MemberName(Handle mname, FieldAccessInfo& info, TRAPS) { return Handle(); #if 0 // FIXME KlassHandle field_holder = info.klass(); @@ -684,7 +693,7 @@ Handle MethodHandles::resolve_MemberName(Handle mname, TRAPS) { return empty; } } - return init_method_MemberName(mname(), result, THREAD); + return init_method_MemberName(mname, result, THREAD); } case IS_CONSTRUCTOR: { @@ -702,7 +711,7 @@ Handle MethodHandles::resolve_MemberName(Handle mname, TRAPS) { } } assert(result.is_statically_bound(), ""); - return init_method_MemberName(mname(), result, THREAD); + return init_method_MemberName(mname, result, THREAD); } case IS_FIELD: { @@ -715,7 +724,7 @@ Handle MethodHandles::resolve_MemberName(Handle mname, TRAPS) { oop name = field_name_or_null(fd.name()); bool is_setter = (ref_kind_is_valid(ref_kind) && ref_kind_is_setter(ref_kind)); mname = Handle(THREAD, - init_field_MemberName(mname(), sel_klass(), + init_field_MemberName(mname, sel_klass, fd.access_flags(), type, name, fd.offset(), is_setter)); return mname; } @@ -807,16 +816,15 @@ void MethodHandles::expand_MemberName(Handle mname, int suppress, TRAPS) { THROW_MSG(vmSymbols::java_lang_InternalError(), "unrecognized MemberName format"); } -int MethodHandles::find_MemberNames(Klass* k, +int MethodHandles::find_MemberNames(KlassHandle k, Symbol* name, Symbol* sig, - int mflags, Klass* caller, - int skip, objArrayOop results) { - DEBUG_ONLY(No_Safepoint_Verifier nsv); - // this code contains no safepoints! - + int mflags, KlassHandle caller, + int skip, objArrayHandle results) { // %%% take caller into account! - if (k == NULL || !k->oop_is_instance()) return -1; + Thread* thread = Thread::current(); + + if (k.is_null() || !k->oop_is_instance()) return -1; int rfill = 0, rlimit = results->length(), rskip = skip; // overflow measurement: @@ -844,7 +852,7 @@ int MethodHandles::find_MemberNames(Klass* k, } if ((match_flags & IS_FIELD) != 0) { - for (FieldStream st(k, local_only, !search_intfc); !st.eos(); st.next()) { + for (FieldStream st(k(), local_only, !search_intfc); !st.eos(); st.next()) { if (name != NULL && st.name() != name) continue; if (sig != NULL && st.signature() != sig) @@ -853,15 +861,15 @@ int MethodHandles::find_MemberNames(Klass* k, if (rskip > 0) { --rskip; } else if (rfill < rlimit) { - oop result = results->obj_at(rfill++); - if (!java_lang_invoke_MemberName::is_instance(result)) + Handle result(thread, results->obj_at(rfill++)); + if (!java_lang_invoke_MemberName::is_instance(result())) return -99; // caller bug! oop type = field_signature_type_or_null(st.signature()); oop name = field_name_or_null(st.name()); - oop saved = MethodHandles::init_field_MemberName(result, st.klass()(), + oop saved = MethodHandles::init_field_MemberName(result, st.klass(), st.access_flags(), type, name, st.offset()); - if (saved != result) + if (saved != result()) results->obj_at_put(rfill-1, saved); // show saved instance to user } else if (++overflow >= overflow_limit) { match_flags = 0; break; // got tired of looking at overflow @@ -894,7 +902,7 @@ int MethodHandles::find_MemberNames(Klass* k, } else { // caller will accept either sort; no need to adjust name } - for (MethodStream st(k, local_only, !search_intfc); !st.eos(); st.next()) { + for (MethodStream st(k(), local_only, !search_intfc); !st.eos(); st.next()) { Method* m = st.method(); Symbol* m_name = m->name(); if (m_name == clinit_name) @@ -907,11 +915,11 @@ int MethodHandles::find_MemberNames(Klass* k, if (rskip > 0) { --rskip; } else if (rfill < rlimit) { - oop result = results->obj_at(rfill++); - if (!java_lang_invoke_MemberName::is_instance(result)) + Handle result(thread, results->obj_at(rfill++)); + if (!java_lang_invoke_MemberName::is_instance(result())) return -99; // caller bug! oop saved = MethodHandles::init_method_MemberName(result, m, true, NULL); - if (saved != result) + if (saved != result()) results->obj_at_put(rfill-1, saved); // show saved instance to user } else if (++overflow >= overflow_limit) { match_flags = 0; break; // got tired of looking at overflow @@ -922,6 +930,99 @@ int MethodHandles::find_MemberNames(Klass* k, // return number of elements we at leasted wanted to initialize return rfill + overflow; } + +//------------------------------------------------------------------------------ +// MemberNameTable +// + +MemberNameTable::MemberNameTable() : GrowableArray(10, true) { + assert_locked_or_safepoint(MemberNameTable_lock); +} + +MemberNameTable::~MemberNameTable() { + assert_locked_or_safepoint(MemberNameTable_lock); + int len = this->length(); + + for (int idx = 0; idx < len; idx++) { + jweak ref = this->at(idx); + JNIHandles::destroy_weak_global(ref); + } +} + +// Return entry index if found, return -1 otherwise. +int MemberNameTable::find_member_name(oop mem_name) { + assert_locked_or_safepoint(MemberNameTable_lock); + int len = this->length(); + + for (int idx = 0; idx < len; idx++) { + jweak ref = this->at(idx); + oop entry = JNIHandles::resolve(ref); + if (entry == mem_name) { + return idx; + } + } + return -1; +} + +void MemberNameTable::add_member_name(jweak mem_name_wref) { + assert_locked_or_safepoint(MemberNameTable_lock); + oop mem_name = JNIHandles::resolve(mem_name_wref); + + // Each member name may appear just once: add only if not found + if (find_member_name(mem_name) == -1) { + this->append(mem_name_wref); + } +} + +#if INCLUDE_JVMTI +oop MemberNameTable::find_member_name_by_method(Method* old_method) { + assert_locked_or_safepoint(MemberNameTable_lock); + oop found = NULL; + int len = this->length(); + + for (int idx = 0; idx < len; idx++) { + oop mem_name = JNIHandles::resolve(this->at(idx)); + if (mem_name == NULL) { + continue; + } + Method* method = (Method*)java_lang_invoke_MemberName::vmtarget(mem_name); + if (method == old_method) { + found = mem_name; + break; + } + } + return found; +} + +// It is called at safepoint only +void MemberNameTable::adjust_method_entries(Method** old_methods, Method** new_methods, + int methods_length, bool *trace_name_printed) { + assert(SafepointSynchronize::is_at_safepoint(), "only called at safepoint"); + // search the MemberNameTable for uses of either obsolete or EMCP methods + for (int j = 0; j < methods_length; j++) { + Method* old_method = old_methods[j]; + Method* new_method = new_methods[j]; + oop mem_name = find_member_name_by_method(old_method); + if (mem_name != NULL) { + java_lang_invoke_MemberName::adjust_vmtarget(mem_name, new_method); + + if (RC_TRACE_IN_RANGE(0x00100000, 0x00400000)) { + if (!(*trace_name_printed)) { + // RC_TRACE_MESG macro has an embedded ResourceMark + RC_TRACE_MESG(("adjust: name=%s", + old_method->method_holder()->external_name())); + *trace_name_printed = true; + } + // RC_TRACE macro has an embedded ResourceMark + RC_TRACE(0x00400000, ("MemberName method update: %s(%s)", + new_method->name()->as_C_string(), + new_method->signature()->as_C_string())); + } + } + } +} +#endif // INCLUDE_JVMTI + // // Here are the native methods in java.lang.invoke.MethodHandleNatives // They are the private interface between this JVM and the HotSpot-specific @@ -1015,8 +1116,8 @@ JVM_ENTRY(void, MHN_init_Mem(JNIEnv *env, jobject igcls, jobject mname_jh, jobje if (mname_jh == NULL) { THROW_MSG(vmSymbols::java_lang_InternalError(), "mname is null"); } if (target_jh == NULL) { THROW_MSG(vmSymbols::java_lang_InternalError(), "target is null"); } Handle mname(THREAD, JNIHandles::resolve_non_null(mname_jh)); - oop target_oop = JNIHandles::resolve_non_null(target_jh); - MethodHandles::init_MemberName(mname(), target_oop); + Handle target(THREAD, JNIHandles::resolve_non_null(target_jh)); + MethodHandles::init_MemberName(mname, target); } JVM_END @@ -1123,7 +1224,7 @@ JVM_ENTRY(jobject, MHN_getMemberVMInfo(JNIEnv *env, jobject igcls, jobject mname x = ((Klass*) vmtarget)->java_mirror(); } else if (vmtarget->is_method()) { Handle mname2 = MethodHandles::new_MemberName(CHECK_NULL); - x = MethodHandles::init_method_MemberName(mname2(), (Method*)vmtarget, false, NULL); + x = MethodHandles::init_method_MemberName(mname2, (Method*)vmtarget, false, NULL); } result->obj_at_put(1, x); return JNIHandles::make_local(env, result()); @@ -1166,8 +1267,8 @@ JVM_ENTRY(jint, MHN_getMembers(JNIEnv *env, jobject igcls, // %%% TO DO } - int res = MethodHandles::find_MemberNames(k(), name, sig, mflags, - caller(), skip, results()); + int res = MethodHandles::find_MemberNames(k, name, sig, mflags, + caller, skip, results); // TO DO: expand at least some of the MemberNames, to avoid massive callbacks return res; } diff --git a/hotspot/src/share/vm/prims/methodHandles.hpp b/hotspot/src/share/vm/prims/methodHandles.hpp index 2e45bac1c60..f01a3c9fc1b 100644 --- a/hotspot/src/share/vm/prims/methodHandles.hpp +++ b/hotspot/src/share/vm/prims/methodHandles.hpp @@ -54,23 +54,23 @@ class MethodHandles: AllStatic { static Handle resolve_MemberName(Handle mname, TRAPS); // compute vmtarget/vmindex from name/type static void expand_MemberName(Handle mname, int suppress, TRAPS); // expand defc/name/type if missing static Handle new_MemberName(TRAPS); // must be followed by init_MemberName - static oop init_MemberName(oop mname_oop, oop target_oop); // compute vmtarget/vmindex from target - static oop init_method_MemberName(oop mname_oop, Method* m, bool do_dispatch, - Klass* receiver_limit); - static oop init_field_MemberName(oop mname_oop, Klass* field_holder, + static oop init_MemberName(Handle mname_h, Handle target_h); // compute vmtarget/vmindex from target + static oop init_method_MemberName(Handle mname_h, Method* m, bool do_dispatch, + KlassHandle receiver_limit_h); + static oop init_field_MemberName(Handle mname_h, KlassHandle field_holder_h, AccessFlags mods, oop type, oop name, intptr_t offset, bool is_setter = false); - static Handle init_method_MemberName(oop mname_oop, CallInfo& info, TRAPS); - static Handle init_field_MemberName(oop mname_oop, FieldAccessInfo& info, TRAPS); + static Handle init_method_MemberName(Handle mname_h, CallInfo& info, TRAPS); + static Handle init_field_MemberName(Handle mname_h, FieldAccessInfo& info, TRAPS); static int method_ref_kind(Method* m, bool do_dispatch_if_possible = true); - static int find_MemberNames(Klass* k, Symbol* name, Symbol* sig, - int mflags, Klass* caller, - int skip, objArrayOop results); + static int find_MemberNames(KlassHandle k, Symbol* name, Symbol* sig, + int mflags, KlassHandle caller, + int skip, objArrayHandle results); // bit values for suppress argument to expand_MemberName: enum { _suppress_defc = 1, _suppress_name = 2, _suppress_type = 4 }; // Generate MethodHandles adapters. - static void generate_adapters(); + static void generate_adapters(); // Called from MethodHandlesAdapterGenerator. static address generate_method_handle_interpreter_entry(MacroAssembler* _masm, vmIntrinsics::ID iid); @@ -230,4 +230,27 @@ public: void generate(); }; +//------------------------------------------------------------------------------ +// MemberNameTable +// +class MemberNameTable : public GrowableArray { + public: + MemberNameTable(); + ~MemberNameTable(); + void add_member_name(jweak mem_name_ref); + private: + int find_member_name(oop mem_name); + +#if INCLUDE_JVMTI + public: + // RedefineClasses() API support: + // If a MemberName refers to old_method then update it + // to refer to new_method. + void adjust_method_entries(Method** old_methods, Method** new_methods, + int methods_length, bool *trace_name_printed); + private: + oop find_member_name_by_method(Method* old_method); +#endif // INCLUDE_JVMTI +}; + #endif // SHARE_VM_PRIMS_METHODHANDLES_HPP diff --git a/hotspot/src/share/vm/runtime/mutexLocker.cpp b/hotspot/src/share/vm/runtime/mutexLocker.cpp index 31fe66f385c..c386ae8f4e8 100644 --- a/hotspot/src/share/vm/runtime/mutexLocker.cpp +++ b/hotspot/src/share/vm/runtime/mutexLocker.cpp @@ -46,6 +46,7 @@ Mutex* VMStatistic_lock = NULL; Mutex* JNIGlobalHandle_lock = NULL; Mutex* JNIHandleBlockFreeList_lock = NULL; Mutex* JNICachedItableIndex_lock = NULL; +Mutex* MemberNameTable_lock = NULL; Mutex* JmethodIdCreation_lock = NULL; Mutex* JfieldIdCreation_lock = NULL; Monitor* JNICritical_lock = NULL; @@ -252,6 +253,7 @@ void mutex_init() { def(Heap_lock , Monitor, nonleaf+1, false); def(JfieldIdCreation_lock , Mutex , nonleaf+1, true ); // jfieldID, Used in VM_Operation def(JNICachedItableIndex_lock , Mutex , nonleaf+1, false); // Used to cache an itable index during JNI invoke + def(MemberNameTable_lock , Mutex , nonleaf+1, false); // Used to protect MemberNameTable def(CompiledIC_lock , Mutex , nonleaf+2, false); // locks VtableStubs_lock, InlineCacheBuffer_lock def(CompileTaskAlloc_lock , Mutex , nonleaf+2, true ); diff --git a/hotspot/src/share/vm/runtime/mutexLocker.hpp b/hotspot/src/share/vm/runtime/mutexLocker.hpp index 7fae11b6467..7a2e240bd4f 100644 --- a/hotspot/src/share/vm/runtime/mutexLocker.hpp +++ b/hotspot/src/share/vm/runtime/mutexLocker.hpp @@ -51,6 +51,7 @@ extern Mutex* VMStatistic_lock; // a lock used to guard statist extern Mutex* JNIGlobalHandle_lock; // a lock on creating JNI global handles extern Mutex* JNIHandleBlockFreeList_lock; // a lock on the JNI handle block free list extern Mutex* JNICachedItableIndex_lock; // a lock on caching an itable index during JNI invoke +extern Mutex* MemberNameTable_lock; // a lock on the MemberNameTable updates extern Mutex* JmethodIdCreation_lock; // a lock on creating JNI method identifiers extern Mutex* JfieldIdCreation_lock; // a lock on creating JNI static field identifiers extern Monitor* JNICritical_lock; // a lock used while entering and exiting JNI critical regions, allows GC to sometimes get in From a5c3cd8ee3a25fadae645e4d8e650677b62aa3f6 Mon Sep 17 00:00:00 2001 From: Peter Allwin Date: Sat, 20 Apr 2013 19:02:11 +0200 Subject: [PATCH 27/50] 6729929: I18N - Taking Heap Dump failed if project path contains multibyte characters Reviewed-by: dholmes, rbackman --- hotspot/src/share/vm/services/management.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/services/management.cpp b/hotspot/src/share/vm/services/management.cpp index 549622e9210..aeee6ca3e9f 100644 --- a/hotspot/src/share/vm/services/management.cpp +++ b/hotspot/src/share/vm/services/management.cpp @@ -2126,7 +2126,7 @@ JVM_ENTRY(jint, jmm_DumpHeap0(JNIEnv *env, jstring outputfile, jboolean live)) THROW_MSG_(vmSymbols::java_lang_NullPointerException(), "Output file name cannot be null.", -1); } - char* name = java_lang_String::as_utf8_string(on); + char* name = java_lang_String::as_platform_dependent_str(on, CHECK_(-1)); if (name == NULL) { THROW_MSG_(vmSymbols::java_lang_NullPointerException(), "Output file name cannot be null.", -1); From 138bab2963816f6f397925f71409abfef4261530 Mon Sep 17 00:00:00 2001 From: "Daniel D. Daugherty" Date: Sun, 21 Apr 2013 20:41:04 -0700 Subject: [PATCH 28/50] 8012907: anti-delta fix for 8010992 Anti-delta fix for 8010992 until 8012902 can be fixed Reviewed-by: acorn, minqi, rdurbin --- hotspot/src/os/windows/vm/os_windows.cpp | 2 +- hotspot/src/share/vm/classfile/altHashing.cpp | 6 +- .../cmsCollectorPolicy.cpp | 4 +- .../gc_implementation/g1/heapRegionRemSet.cpp | 5 +- hotspot/src/share/vm/memory/allocation.cpp | 45 +++------ hotspot/src/share/vm/memory/allocation.hpp | 97 ++----------------- .../src/share/vm/memory/allocation.inline.hpp | 29 ++---- .../src/share/vm/memory/cardTableModRefBS.cpp | 43 ++------ .../src/share/vm/memory/cardTableModRefBS.hpp | 3 +- hotspot/src/share/vm/memory/cardTableRS.cpp | 17 +--- hotspot/src/share/vm/memory/cardTableRS.hpp | 3 +- .../src/share/vm/memory/collectorPolicy.cpp | 2 +- .../src/share/vm/opto/idealGraphPrinter.hpp | 11 ++- hotspot/src/share/vm/runtime/handles.hpp | 10 +- .../src/share/vm/runtime/reflectionUtils.hpp | 6 +- hotspot/src/share/vm/runtime/synchronizer.cpp | 3 +- hotspot/src/share/vm/runtime/thread.cpp | 8 +- hotspot/src/share/vm/runtime/vmStructs.cpp | 12 +-- hotspot/src/share/vm/utilities/events.hpp | 4 +- hotspot/src/share/vm/utilities/quickSort.cpp | 12 +-- hotspot/src/share/vm/utilities/workgroup.cpp | 5 +- hotspot/src/share/vm/utilities/workgroup.hpp | 4 +- 22 files changed, 93 insertions(+), 238 deletions(-) diff --git a/hotspot/src/os/windows/vm/os_windows.cpp b/hotspot/src/os/windows/vm/os_windows.cpp index 4434da815d0..0a8034d3217 100644 --- a/hotspot/src/os/windows/vm/os_windows.cpp +++ b/hotspot/src/os/windows/vm/os_windows.cpp @@ -3305,7 +3305,7 @@ void os::pd_start_thread(Thread* thread) { assert(ret != SYS_THREAD_ERROR, "StartThread failed"); // should propagate back } -class HighResolutionInterval : public CHeapObj { +class HighResolutionInterval { // The default timer resolution seems to be 10 milliseconds. // (Where is this written down?) // If someone wants to sleep for only a fraction of the default, diff --git a/hotspot/src/share/vm/classfile/altHashing.cpp b/hotspot/src/share/vm/classfile/altHashing.cpp index 8dfc3153ca4..df2c53e5501 100644 --- a/hotspot/src/share/vm/classfile/altHashing.cpp +++ b/hotspot/src/share/vm/classfile/altHashing.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -242,8 +242,8 @@ static const juint MURMUR3_32_X86_CHECK_VALUE = 0xB0F57EE3; void AltHashing::testMurmur3_32_ByteArray() { // printf("testMurmur3_32_ByteArray\n"); - jbyte vector[256]; - jbyte hashes[4 * 256]; + jbyte* vector = new jbyte[256]; + jbyte* hashes = new jbyte[4 * 256]; for (int i = 0; i < 256; i++) { vector[i] = (jbyte) i; diff --git a/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp b/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp index c2aafb7bc20..e57d405e5d0 100644 --- a/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp +++ b/hotspot/src/share/vm/gc_implementation/concurrentMarkSweep/cmsCollectorPolicy.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,7 +52,7 @@ ConcurrentMarkSweepPolicy::ConcurrentMarkSweepPolicy() { } void ConcurrentMarkSweepPolicy::initialize_generations() { - _generations = NEW_C_HEAP_ARRAY3(GenerationSpecPtr, number_of_generations(), mtGC, 0, AllocFailStrategy::RETURN_NULL); + _generations = new GenerationSpecPtr[number_of_generations()]; if (_generations == NULL) vm_exit_during_initialization("Unable to allocate gen spec"); diff --git a/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp b/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp index a1ea68998fe..56e94051c3a 100644 --- a/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp +++ b/hotspot/src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -282,8 +282,7 @@ OtherRegionsTable::OtherRegionsTable(HeapRegion* hr) : _fine_eviction_stride = _max_fine_entries / _fine_eviction_sample_size; } - _fine_grain_regions = NEW_C_HEAP_ARRAY3(PerRegionTablePtr, _max_fine_entries, - mtGC, 0, AllocFailStrategy::RETURN_NULL); + _fine_grain_regions = new PerRegionTablePtr[_max_fine_entries]; if (_fine_grain_regions == NULL) { vm_exit_out_of_memory(sizeof(void*)*_max_fine_entries, diff --git a/hotspot/src/share/vm/memory/allocation.cpp b/hotspot/src/share/vm/memory/allocation.cpp index 18f758ab921..f83eada8192 100644 --- a/hotspot/src/share/vm/memory/allocation.cpp +++ b/hotspot/src/share/vm/memory/allocation.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -51,12 +51,8 @@ void* StackObj::operator new(size_t size) { ShouldNotCallThis(); return 0; }; void StackObj::operator delete(void* p) { ShouldNotCallThis(); }; -void* StackObj::operator new [](size_t size) { ShouldNotCallThis(); return 0; }; -void StackObj::operator delete [](void* p) { ShouldNotCallThis(); }; void* _ValueObj::operator new(size_t size) { ShouldNotCallThis(); return 0; }; void _ValueObj::operator delete(void* p) { ShouldNotCallThis(); }; -void* _ValueObj::operator new [](size_t size) { ShouldNotCallThis(); return 0; }; -void _ValueObj::operator delete [](void* p) { ShouldNotCallThis(); }; void* MetaspaceObj::operator new(size_t size, ClassLoaderData* loader_data, size_t word_size, bool read_only, TRAPS) { @@ -85,6 +81,7 @@ void MetaspaceObj::print_address_on(outputStream* st) const { st->print(" {"INTPTR_FORMAT"}", this); } + void* ResourceObj::operator new(size_t size, allocation_type type, MEMFLAGS flags) { address res; switch (type) { @@ -102,10 +99,6 @@ void* ResourceObj::operator new(size_t size, allocation_type type, MEMFLAGS flag return res; } -void* ResourceObj::operator new [](size_t size, allocation_type type, MEMFLAGS flags) { - return (address) operator new(size, type, flags); -} - void* ResourceObj::operator new(size_t size, const std::nothrow_t& nothrow_constant, allocation_type type, MEMFLAGS flags) { //should only call this with std::nothrow, use other operator new() otherwise @@ -125,10 +118,6 @@ void* ResourceObj::operator new(size_t size, const std::nothrow_t& nothrow_cons return res; } -void* ResourceObj::operator new [](size_t size, const std::nothrow_t& nothrow_constant, - allocation_type type, MEMFLAGS flags) { - return (address)operator new(size, nothrow_constant, type, flags); -} void ResourceObj::operator delete(void* p) { assert(((ResourceObj *)p)->allocated_on_C_heap(), @@ -137,10 +126,6 @@ void ResourceObj::operator delete(void* p) { FreeHeap(p); } -void ResourceObj::operator delete [](void* p) { - operator delete(p); -} - #ifdef ASSERT void ResourceObj::set_allocation_type(address res, allocation_type type) { // Set allocation type in the resource object @@ -375,7 +360,7 @@ class ChunkPoolCleaner : public PeriodicTask { void* Chunk::operator new(size_t requested_size, size_t length) { // requested_size is equal to sizeof(Chunk) but in order for the arena // allocations to come out aligned as expected the size must be aligned - // to expected arena alignment. + // to expected arean alignment. // expect requested_size but if sizeof(Chunk) doesn't match isn't proper size we must align it. assert(ARENA_ALIGN(requested_size) == aligned_overhead_size(), "Bad alignment"); size_t bytes = ARENA_ALIGN(requested_size) + length; @@ -684,21 +669,19 @@ void* Arena::internal_malloc_4(size_t x) { // a memory leak. Use CHeapObj as the base class of such objects to make it explicit // that they're allocated on the C heap. // Commented out in product version to avoid conflicts with third-party C++ native code. +// %% note this is causing a problem on solaris debug build. the global +// new is being called from jdk source and causing data corruption. +// src/share/native/sun/awt/font/fontmanager/textcache/hsMemory.cpp::hsSoftNew +// define CATCH_OPERATOR_NEW_USAGE if you want to use this. +#ifdef CATCH_OPERATOR_NEW_USAGE void* operator new(size_t size){ - ShouldNotReachHere(); return 0; -} - -void* operator new [](size_t size){ - ShouldNotReachHere(); return 0; -} - -void* operator new(size_t size, const std::nothrow_t& nothrow_constant){ - ShouldNotReachHere(); return 0; -} - -void* operator new [](size_t size, std::nothrow_t& nothrow_constant){ - ShouldNotReachHere(); return 0; + static bool warned = false; + if (!warned && warn_new_operator) + warning("should not call global (default) operator new"); + warned = true; + return (void *) AllocateHeap(size, "global operator new"); } +#endif void AllocatedObj::print() const { print_on(tty); } void AllocatedObj::print_value() const { print_value_on(tty); } diff --git a/hotspot/src/share/vm/memory/allocation.hpp b/hotspot/src/share/vm/memory/allocation.hpp index 7e5616e8560..bc01b0135b0 100644 --- a/hotspot/src/share/vm/memory/allocation.hpp +++ b/hotspot/src/share/vm/memory/allocation.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -86,24 +86,12 @@ typedef AllocFailStrategy::AllocFailEnum AllocFailType; // subclasses. // // The following macros and function should be used to allocate memory -// directly in the resource area or in the C-heap, The _OBJECT variants -// of the NEW_C_HEAP macros are used when a constructor and destructor -// must be invoked for the object(s) and the objects are not inherited -// from CHeapObj. The preferable way to allocate objects is using the -// new operator. -// -// WARNING: The array variant must only be used for a homogenous array -// where all objects are of the exact type specified. If subtypes are -// stored in the array then the incorrect destructor might be called. +// directly in the resource area or in the C-heap: // // NEW_RESOURCE_ARRAY(type,size) // NEW_RESOURCE_OBJ(type) // NEW_C_HEAP_ARRAY(type,size) // NEW_C_HEAP_OBJ(type) -// NEW_C_HEAP_OBJECT(type, memflags, pc, allocfail) -// NEW_C_HEAP_OBJECT_ARRAY(type, size, memflags, pc, allocfail) -// FREE_C_HEAP_OBJECT(type, objname, memflags) -// FREE_C_HEAP_OBJECT_ARRAY(type, size, arrayname, memflags) // char* AllocateHeap(size_t size, const char* name); // void FreeHeap(void* p); // @@ -207,11 +195,8 @@ template class CHeapObj ALLOCATION_SUPER_CLASS_SPEC { _NOINLINE_ void* operator new(size_t size, address caller_pc = 0); _NOINLINE_ void* operator new (size_t size, const std::nothrow_t& nothrow_constant, address caller_pc = 0); - _NOINLINE_ void* operator new [](size_t size, address caller_pc = 0); - _NOINLINE_ void* operator new [](size_t size, const std::nothrow_t& nothrow_constant, - address caller_pc = 0); + void operator delete(void* p); - void operator delete [] (void* p); }; // Base class for objects allocated on the stack only. @@ -221,8 +206,6 @@ class StackObj ALLOCATION_SUPER_CLASS_SPEC { private: void* operator new(size_t size); void operator delete(void* p); - void* operator new [](size_t size); - void operator delete [](void* p); }; // Base class for objects used as value objects. @@ -246,9 +229,7 @@ class StackObj ALLOCATION_SUPER_CLASS_SPEC { class _ValueObj { private: void* operator new(size_t size); - void operator delete(void* p); - void* operator new [](size_t size); - void operator delete [](void* p); + void operator delete(void* p); }; @@ -529,24 +510,13 @@ class ResourceObj ALLOCATION_SUPER_CLASS_SPEC { public: void* operator new(size_t size, allocation_type type, MEMFLAGS flags); - void* operator new [](size_t size, allocation_type type, MEMFLAGS flags); void* operator new(size_t size, const std::nothrow_t& nothrow_constant, allocation_type type, MEMFLAGS flags); - void* operator new [](size_t size, const std::nothrow_t& nothrow_constant, - allocation_type type, MEMFLAGS flags); - void* operator new(size_t size, Arena *arena) { address res = (address)arena->Amalloc(size); DEBUG_ONLY(set_allocation_type(res, ARENA);) return res; } - - void* operator new [](size_t size, Arena *arena) { - address res = (address)arena->Amalloc(size); - DEBUG_ONLY(set_allocation_type(res, ARENA);) - return res; - } - void* operator new(size_t size) { address res = (address)resource_allocate_bytes(size); DEBUG_ONLY(set_allocation_type(res, RESOURCE_AREA);) @@ -559,20 +529,7 @@ class ResourceObj ALLOCATION_SUPER_CLASS_SPEC { return res; } - void* operator new [](size_t size) { - address res = (address)resource_allocate_bytes(size); - DEBUG_ONLY(set_allocation_type(res, RESOURCE_AREA);) - return res; - } - - void* operator new [](size_t size, const std::nothrow_t& nothrow_constant) { - address res = (address)resource_allocate_bytes(size, AllocFailStrategy::RETURN_NULL); - DEBUG_ONLY(if (res != NULL) set_allocation_type(res, RESOURCE_AREA);) - return res; - } - void operator delete(void* p); - void operator delete [](void* p); }; // One of the following macros must be used when allocating an array @@ -603,60 +560,22 @@ class ResourceObj ALLOCATION_SUPER_CLASS_SPEC { #define REALLOC_C_HEAP_ARRAY(type, old, size, memflags)\ (type*) (ReallocateHeap((char*)old, (size) * sizeof(type), memflags)) -#define FREE_C_HEAP_ARRAY(type, old, memflags) \ +#define FREE_C_HEAP_ARRAY(type,old,memflags) \ FreeHeap((char*)(old), memflags) -// allocate type in heap without calling ctor -// WARNING: type must not have virtual functions!!! There is no way to initialize vtable. #define NEW_C_HEAP_OBJ(type, memflags)\ NEW_C_HEAP_ARRAY(type, 1, memflags) + #define NEW_C_HEAP_ARRAY2(type, size, memflags, pc)\ (type*) (AllocateHeap((size) * sizeof(type), memflags, pc)) #define REALLOC_C_HEAP_ARRAY2(type, old, size, memflags, pc)\ (type*) (ReallocateHeap((char*)old, (size) * sizeof(type), memflags, pc)) -#define NEW_C_HEAP_ARRAY3(type, size, memflags, pc, allocfail) \ - (type*) AllocateHeap(size * sizeof(type), memflags, pc, allocfail); +#define NEW_C_HEAP_OBJ2(type, memflags, pc)\ + NEW_C_HEAP_ARRAY2(type, 1, memflags, pc) -// !!! Attention, see comments above about the usage !!! - -// allocate type in heap and call ctor -#define NEW_C_HEAP_OBJECT(objname, type, memflags, pc, allocfail)\ - { \ - objname = (type*)AllocateHeap(sizeof(type), memflags, pc, allocfail); \ - if (objname != NULL) ::new ((void *)objname) type(); \ - } - -// allocate array of type, call ctor for every element in the array -#define NEW_C_HEAP_OBJECT_ARRAY(array_name, type, size, memflags, pc, allocfail) \ - { \ - array_name = (type*)AllocateHeap(size * sizeof(type), memflags, pc, allocfail); \ - if (array_name != NULL) { \ - for (int index = 0; index < size; index++) { \ - ::new ((void*)&array_name[index]) type(); \ - } \ - } \ - } - -// deallocate type in heap, call dtor -#define FREE_C_HEAP_OBJECT(type, objname, memflags) \ - if (objname != NULL) { \ - ((type*)objname)->~type(); \ - FREE_C_HEAP_ARRAY(type, objname, memflags); \ - } - -// deallocate array of type with size, call dtor for every element in the array -#define FREE_C_HEAP_OBJECT_ARRAY(type, array_name, size, memflags) \ - { \ - if (array_name != NULL) { \ - for (int index = 0; index < size; index++) { \ - ((type*)&array_name[index])->~type(); \ - } \ - FREE_C_HEAP_ARRAY(type, array_name, memflags); \ - } \ - } extern bool warn_new_operator; diff --git a/hotspot/src/share/vm/memory/allocation.inline.hpp b/hotspot/src/share/vm/memory/allocation.inline.hpp index 628b2a29e7f..79bd774e358 100644 --- a/hotspot/src/share/vm/memory/allocation.inline.hpp +++ b/hotspot/src/share/vm/memory/allocation.inline.hpp @@ -82,39 +82,30 @@ inline void FreeHeap(void* p, MEMFLAGS memflags = mtInternal) { template void* CHeapObj::operator new(size_t size, address caller_pc){ - void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC)); #ifdef ASSERT + void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC)); if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p); -#endif return p; +#else + return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC)); +#endif } template void* CHeapObj::operator new (size_t size, const std::nothrow_t& nothrow_constant, address caller_pc) { +#ifdef ASSERT void* p = (void*)AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC), AllocFailStrategy::RETURN_NULL); -#ifdef ASSERT if (PrintMallocFree) trace_heap_malloc(size, "CHeapObj-new", p); -#endif return p; -} - -template void* CHeapObj::operator new [](size_t size, - address caller_pc){ - return CHeapObj::operator new(size, caller_pc); -} - -template void* CHeapObj::operator new [](size_t size, - const std::nothrow_t& nothrow_constant, address caller_pc) { - return CHeapObj::operator new(size, nothrow_constant, caller_pc); +#else + return (void *) AllocateHeap(size, F, (caller_pc != 0 ? caller_pc : CALLER_PC), + AllocFailStrategy::RETURN_NULL); +#endif } template void CHeapObj::operator delete(void* p){ - FreeHeap(p, F); -} - -template void CHeapObj::operator delete [](void* p){ - FreeHeap(p, F); + FreeHeap(p, F); } template diff --git a/hotspot/src/share/vm/memory/cardTableModRefBS.cpp b/hotspot/src/share/vm/memory/cardTableModRefBS.cpp index ad9a684d2b2..3c65d29a5f2 100644 --- a/hotspot/src/share/vm/memory/cardTableModRefBS.cpp +++ b/hotspot/src/share/vm/memory/cardTableModRefBS.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -78,13 +78,17 @@ CardTableModRefBS::CardTableModRefBS(MemRegion whole_heap, assert(card_size <= 512, "card_size must be less than 512"); // why? - NEW_C_HEAP_OBJECT_ARRAY(_covered, MemRegion, max_covered_regions, mtGC, 0, AllocFailStrategy::RETURN_NULL); - NEW_C_HEAP_OBJECT_ARRAY(_committed, MemRegion, max_covered_regions, mtGC, 0, AllocFailStrategy::RETURN_NULL); - if (_covered == NULL || _committed == NULL) { + _covered = new MemRegion[max_covered_regions]; + _committed = new MemRegion[max_covered_regions]; + if (_covered == NULL || _committed == NULL) vm_exit_during_initialization("couldn't alloc card table covered region set."); + int i; + for (i = 0; i < max_covered_regions; i++) { + _covered[i].set_word_size(0); + _committed[i].set_word_size(0); } - _cur_covered_regions = 0; + const size_t rs_align = _page_size == (size_t) os::vm_page_size() ? 0 : MAX2(_page_size, (size_t) os::vm_allocation_granularity()); ReservedSpace heap_rs(_byte_map_size, rs_align, false); @@ -130,7 +134,7 @@ CardTableModRefBS::CardTableModRefBS(MemRegion whole_heap, || _lowest_non_clean_base_chunk_index == NULL || _last_LNC_resizing_collection == NULL) vm_exit_during_initialization("couldn't allocate an LNC array."); - for (int i = 0; i < max_covered_regions; i++) { + for (i = 0; i < max_covered_regions; i++) { _lowest_non_clean[i] = NULL; _lowest_non_clean_chunk_size[i] = 0; _last_LNC_resizing_collection[i] = -1; @@ -149,33 +153,6 @@ CardTableModRefBS::CardTableModRefBS(MemRegion whole_heap, } } -CardTableModRefBS::~CardTableModRefBS() { - if (_covered) { - FREE_C_HEAP_OBJECT_ARRAY(MemRegion, _covered, _max_covered_regions, mtGC); - _covered = NULL; - } - if (_committed) { - FREE_C_HEAP_OBJECT_ARRAY(MemRegion, _committed, _max_covered_regions, mtGC); - _committed = NULL; - } - if (_lowest_non_clean) { - FREE_C_HEAP_ARRAY(CardArr, _lowest_non_clean, mtGC); - _lowest_non_clean = NULL; - } - if (_lowest_non_clean_chunk_size) { - FREE_C_HEAP_ARRAY(size_t, _lowest_non_clean_chunk_size, mtGC); - _lowest_non_clean_chunk_size = NULL; - } - if (_lowest_non_clean_base_chunk_index) { - FREE_C_HEAP_ARRAY(uintptr_t, _lowest_non_clean_base_chunk_index, mtGC); - _lowest_non_clean_base_chunk_index = NULL; - } - if (_last_LNC_resizing_collection) { - FREE_C_HEAP_ARRAY(int, _last_LNC_resizing_collection, mtGC); - _last_LNC_resizing_collection = NULL; - } -} - int CardTableModRefBS::find_covering_region_by_base(HeapWord* base) { int i; for (i = 0; i < _cur_covered_regions; i++) { diff --git a/hotspot/src/share/vm/memory/cardTableModRefBS.hpp b/hotspot/src/share/vm/memory/cardTableModRefBS.hpp index 6b5de2a4460..69af2daa8e1 100644 --- a/hotspot/src/share/vm/memory/cardTableModRefBS.hpp +++ b/hotspot/src/share/vm/memory/cardTableModRefBS.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -280,7 +280,6 @@ public: } CardTableModRefBS(MemRegion whole_heap, int max_covered_regions); - ~CardTableModRefBS(); // *** Barrier set functions. diff --git a/hotspot/src/share/vm/memory/cardTableRS.cpp b/hotspot/src/share/vm/memory/cardTableRS.cpp index 7c21869945b..bd1cd9dd2cd 100644 --- a/hotspot/src/share/vm/memory/cardTableRS.cpp +++ b/hotspot/src/share/vm/memory/cardTableRS.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -54,10 +54,9 @@ CardTableRS::CardTableRS(MemRegion whole_heap, _ct_bs = new CardTableModRefBSForCTRS(whole_heap, max_covered_regions); #endif set_bs(_ct_bs); - _last_cur_val_in_gen = NEW_C_HEAP_ARRAY3(jbyte, GenCollectedHeap::max_gens + 1, - mtGC, 0, AllocFailStrategy::RETURN_NULL); + _last_cur_val_in_gen = new jbyte[GenCollectedHeap::max_gens + 1]; if (_last_cur_val_in_gen == NULL) { - vm_exit_during_initialization("Could not create last_cur_val_in_gen array."); + vm_exit_during_initialization("Could not last_cur_val_in_gen array."); } for (int i = 0; i < GenCollectedHeap::max_gens + 1; i++) { _last_cur_val_in_gen[i] = clean_card_val(); @@ -65,16 +64,6 @@ CardTableRS::CardTableRS(MemRegion whole_heap, _ct_bs->set_CTRS(this); } -CardTableRS::~CardTableRS() { - if (_ct_bs) { - delete _ct_bs; - _ct_bs = NULL; - } - if (_last_cur_val_in_gen) { - FREE_C_HEAP_ARRAY(jbyte, _last_cur_val_in_gen, mtInternal); - } -} - void CardTableRS::resize_covered_region(MemRegion new_region) { _ct_bs->resize_covered_region(new_region); } diff --git a/hotspot/src/share/vm/memory/cardTableRS.hpp b/hotspot/src/share/vm/memory/cardTableRS.hpp index 234b3972db5..7ac9e4162bd 100644 --- a/hotspot/src/share/vm/memory/cardTableRS.hpp +++ b/hotspot/src/share/vm/memory/cardTableRS.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -102,7 +102,6 @@ class CardTableRS: public GenRemSet { public: CardTableRS(MemRegion whole_heap, int max_covered_regions); - ~CardTableRS(); // *** GenRemSet functions. GenRemSet::Name rs_kind() { return GenRemSet::CardTable; } diff --git a/hotspot/src/share/vm/memory/collectorPolicy.cpp b/hotspot/src/share/vm/memory/collectorPolicy.cpp index 5c190b3cf29..a2049597af7 100644 --- a/hotspot/src/share/vm/memory/collectorPolicy.cpp +++ b/hotspot/src/share/vm/memory/collectorPolicy.cpp @@ -842,7 +842,7 @@ MarkSweepPolicy::MarkSweepPolicy() { } void MarkSweepPolicy::initialize_generations() { - _generations = NEW_C_HEAP_ARRAY3(GenerationSpecPtr, number_of_generations(), mtGC, 0, AllocFailStrategy::RETURN_NULL); + _generations = new GenerationSpecPtr[number_of_generations()]; if (_generations == NULL) vm_exit_during_initialization("Unable to allocate gen spec"); diff --git a/hotspot/src/share/vm/opto/idealGraphPrinter.hpp b/hotspot/src/share/vm/opto/idealGraphPrinter.hpp index f2892d5a9c3..7d1863f4a2a 100644 --- a/hotspot/src/share/vm/opto/idealGraphPrinter.hpp +++ b/hotspot/src/share/vm/opto/idealGraphPrinter.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,8 +41,9 @@ class Node; class InlineTree; class ciMethod; -class IdealGraphPrinter : public CHeapObj { - private: +class IdealGraphPrinter +{ +private: static const char *INDENT; static const char *TOP_ELEMENT; @@ -120,7 +121,7 @@ class IdealGraphPrinter : public CHeapObj { IdealGraphPrinter(); ~IdealGraphPrinter(); - public: +public: static void clean_up(); static IdealGraphPrinter *printer(); @@ -134,6 +135,8 @@ class IdealGraphPrinter : public CHeapObj { void print_method(Compile* compile, const char *name, int level=1, bool clear_nodes = false); void print(Compile* compile, const char *name, Node *root, int level=1, bool clear_nodes = false); void print_xml(const char *name); + + }; #endif diff --git a/hotspot/src/share/vm/runtime/handles.hpp b/hotspot/src/share/vm/runtime/handles.hpp index b15ed96476c..8c643d7c206 100644 --- a/hotspot/src/share/vm/runtime/handles.hpp +++ b/hotspot/src/share/vm/runtime/handles.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -280,10 +280,10 @@ class HandleArea: public Arena { // If h has to be preserved, it can be converted to an oop or a local JNI handle // across the HandleMark boundary. -// The only special case for HandleMark is when a Thread is created, the first -// HandleMark of the Thread is allocated in heap. +// The base class of HandleMark should have been StackObj but we also heap allocate +// a HandleMark when a thread is created. -class HandleMark : public StackObj { +class HandleMark { private: Thread *_thread; // thread that owns this mark HandleArea *_area; // saved handle area @@ -293,6 +293,7 @@ class HandleMark : public StackObj { // Link to previous active HandleMark in thread HandleMark* _previous_handle_mark; + void initialize(Thread* thread); // common code for constructors void set_previous_handle_mark(HandleMark* mark) { _previous_handle_mark = mark; } HandleMark* previous_handle_mark() const { return _previous_handle_mark; } @@ -302,7 +303,6 @@ class HandleMark : public StackObj { HandleMark(Thread* thread) { initialize(thread); } ~HandleMark(); - void initialize(Thread* thread); // common code for constructors // Functions used by HandleMarkCleaner // called in the constructor of HandleMarkCleaner void push(); diff --git a/hotspot/src/share/vm/runtime/reflectionUtils.hpp b/hotspot/src/share/vm/runtime/reflectionUtils.hpp index d51b2ab7874..7641fa76923 100644 --- a/hotspot/src/share/vm/runtime/reflectionUtils.hpp +++ b/hotspot/src/share/vm/runtime/reflectionUtils.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -136,10 +136,10 @@ class FieldStream : public KlassStream { } }; -class FilteredField : public CHeapObj { +class FilteredField { private: Klass* _klass; - int _field_offset; + int _field_offset; public: FilteredField(Klass* klass, int field_offset) { diff --git a/hotspot/src/share/vm/runtime/synchronizer.cpp b/hotspot/src/share/vm/runtime/synchronizer.cpp index da4259ea204..6e28286c1a8 100644 --- a/hotspot/src/share/vm/runtime/synchronizer.cpp +++ b/hotspot/src/share/vm/runtime/synchronizer.cpp @@ -1012,8 +1012,7 @@ ObjectMonitor * ATTR ObjectSynchronizer::omAlloc (Thread * Self) { // Both the local and global free lists are empty -- resort to malloc(). // In the current implementation objectMonitors are TSM - immortal. assert (_BLOCKSIZE > 1, "invariant") ; - ObjectMonitor * temp; - NEW_C_HEAP_OBJECT_ARRAY(temp, ObjectMonitor, _BLOCKSIZE, mtInternal, 0, AllocFailStrategy::RETURN_NULL); + ObjectMonitor * temp = new ObjectMonitor[_BLOCKSIZE]; // NOTE: (almost) no way to recover if allocation failed. // We might be able to induce a STW safepoint and scavenge enough diff --git a/hotspot/src/share/vm/runtime/thread.cpp b/hotspot/src/share/vm/runtime/thread.cpp index 15ac8e2b75d..cf0297de099 100644 --- a/hotspot/src/share/vm/runtime/thread.cpp +++ b/hotspot/src/share/vm/runtime/thread.cpp @@ -228,8 +228,8 @@ Thread::Thread() { _oops_do_parity = 0; // the handle mark links itself to last_handle_mark - HandleMark *hm = NEW_C_HEAP_OBJ(HandleMark, mtThread); - hm->initialize(this); + new HandleMark(this); + // plain initialization debug_only(_owned_locks = NULL;) debug_only(_allow_allocation_count = 0;) @@ -352,8 +352,8 @@ Thread::~Thread() { // since the handle marks are using the handle area, we have to deallocated the root // handle mark before deallocating the thread's handle area, assert(last_handle_mark() != NULL, "check we have an element"); - FREE_C_HEAP_OBJECT(HandleMark, last_handle_mark(), mtThread); - set_last_handle_mark(NULL); + delete last_handle_mark(); + assert(last_handle_mark() == NULL, "check we have reached the end"); // It's possible we can encounter a null _ParkEvent, etc., in stillborn threads. // We NULL out the fields for good hygiene. diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index 429d9aca6f2..b00f6825ddd 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -3116,15 +3116,15 @@ static int recursiveFindType(VMTypeEntry* origtypes, const char* typeName, bool // Search for the base type by peeling off const and * size_t len = strlen(typeName); if (typeName[len-1] == '*') { - char * s = NEW_C_HEAP_ARRAY(char, len, mtInternal); + char * s = new char[len]; strncpy(s, typeName, len - 1); s[len-1] = '\0'; // tty->print_cr("checking \"%s\" for \"%s\"", s, typeName); if (recursiveFindType(origtypes, s, true) == 1) { - FREE_C_HEAP_ARRAY(char, s, mtInternal); + delete [] s; return 1; } - FREE_C_HEAP_ARRAY(char, s, mtInternal); + delete [] s; } const char* start = NULL; if (strstr(typeName, "GrowableArray<") == typeName) { @@ -3135,15 +3135,15 @@ static int recursiveFindType(VMTypeEntry* origtypes, const char* typeName, bool if (start != NULL) { const char * end = strrchr(typeName, '>'); int len = end - start + 1; - char * s = NEW_C_HEAP_ARRAY(char, len, mtInternal); + char * s = new char[len]; strncpy(s, start, len - 1); s[len-1] = '\0'; // tty->print_cr("checking \"%s\" for \"%s\"", s, typeName); if (recursiveFindType(origtypes, s, true) == 1) { - FREE_C_HEAP_ARRAY(char, s, mtInternal); + delete [] s; return 1; } - FREE_C_HEAP_ARRAY(char, s, mtInternal); + delete [] s; } if (strstr(typeName, "const ") == typeName) { const char * s = typeName + strlen("const "); diff --git a/hotspot/src/share/vm/utilities/events.hpp b/hotspot/src/share/vm/utilities/events.hpp index 804fe77df2d..c2e543da976 100644 --- a/hotspot/src/share/vm/utilities/events.hpp +++ b/hotspot/src/share/vm/utilities/events.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -69,7 +69,7 @@ class EventLog : public CHeapObj { // semantics aren't appropriate. The name is used as the label of the // log when it is dumped during a crash. template class EventLogBase : public EventLog { - template class EventRecord : public CHeapObj { + template class EventRecord { public: double timestamp; Thread* thread; diff --git a/hotspot/src/share/vm/utilities/quickSort.cpp b/hotspot/src/share/vm/utilities/quickSort.cpp index 86c33a208a2..e3cfa1efa5e 100644 --- a/hotspot/src/share/vm/utilities/quickSort.cpp +++ b/hotspot/src/share/vm/utilities/quickSort.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,6 @@ #include "runtime/os.hpp" #include "utilities/quickSort.hpp" -#include "memory/allocation.hpp" -#include "memory/allocation.inline.hpp" #include static int test_comparator(int a, int b) { @@ -189,8 +187,8 @@ void QuickSort::test_quick_sort() { // test sorting random arrays for (int i = 0; i < 1000; i++) { int length = os::random() % 100; - int* test_array = NEW_C_HEAP_ARRAY(int, length, mtInternal); - int* expected_array = NEW_C_HEAP_ARRAY(int, length, mtInternal); + int* test_array = new int[length]; + int* expected_array = new int[length]; for (int j = 0; j < length; j++) { // Choose random values, but get a chance of getting duplicates test_array[j] = os::random() % (length * 2); @@ -212,8 +210,8 @@ void QuickSort::test_quick_sort() { sort(test_array, length, test_even_odd_comparator, true); assert(compare_arrays(test_array, expected_array, length), "Sorting already sorted array changed order of elements - not idempotent"); - FREE_C_HEAP_ARRAY(int, test_array, mtInternal); - FREE_C_HEAP_ARRAY(int, expected_array, mtInternal); + delete[] test_array; + delete[] expected_array; } } diff --git a/hotspot/src/share/vm/utilities/workgroup.cpp b/hotspot/src/share/vm/utilities/workgroup.cpp index 59d347b0407..3225ccacbb8 100644 --- a/hotspot/src/share/vm/utilities/workgroup.cpp +++ b/hotspot/src/share/vm/utilities/workgroup.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -528,7 +528,7 @@ bool FreeIdSet::_safepoint; FreeIdSet::FreeIdSet(int sz, Monitor* mon) : _sz(sz), _mon(mon), _hd(0), _waiters(0), _index(-1), _claimed(0) { - _ids = NEW_C_HEAP_ARRAY(int, sz, mtInternal); + _ids = new int[sz]; for (int i = 0; i < sz; i++) _ids[i] = i+1; _ids[sz-1] = end_of_list; // end of list. if (_stat_init) { @@ -548,7 +548,6 @@ FreeIdSet::FreeIdSet(int sz, Monitor* mon) : FreeIdSet::~FreeIdSet() { _sets[_index] = NULL; - FREE_C_HEAP_ARRAY(int, _ids, mtInternal); } void FreeIdSet::set_safepoint(bool b) { diff --git a/hotspot/src/share/vm/utilities/workgroup.hpp b/hotspot/src/share/vm/utilities/workgroup.hpp index e1184a67972..6a93536246b 100644 --- a/hotspot/src/share/vm/utilities/workgroup.hpp +++ b/hotspot/src/share/vm/utilities/workgroup.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -494,7 +494,7 @@ public: }; // Represents a set of free small integer ids. -class FreeIdSet : public CHeapObj { +class FreeIdSet { enum { end_of_list = -1, claimed = -2 From cadadd73c2cc2a34d23204b888ddbd7d3253aca1 Mon Sep 17 00:00:00 2001 From: Bharadwaj Yadavalli Date: Tue, 23 Apr 2013 08:12:14 -0700 Subject: [PATCH 29/50] 8012961: Do not restrict static interface methods to be private Lambda changes; spec 0.6.2 - remove the restriction that was added as part of recent changes made to support upcoming changes to compilation of lambda methods. Reviewed-by: dholmes, acorn --- hotspot/src/share/vm/prims/methodHandles.cpp | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/prims/methodHandles.cpp b/hotspot/src/share/vm/prims/methodHandles.cpp index 388723f6927..e5a40f43b2a 100644 --- a/hotspot/src/share/vm/prims/methodHandles.cpp +++ b/hotspot/src/share/vm/prims/methodHandles.cpp @@ -192,9 +192,8 @@ oop MethodHandles::init_method_MemberName(Handle mname, Method* m, bool do_dispa flags |= IS_CONSTRUCTOR | (JVM_REF_invokeSpecial << REFERENCE_KIND_SHIFT); } else if (mods.is_static()) { flags |= IS_METHOD | (JVM_REF_invokeStatic << REFERENCE_KIND_SHIFT); - // Check if this method is a lambda method that is generated as - // private static method. - if (m->is_private() && m->method_holder()->is_interface()) { + // Get vindex from itable if method holder is an interface. + if (m->method_holder()->is_interface()) { vmindex = klassItable::compute_itable_index(m); } } else if (receiver_limit != mklass && From 8c2c17a0677e790a5eec33db85aa94592542b51e Mon Sep 17 00:00:00 2001 From: Jiangli Zhou Date: Tue, 23 Apr 2013 12:32:17 -0400 Subject: [PATCH 30/50] 8012927: 'assert(nbits == 32 || (-(1 << nbits-1) <= x && x < ( 1 << nbits-1))) failed: value out of range' in interpreter initialization Change br_null_short() to br_null(). Reviewed-by: coleenp, hseigel --- hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp b/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp index c543e364198..d4f8b9b2341 100644 --- a/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/interp_masm_sparc.cpp @@ -2097,7 +2097,8 @@ void InterpreterMacroAssembler::get_method_counters(Register method, call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::build_method_counters), method); ld_ptr(method_counters, Rcounters); - br_null_short(Rcounters, Assembler::pn, skip); // No MethodCounters, OutOfMemory + br_null(Rcounters, false, Assembler::pn, skip); // No MethodCounters, OutOfMemory + delayed()->nop(); bind(has_counters); } From 95ce391b51be94d57a96c0221f2dc20993b3e876 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Wed, 24 Apr 2013 09:42:08 +0200 Subject: [PATCH 31/50] 8011771: runThese crashed with EAV Array bound check elimination's in block motion doesn't always reset its data structures from one step to the other. Reviewed-by: kvn, twisti --- hotspot/src/share/vm/c1/c1_RangeCheckElimination.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/c1/c1_RangeCheckElimination.cpp b/hotspot/src/share/vm/c1/c1_RangeCheckElimination.cpp index 40c448a39ed..12cdce62fee 100644 --- a/hotspot/src/share/vm/c1/c1_RangeCheckElimination.cpp +++ b/hotspot/src/share/vm/c1/c1_RangeCheckElimination.cpp @@ -459,7 +459,7 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList // Iterate over all different indices if (_optimistic) { - for (int i=0; iid()]; assert(info != NULL, "Info must not be null"); @@ -531,9 +531,7 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList remove_range_check(ai); } } - _access_indexed_info[index_instruction->id()] = NULL; } - indices.clear(); if (list_constant.length() > 1) { AccessIndexed *first = list_constant.at(0); @@ -560,6 +558,13 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList } } } + + // Clear data structures for next array + for (int i = 0; i < indices.length(); i++) { + Instruction *index_instruction = indices.at(i); + _access_indexed_info[index_instruction->id()] = NULL; + } + indices.clear(); } } From 670aea401adb4c200545ef7ff9c56a21fbf1ed91 Mon Sep 17 00:00:00 2001 From: Jiangli Zhou Date: Wed, 24 Apr 2013 18:20:04 -0400 Subject: [PATCH 32/50] 8013041: guarantee(this->is8bit(imm8)) failed: Short forward jump exceeds 8-bit offset Change jmpb() to jmp(). Reviewed-by: coleenp, rdurbin, dcubed --- hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp | 2 +- hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp index f8a55c1640b..ca3ab92f2d0 100644 --- a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp @@ -360,7 +360,7 @@ void InterpreterGenerator::generate_counter_incr(Label* overflow, Label* profile const Address mdo_invocation_counter(rax, in_bytes(MethodData::invocation_counter_offset()) + in_bytes(InvocationCounter::counter_offset())); __ increment_mask_and_jump(mdo_invocation_counter, increment, mask, rcx, false, Assembler::zero, overflow); - __ jmpb(done); + __ jmp(done); } __ bind(no_mdo); // Increment counter in MethodCounters diff --git a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp index 27e16264438..4ad577ca4c9 100644 --- a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp @@ -315,7 +315,7 @@ void InterpreterGenerator::generate_counter_incr( const Address mdo_invocation_counter(rax, in_bytes(MethodData::invocation_counter_offset()) + in_bytes(InvocationCounter::counter_offset())); __ increment_mask_and_jump(mdo_invocation_counter, increment, mask, rcx, false, Assembler::zero, overflow); - __ jmpb(done); + __ jmp(done); } __ bind(no_mdo); // Increment counter in MethodCounters From cfb277ad095eeb43c562bced2937e410efe00731 Mon Sep 17 00:00:00 2001 From: Omair Majid Date: Mon, 29 Apr 2013 12:34:30 -0400 Subject: [PATCH 33/50] 8013480: fix zero build on arm Reviewed-by: erikj --- common/autoconf/generated-configure.sh | 1956 ++++++++++++++++++------ common/autoconf/platform.m4 | 49 + common/autoconf/spec.gmk.in | 2 + 3 files changed, 1516 insertions(+), 491 deletions(-) diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index ece735837c6..eee1f4c4e54 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.67 for OpenJDK jdk8. +# Generated by GNU Autoconf 2.68 for OpenJDK jdk8. # # Report bugs to . # @@ -91,6 +91,7 @@ fi IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. +as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR @@ -216,11 +217,18 @@ IFS=$as_save_IFS # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. + # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV export CONFIG_SHELL - exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"} + case $- in # (((( + *v*x* | *x*v* ) as_opts=-vx ;; + *v* ) as_opts=-v ;; + *x* ) as_opts=-x ;; + * ) as_opts= ;; + esac + exec "$CONFIG_SHELL" $as_opts "$as_myself" ${1+"$@"} fi if test x$as_have_required = xno; then : @@ -679,6 +687,7 @@ LIBRARY_PREFIX STATIC_LIBRARY SHARED_LIBRARY OBJ_SUFFIX +COMPILER_SUPPORTS_TARGET_BITS_FLAG LIPO ac_ct_OBJDUMP OBJDUMP @@ -711,20 +720,10 @@ LD ac_ct_OBJC OBJCFLAGS OBJC -ac_ct_CXX -CXXFLAGS -CXX ac_ct_PROPER_COMPILER_CXX PROPER_COMPILER_CXX POTENTIAL_CXX TOOLS_DIR_CXX -OBJEXT -EXEEXT -ac_ct_CC -CPPFLAGS -LDFLAGS -CFLAGS -CC ac_ct_PROPER_COMPILER_CC PROPER_COMPILER_CC POTENTIAL_CC @@ -836,6 +835,16 @@ PATH_SEP SRC_ROOT ZERO_ARCHDEF ZERO_ARCHFLAG +ac_ct_CXX +CXXFLAGS +CXX +OBJEXT +EXEEXT +ac_ct_CC +CPPFLAGS +LDFLAGS +CFLAGS +CC DEFINE_CROSS_COMPILE_ARCH LP64 OPENJDK_TARGET_OS_API_DIR @@ -1032,7 +1041,6 @@ with_ccache_dir ac_precious_vars='build_alias host_alias target_alias -PKG_CONFIG CC CFLAGS LDFLAGS @@ -1041,6 +1049,7 @@ CPPFLAGS CXX CXXFLAGS CCC +PKG_CONFIG OBJC OBJCFLAGS CPP @@ -1456,7 +1465,7 @@ Try \`$0 --help' for more information" $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 - : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} + : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" ;; esac @@ -1800,7 +1809,6 @@ Optional Packages: --with-ccache-dir where to store ccache files [~/.ccache] Some influential environment variables: - PKG_CONFIG path to pkg-config utility CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L if you have libraries in a @@ -1810,6 +1818,7 @@ Some influential environment variables: you have headers in a nonstandard directory CXX C++ compiler command CXXFLAGS C++ compiler flags + PKG_CONFIG path to pkg-config utility OBJC Objective C compiler command OBJCFLAGS Objective C compiler flags CPP C preprocessor @@ -1893,7 +1902,7 @@ test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF OpenJDK configure jdk8 -generated by GNU Autoconf 2.67 +generated by GNU Autoconf 2.68 Copyright (C) 2010 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation @@ -1939,7 +1948,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_compile @@ -1977,7 +1986,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_compile @@ -2015,7 +2024,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_objc_try_compile @@ -2052,7 +2061,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_cpp @@ -2089,7 +2098,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_cpp @@ -2102,10 +2111,10 @@ fi ac_fn_cxx_check_header_mongrel () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - if eval "test \"\${$3+set}\"" = set; then : + if eval \${$3+:} false; then : { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 fi eval ac_res=\$$3 @@ -2172,7 +2181,7 @@ $as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else eval "$3=\$ac_header_compiler" @@ -2181,7 +2190,7 @@ eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_header_mongrel @@ -2222,7 +2231,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_run @@ -2236,7 +2245,7 @@ ac_fn_cxx_check_header_compile () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2254,7 +2263,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_header_compile @@ -2431,7 +2440,7 @@ rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ rm -f conftest.val fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_compute_int @@ -2477,7 +2486,7 @@ fi # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_link @@ -2490,7 +2499,7 @@ ac_fn_cxx_check_func () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2545,7 +2554,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_func @@ -2558,7 +2567,7 @@ ac_fn_c_check_header_compile () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2576,7 +2585,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_compile cat >config.log <<_ACEOF @@ -2584,7 +2593,7 @@ This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by OpenJDK $as_me jdk8, which was -generated by GNU Autoconf 2.67. Invocation command line was +generated by GNU Autoconf 2.68. Invocation command line was $ $0 $@ @@ -2842,7 +2851,7 @@ $as_echo "$as_me: loading site script $ac_site_file" >&6;} || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi done @@ -3627,6 +3636,16 @@ fi +# PLATFORM_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE], +# [RUN-IF-FALSE]) +# ------------------------------------------------------------ +# Check that the c and c++ compilers support an argument + + +# Check that the compiler supports -mX flags +# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does + + # Support macro for PLATFORM_SETUP_OPENJDK_TARGET_BITS. # Add -mX to various FLAGS variables. @@ -3764,7 +3783,7 @@ fi #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1365493306 +DATE_WHEN_GENERATED=1366642537 ############################################################################### # @@ -3802,7 +3821,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BASENAME+set}" = set; then : +if ${ac_cv_path_BASENAME+:} false; then : $as_echo_n "(cached) " >&6 else case $BASENAME in @@ -3861,7 +3880,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BASH+set}" = set; then : +if ${ac_cv_path_BASH+:} false; then : $as_echo_n "(cached) " >&6 else case $BASH in @@ -3920,7 +3939,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CAT+set}" = set; then : +if ${ac_cv_path_CAT+:} false; then : $as_echo_n "(cached) " >&6 else case $CAT in @@ -3979,7 +3998,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHMOD+set}" = set; then : +if ${ac_cv_path_CHMOD+:} false; then : $as_echo_n "(cached) " >&6 else case $CHMOD in @@ -4038,7 +4057,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CMP+set}" = set; then : +if ${ac_cv_path_CMP+:} false; then : $as_echo_n "(cached) " >&6 else case $CMP in @@ -4097,7 +4116,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_COMM+set}" = set; then : +if ${ac_cv_path_COMM+:} false; then : $as_echo_n "(cached) " >&6 else case $COMM in @@ -4156,7 +4175,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CP+set}" = set; then : +if ${ac_cv_path_CP+:} false; then : $as_echo_n "(cached) " >&6 else case $CP in @@ -4215,7 +4234,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CPIO+set}" = set; then : +if ${ac_cv_path_CPIO+:} false; then : $as_echo_n "(cached) " >&6 else case $CPIO in @@ -4274,7 +4293,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CUT+set}" = set; then : +if ${ac_cv_path_CUT+:} false; then : $as_echo_n "(cached) " >&6 else case $CUT in @@ -4333,7 +4352,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DATE+set}" = set; then : +if ${ac_cv_path_DATE+:} false; then : $as_echo_n "(cached) " >&6 else case $DATE in @@ -4392,7 +4411,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DIFF+set}" = set; then : +if ${ac_cv_path_DIFF+:} false; then : $as_echo_n "(cached) " >&6 else case $DIFF in @@ -4451,7 +4470,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DIRNAME+set}" = set; then : +if ${ac_cv_path_DIRNAME+:} false; then : $as_echo_n "(cached) " >&6 else case $DIRNAME in @@ -4510,7 +4529,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_ECHO+set}" = set; then : +if ${ac_cv_path_ECHO+:} false; then : $as_echo_n "(cached) " >&6 else case $ECHO in @@ -4569,7 +4588,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_EXPR+set}" = set; then : +if ${ac_cv_path_EXPR+:} false; then : $as_echo_n "(cached) " >&6 else case $EXPR in @@ -4628,7 +4647,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_FILE+set}" = set; then : +if ${ac_cv_path_FILE+:} false; then : $as_echo_n "(cached) " >&6 else case $FILE in @@ -4687,7 +4706,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_FIND+set}" = set; then : +if ${ac_cv_path_FIND+:} false; then : $as_echo_n "(cached) " >&6 else case $FIND in @@ -4746,7 +4765,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_HEAD+set}" = set; then : +if ${ac_cv_path_HEAD+:} false; then : $as_echo_n "(cached) " >&6 else case $HEAD in @@ -4805,7 +4824,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LN+set}" = set; then : +if ${ac_cv_path_LN+:} false; then : $as_echo_n "(cached) " >&6 else case $LN in @@ -4864,7 +4883,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LS+set}" = set; then : +if ${ac_cv_path_LS+:} false; then : $as_echo_n "(cached) " >&6 else case $LS in @@ -4923,7 +4942,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MKDIR+set}" = set; then : +if ${ac_cv_path_MKDIR+:} false; then : $as_echo_n "(cached) " >&6 else case $MKDIR in @@ -4982,7 +5001,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MKTEMP+set}" = set; then : +if ${ac_cv_path_MKTEMP+:} false; then : $as_echo_n "(cached) " >&6 else case $MKTEMP in @@ -5041,7 +5060,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MV+set}" = set; then : +if ${ac_cv_path_MV+:} false; then : $as_echo_n "(cached) " >&6 else case $MV in @@ -5100,7 +5119,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_PRINTF+set}" = set; then : +if ${ac_cv_path_PRINTF+:} false; then : $as_echo_n "(cached) " >&6 else case $PRINTF in @@ -5159,7 +5178,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_THEPWDCMD+set}" = set; then : +if ${ac_cv_path_THEPWDCMD+:} false; then : $as_echo_n "(cached) " >&6 else case $THEPWDCMD in @@ -5218,7 +5237,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_RM+set}" = set; then : +if ${ac_cv_path_RM+:} false; then : $as_echo_n "(cached) " >&6 else case $RM in @@ -5277,7 +5296,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_SH+set}" = set; then : +if ${ac_cv_path_SH+:} false; then : $as_echo_n "(cached) " >&6 else case $SH in @@ -5336,7 +5355,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_SORT+set}" = set; then : +if ${ac_cv_path_SORT+:} false; then : $as_echo_n "(cached) " >&6 else case $SORT in @@ -5395,7 +5414,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TAIL+set}" = set; then : +if ${ac_cv_path_TAIL+:} false; then : $as_echo_n "(cached) " >&6 else case $TAIL in @@ -5454,7 +5473,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TAR+set}" = set; then : +if ${ac_cv_path_TAR+:} false; then : $as_echo_n "(cached) " >&6 else case $TAR in @@ -5513,7 +5532,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TEE+set}" = set; then : +if ${ac_cv_path_TEE+:} false; then : $as_echo_n "(cached) " >&6 else case $TEE in @@ -5572,7 +5591,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TOUCH+set}" = set; then : +if ${ac_cv_path_TOUCH+:} false; then : $as_echo_n "(cached) " >&6 else case $TOUCH in @@ -5631,7 +5650,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TR+set}" = set; then : +if ${ac_cv_path_TR+:} false; then : $as_echo_n "(cached) " >&6 else case $TR in @@ -5690,7 +5709,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_UNAME+set}" = set; then : +if ${ac_cv_path_UNAME+:} false; then : $as_echo_n "(cached) " >&6 else case $UNAME in @@ -5749,7 +5768,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_UNIQ+set}" = set; then : +if ${ac_cv_path_UNIQ+:} false; then : $as_echo_n "(cached) " >&6 else case $UNIQ in @@ -5808,7 +5827,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_WC+set}" = set; then : +if ${ac_cv_path_WC+:} false; then : $as_echo_n "(cached) " >&6 else case $WC in @@ -5867,7 +5886,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_WHICH+set}" = set; then : +if ${ac_cv_path_WHICH+:} false; then : $as_echo_n "(cached) " >&6 else case $WHICH in @@ -5926,7 +5945,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_XARGS+set}" = set; then : +if ${ac_cv_path_XARGS+:} false; then : $as_echo_n "(cached) " >&6 else case $XARGS in @@ -5986,7 +6005,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_AWK+set}" = set; then : +if ${ac_cv_prog_AWK+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AWK"; then @@ -6036,7 +6055,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 $as_echo_n "checking for grep that handles long lines and -e... " >&6; } -if test "${ac_cv_path_GREP+set}" = set; then : +if ${ac_cv_path_GREP+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$GREP"; then @@ -6111,7 +6130,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 $as_echo_n "checking for egrep... " >&6; } -if test "${ac_cv_path_EGREP+set}" = set; then : +if ${ac_cv_path_EGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 @@ -6190,7 +6209,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 $as_echo_n "checking for fgrep... " >&6; } -if test "${ac_cv_path_FGREP+set}" = set; then : +if ${ac_cv_path_FGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 @@ -6269,7 +6288,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } -if test "${ac_cv_path_SED+set}" = set; then : +if ${ac_cv_path_SED+:} false; then : $as_echo_n "(cached) " >&6 else ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ @@ -6355,7 +6374,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_NAWK+set}" = set; then : +if ${ac_cv_path_NAWK+:} false; then : $as_echo_n "(cached) " >&6 else case $NAWK in @@ -6415,7 +6434,7 @@ RM="$RM -f" set dummy cygpath; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CYGPATH+set}" = set; then : +if ${ac_cv_path_CYGPATH+:} false; then : $as_echo_n "(cached) " >&6 else case $CYGPATH in @@ -6455,7 +6474,7 @@ fi set dummy readlink; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_READLINK+set}" = set; then : +if ${ac_cv_path_READLINK+:} false; then : $as_echo_n "(cached) " >&6 else case $READLINK in @@ -6495,7 +6514,7 @@ fi set dummy df; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DF+set}" = set; then : +if ${ac_cv_path_DF+:} false; then : $as_echo_n "(cached) " >&6 else case $DF in @@ -6535,7 +6554,7 @@ fi set dummy SetFile; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_SETFILE+set}" = set; then : +if ${ac_cv_path_SETFILE+:} false; then : $as_echo_n "(cached) " >&6 else case $SETFILE in @@ -6581,7 +6600,7 @@ $SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || { $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 $as_echo_n "checking build system type... " >&6; } -if test "${ac_cv_build+set}" = set; then : +if ${ac_cv_build+:} false; then : $as_echo_n "(cached) " >&6 else ac_build_alias=$build_alias @@ -6597,7 +6616,7 @@ fi $as_echo "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical build" "$LINENO" 5 ;; +*) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' @@ -6615,7 +6634,7 @@ case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 $as_echo_n "checking host system type... " >&6; } -if test "${ac_cv_host+set}" = set; then : +if ${ac_cv_host+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$host_alias" = x; then @@ -6630,7 +6649,7 @@ fi $as_echo "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical host" "$LINENO" 5 ;; +*) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' @@ -6648,7 +6667,7 @@ case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking target system type" >&5 $as_echo_n "checking target system type... " >&6; } -if test "${ac_cv_target+set}" = set; then : +if ${ac_cv_target+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$target_alias" = x; then @@ -6663,7 +6682,7 @@ fi $as_echo "$ac_cv_target" >&6; } case $ac_cv_target in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical target" "$LINENO" 5 ;; +*) as_fn_error $? "invalid value of canonical target" "$LINENO" 5;; esac target=$ac_cv_target ac_save_IFS=$IFS; IFS='-' @@ -6685,6 +6704,1055 @@ test -n "$target_alias" && test "$program_prefix$program_suffix$program_transform_name" = \ NONENONEs,x,x, && program_prefix=${target_alias}- +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. +set dummy ${ac_tool_prefix}gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +else + CC="$ac_cv_prog_CC" +fi + +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. +set dummy ${ac_tool_prefix}cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + fi +fi +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + ac_prog_rejected=no +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# != 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" + fi +fi +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + for ac_prog in cl.exe + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CC" && break + done +fi +if test -z "$CC"; then + ac_ct_CC=$CC + for ac_prog in cl.exe +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CC" && break +done + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +fi + +fi + + +test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "no acceptable C compiler found in \$PATH +See \`config.log' for more details" "$LINENO" 5; } + +# Provide some information about the compiler. +$as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +for ac_option in --version -v -V -qversion; do + { { ac_try="$ac_compiler $ac_option >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compiler $ac_option >&5") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + sed '10a\ +... rest of stderr output deleted ... + 10q' conftest.err >conftest.er1 + cat conftest.er1 >&5 + fi + rm -f conftest.er1 conftest.err + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } +done + +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" +# Try to create an executable without -o first, disregard a.out. +# It will help us diagnose broken compilers, and finding out an intuition +# of exeext. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 +$as_echo_n "checking whether the C compiler works... " >&6; } +ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` + +# The possible output files: +ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" + +ac_rmfiles= +for ac_file in $ac_files +do + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + * ) ac_rmfiles="$ac_rmfiles $ac_file";; + esac +done +rm -f $ac_rmfiles + +if { { ac_try="$ac_link_default" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link_default") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. +# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' +# in a Makefile. We should not override ac_cv_exeext if it was cached, +# so that the user can short-circuit this test for compilers unknown to +# Autoconf. +for ac_file in $ac_files '' +do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) + ;; + [ab].out ) + # We found the default executable, but exeext='' is most + # certainly right. + break;; + *.* ) + if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; + then :; else + ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + fi + # We set ac_cv_exeext here because the later test for it is not + # safe: cross compilers may not add the suffix if given an `-o' + # argument, so we may need to know it at that point already. + # Even if this section looks crufty: it has the advantage of + # actually working. + break;; + * ) + break;; + esac +done +test "$ac_cv_exeext" = no && ac_cv_exeext= + +else + ac_file='' +fi +if test -z "$ac_file"; then : + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error 77 "C compiler cannot create executables +See \`config.log' for more details" "$LINENO" 5; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 +$as_echo_n "checking for C compiler default output file name... " >&6; } +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 +$as_echo "$ac_file" >&6; } +ac_exeext=$ac_cv_exeext + +rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out +ac_clean_files=$ac_clean_files_save +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 +$as_echo_n "checking for suffix of executables... " >&6; } +if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # If both `conftest.exe' and `conftest' are `present' (well, observable) +# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will +# work properly (i.e., refer to `conftest.exe'), while it won't with +# `rm'. +for ac_file in conftest.exe conftest conftest.*; do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + break;; + * ) break;; + esac +done +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details" "$LINENO" 5; } +fi +rm -f conftest conftest$ac_cv_exeext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 +$as_echo "$ac_cv_exeext" >&6; } + +rm -f conftest.$ac_ext +EXEEXT=$ac_cv_exeext +ac_exeext=$EXEEXT +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +int +main () +{ +FILE *f = fopen ("conftest.out", "w"); + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +ac_clean_files="$ac_clean_files conftest.out" +# Check that the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 +$as_echo_n "checking whether we are cross compiling... " >&6; } +if test "$cross_compiling" != yes; then + { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } + if { ac_try='./conftest$ac_cv_exeext' + { { case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; }; then + cross_compiling=no + else + if test "$cross_compiling" = maybe; then + cross_compiling=yes + else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details" "$LINENO" 5; } + fi + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 +$as_echo "$cross_compiling" >&6; } + +rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out +ac_clean_files=$ac_clean_files_save +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 +$as_echo_n "checking for suffix of object files... " >&6; } +if ${ac_cv_objext+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.o conftest.obj +if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + for ac_file in conftest.o conftest.obj conftest.*; do + test -f "$ac_file" || continue; + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; + *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` + break;; + esac +done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot compute suffix of object files: cannot compile +See \`config.log' for more details" "$LINENO" 5; } +fi +rm -f conftest.$ac_cv_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 +$as_echo "$ac_cv_objext" >&6; } +OBJEXT=$ac_cv_objext +ac_objext=$OBJEXT +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 +$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } +if ${ac_cv_c_compiler_gnu+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_compiler_gnu=yes +else + ac_compiler_gnu=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_c_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 +$as_echo "$ac_cv_c_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GCC=yes +else + GCC= +fi +ac_test_CFLAGS=${CFLAGS+set} +ac_save_CFLAGS=$CFLAGS +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 +$as_echo_n "checking whether $CC accepts -g... " >&6; } +if ${ac_cv_prog_cc_g+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_save_c_werror_flag=$ac_c_werror_flag + ac_c_werror_flag=yes + ac_cv_prog_cc_g=no + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +else + CFLAGS="" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + ac_c_werror_flag=$ac_save_c_werror_flag + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_c_werror_flag=$ac_save_c_werror_flag +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 +$as_echo "$ac_cv_prog_cc_g" >&6; } +if test "$ac_test_CFLAGS" = set; then + CFLAGS=$ac_save_CFLAGS +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 +$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } +if ${ac_cv_prog_cc_c89+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_cv_prog_cc_c89=no +ac_save_CC=$CC +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +#include +#include +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ +struct buf { int x; }; +FILE * (*rcsopen) (struct buf *, struct stat *, int); +static char *e (p, i) + char **p; + int i; +{ + return p[i]; +} +static char *f (char * (*g) (char **, int), char **p, ...) +{ + char *s; + va_list v; + va_start (v,p); + s = g (p, va_arg (v,int)); + va_end (v); + return s; +} + +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has + function prototypes and stuff, but not '\xHH' hex character constants. + These don't provoke an error unfortunately, instead are silently treated + as 'x'. The following induces an error, until -std is added to get + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an + array size at least. It's necessary to write '\x00'==0 to get something + that's true only with -std. */ +int osf4_cc_array ['\x00' == 0 ? 1 : -1]; + +/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters + inside strings and character constants. */ +#define FOO(x) 'x' +int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; + +int test (int i, double x); +struct s1 {int (*f) (int a);}; +struct s2 {int (*f) (double a);}; +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); +int argc; +char **argv; +int +main () +{ +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; + ; + return 0; +} +_ACEOF +for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ + -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" +do + CC="$ac_save_CC $ac_arg" + if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_c89=$ac_arg +fi +rm -f core conftest.err conftest.$ac_objext + test "x$ac_cv_prog_cc_c89" != "xno" && break +done +rm -f conftest.$ac_ext +CC=$ac_save_CC + +fi +# AC_CACHE_VAL +case "x$ac_cv_prog_cc_c89" in + x) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 +$as_echo "none needed" >&6; } ;; + xno) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 +$as_echo "unsupported" >&6; } ;; + *) + CC="$CC $ac_cv_prog_cc_c89" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 +$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; +esac +if test "x$ac_cv_prog_cc_c89" != xno; then : + +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +if test -z "$CXX"; then + if test -n "$CCC"; then + CXX=$CCC + else + if test -n "$ac_tool_prefix"; then + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CXX"; then + ac_cv_prog_CXX="$CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CXX=$ac_cv_prog_CXX +if test -n "$CXX"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CXX" >&5 +$as_echo "$CXX" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CXX" && break + done +fi +if test -z "$CXX"; then + ac_ct_CXX=$CXX + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CXX"; then + ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CXX="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CXX=$ac_cv_prog_ac_ct_CXX +if test -n "$ac_ct_CXX"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CXX" >&5 +$as_echo "$ac_ct_CXX" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CXX" && break +done + + if test "x$ac_ct_CXX" = x; then + CXX="g++" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CXX=$ac_ct_CXX + fi +fi + + fi +fi +# Provide some information about the compiler. +$as_echo "$as_me:${as_lineno-$LINENO}: checking for C++ compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +for ac_option in --version -v -V -qversion; do + { { ac_try="$ac_compiler $ac_option >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compiler $ac_option >&5") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + sed '10a\ +... rest of stderr output deleted ... + 10q' conftest.err >conftest.er1 + cat conftest.er1 >&5 + fi + rm -f conftest.er1 conftest.err + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C++ compiler" >&5 +$as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } +if ${ac_cv_cxx_compiler_gnu+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + ac_compiler_gnu=yes +else + ac_compiler_gnu=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_cxx_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cxx_compiler_gnu" >&5 +$as_echo "$ac_cv_cxx_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GXX=yes +else + GXX= +fi +ac_test_CXXFLAGS=${CXXFLAGS+set} +ac_save_CXXFLAGS=$CXXFLAGS +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 +$as_echo_n "checking whether $CXX accepts -g... " >&6; } +if ${ac_cv_prog_cxx_g+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_save_cxx_werror_flag=$ac_cxx_werror_flag + ac_cxx_werror_flag=yes + ac_cv_prog_cxx_g=no + CXXFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + ac_cv_prog_cxx_g=yes +else + CXXFLAGS="" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + +else + ac_cxx_werror_flag=$ac_save_cxx_werror_flag + CXXFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + ac_cv_prog_cxx_g=yes +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_cxx_werror_flag=$ac_save_cxx_werror_flag +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cxx_g" >&5 +$as_echo "$ac_cv_prog_cxx_g" >&6; } +if test "$ac_test_CXXFLAGS" = set; then + CXXFLAGS=$ac_save_CXXFLAGS +elif test $ac_cv_prog_cxx_g = yes; then + if test "$GXX" = yes; then + CXXFLAGS="-g -O2" + else + CXXFLAGS="-g" + fi +else + if test "$GXX" = yes; then + CXXFLAGS="-O2" + else + CXXFLAGS= + fi +fi +ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + # Figure out the build and target systems. # Note that in autoconf terminology, "build" is obvious, but "target" # is confusing; it assumes you are cross-compiling a cross-compiler (!) and "target" is thus the target of the @@ -7109,6 +8177,75 @@ $as_echo "$COMPILE_TYPE" >&6; } ZERO_ARCHFLAG="-m${OPENJDK_TARGET_CPU_BITS}" esac + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$ZERO_ARCHFLAG\"" >&5 +$as_echo_n "checking if compiler supports \"$ZERO_ARCHFLAG\"... " >&6; } + supports=yes + + saved_cflags="$CFLAGS" + CFLAGS="$CFLAGS $ZERO_ARCHFLAG" + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + CFLAGS="$saved_cflags" + + saved_cxxflags="$CXXFLAGS" + CXXFLAGS="$CXXFLAG $ZERO_ARCHFLAG" + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + CXXFLAGS="$saved_cxxflags" + + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5 +$as_echo "$supports" >&6; } + if test "x$supports" = "xyes" ; then + : + else + ZERO_ARCHFLAG="" + fi + + # ZERO_ARCHDEF is used to enable architecture-specific code case "${OPENJDK_TARGET_CPU}" in @@ -8161,7 +9298,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_PKGHANDLER+set}" = set; then : +if ${ac_cv_prog_PKGHANDLER+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$PKGHANDLER"; then @@ -8526,7 +9663,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_GMAKE+set}" = set; then : +if ${ac_cv_path_CHECK_GMAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_GMAKE in @@ -8880,7 +10017,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_MAKE+set}" = set; then : +if ${ac_cv_path_CHECK_MAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_MAKE in @@ -9239,7 +10376,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_TOOLSDIR_GMAKE+set}" = set; then : +if ${ac_cv_path_CHECK_TOOLSDIR_GMAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_TOOLSDIR_GMAKE in @@ -9592,7 +10729,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_TOOLSDIR_MAKE+set}" = set; then : +if ${ac_cv_path_CHECK_TOOLSDIR_MAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_TOOLSDIR_MAKE in @@ -9988,7 +11125,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_UNZIP+set}" = set; then : +if ${ac_cv_path_UNZIP+:} false; then : $as_echo_n "(cached) " >&6 else case $UNZIP in @@ -10047,7 +11184,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_ZIP+set}" = set; then : +if ${ac_cv_path_ZIP+:} false; then : $as_echo_n "(cached) " >&6 else case $ZIP in @@ -10106,7 +11243,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} set dummy ldd; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LDD+set}" = set; then : +if ${ac_cv_path_LDD+:} false; then : $as_echo_n "(cached) " >&6 else case $LDD in @@ -10152,7 +11289,7 @@ fi set dummy otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_OTOOL+set}" = set; then : +if ${ac_cv_path_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else case $OTOOL in @@ -10197,7 +11334,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_READELF+set}" = set; then : +if ${ac_cv_path_READELF+:} false; then : $as_echo_n "(cached) " >&6 else case $READELF in @@ -10240,7 +11377,7 @@ done set dummy hg; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_HG+set}" = set; then : +if ${ac_cv_path_HG+:} false; then : $as_echo_n "(cached) " >&6 else case $HG in @@ -10280,7 +11417,7 @@ fi set dummy stat; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_STAT+set}" = set; then : +if ${ac_cv_path_STAT+:} false; then : $as_echo_n "(cached) " >&6 else case $STAT in @@ -10320,7 +11457,7 @@ fi set dummy time; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TIME+set}" = set; then : +if ${ac_cv_path_TIME+:} false; then : $as_echo_n "(cached) " >&6 else case $TIME in @@ -10365,7 +11502,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_COMM+set}" = set; then : +if ${ac_cv_path_COMM+:} false; then : $as_echo_n "(cached) " >&6 else case $COMM in @@ -10427,7 +11564,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_XATTR+set}" = set; then : +if ${ac_cv_path_XATTR+:} false; then : $as_echo_n "(cached) " >&6 else case $XATTR in @@ -10491,7 +11628,7 @@ if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_PKG_CONFIG+set}" = set; then : +if ${ac_cv_path_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $PKG_CONFIG in @@ -10534,7 +11671,7 @@ if test -z "$ac_cv_path_PKG_CONFIG"; then set dummy pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_ac_pt_PKG_CONFIG+set}" = set; then : +if ${ac_cv_path_ac_pt_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $ac_pt_PKG_CONFIG in @@ -10707,7 +11844,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_BDEPS_UNZIP+set}" = set; then : +if ${ac_cv_prog_BDEPS_UNZIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$BDEPS_UNZIP"; then @@ -10753,7 +11890,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_BDEPS_FTP+set}" = set; then : +if ${ac_cv_prog_BDEPS_FTP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$BDEPS_FTP"; then @@ -12026,7 +13163,7 @@ $as_echo "$BOOT_JDK_VERSION" >&6; } set dummy javac; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_JAVAC_CHECK+set}" = set; then : +if ${ac_cv_path_JAVAC_CHECK+:} false; then : $as_echo_n "(cached) " >&6 else case $JAVAC_CHECK in @@ -12066,7 +13203,7 @@ fi set dummy java; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_JAVA_CHECK+set}" = set; then : +if ${ac_cv_path_JAVA_CHECK+:} false; then : $as_echo_n "(cached) " >&6 else case $JAVA_CHECK in @@ -16140,7 +17277,7 @@ if test "x$OPENJDK_TARGET_OS" = "xwindows"; then set dummy link; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CYGWIN_LINK+set}" = set; then : +if ${ac_cv_path_CYGWIN_LINK+:} false; then : $as_echo_n "(cached) " >&6 else case $CYGWIN_LINK in @@ -17555,7 +18692,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BUILD_CC+set}" = set; then : +if ${ac_cv_path_BUILD_CC+:} false; then : $as_echo_n "(cached) " >&6 else case $BUILD_CC in @@ -17866,7 +19003,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BUILD_CXX+set}" = set; then : +if ${ac_cv_path_BUILD_CXX+:} false; then : $as_echo_n "(cached) " >&6 else case $BUILD_CXX in @@ -18175,7 +19312,7 @@ $as_echo "$as_me: Rewriting BUILD_CXX to \"$new_complete\"" >&6;} set dummy ld; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BUILD_LD+set}" = set; then : +if ${ac_cv_path_BUILD_LD+:} false; then : $as_echo_n "(cached) " >&6 else case $BUILD_LD in @@ -18691,7 +19828,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TOOLS_DIR_CC+set}" = set; then : +if ${ac_cv_path_TOOLS_DIR_CC+:} false; then : $as_echo_n "(cached) " >&6 else case $TOOLS_DIR_CC in @@ -18743,7 +19880,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_POTENTIAL_CC+set}" = set; then : +if ${ac_cv_path_POTENTIAL_CC+:} false; then : $as_echo_n "(cached) " >&6 else case $POTENTIAL_CC in @@ -19156,7 +20293,7 @@ $as_echo "yes, trying to find proper $COMPILER_NAME compiler" >&6; } set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_PROPER_COMPILER_CC+set}" = set; then : +if ${ac_cv_prog_PROPER_COMPILER_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$PROPER_COMPILER_CC"; then @@ -19200,7 +20337,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_PROPER_COMPILER_CC+set}" = set; then : +if ${ac_cv_prog_ac_ct_PROPER_COMPILER_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_PROPER_COMPILER_CC"; then @@ -19650,7 +20787,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CC+set}" = set; then : +if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then @@ -19694,7 +20831,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_CC+set}" = set; then : +if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then @@ -19747,7 +20884,7 @@ fi test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 @@ -19774,259 +20911,9 @@ $as_echo "$ac_try_echo"; } >&5 test $ac_status = 0; } done -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" -# Try to create an executable without -o first, disregard a.out. -# It will help us diagnose broken compilers, and finding out an intuition -# of exeext. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 -$as_echo_n "checking whether the C compiler works... " >&6; } -ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` - -# The possible output files: -ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" - -ac_rmfiles= -for ac_file in $ac_files -do - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - * ) ac_rmfiles="$ac_rmfiles $ac_file";; - esac -done -rm -f $ac_rmfiles - -if { { ac_try="$ac_link_default" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link_default") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. -# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' -# in a Makefile. We should not override ac_cv_exeext if it was cached, -# so that the user can short-circuit this test for compilers unknown to -# Autoconf. -for ac_file in $ac_files '' -do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) - ;; - [ab].out ) - # We found the default executable, but exeext='' is most - # certainly right. - break;; - *.* ) - if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; - then :; else - ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - fi - # We set ac_cv_exeext here because the later test for it is not - # safe: cross compilers may not add the suffix if given an `-o' - # argument, so we may need to know it at that point already. - # Even if this section looks crufty: it has the advantage of - # actually working. - break;; - * ) - break;; - esac -done -test "$ac_cv_exeext" = no && ac_cv_exeext= - -else - ac_file='' -fi -if test -z "$ac_file"; then : - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -$as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error 77 "C compiler cannot create executables -See \`config.log' for more details" "$LINENO" 5 ; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; } -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 -$as_echo_n "checking for C compiler default output file name... " >&6; } -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 -$as_echo "$ac_file" >&6; } -ac_exeext=$ac_cv_exeext - -rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out -ac_clean_files=$ac_clean_files_save -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 -$as_echo_n "checking for suffix of executables... " >&6; } -if { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - # If both `conftest.exe' and `conftest' are `present' (well, observable) -# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will -# work properly (i.e., refer to `conftest.exe'), while it won't with -# `rm'. -for ac_file in conftest.exe conftest conftest.*; do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - break;; - * ) break;; - esac -done -else - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot compute suffix of executables: cannot compile and link -See \`config.log' for more details" "$LINENO" 5 ; } -fi -rm -f conftest conftest$ac_cv_exeext -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 -$as_echo "$ac_cv_exeext" >&6; } - -rm -f conftest.$ac_ext -EXEEXT=$ac_cv_exeext -ac_exeext=$EXEEXT -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -int -main () -{ -FILE *f = fopen ("conftest.out", "w"); - return ferror (f) || fclose (f) != 0; - - ; - return 0; -} -_ACEOF -ac_clean_files="$ac_clean_files conftest.out" -# Check that the compiler produces executables we can run. If not, either -# the compiler is broken, or we cross compile. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 -$as_echo_n "checking whether we are cross compiling... " >&6; } -if test "$cross_compiling" != yes; then - { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } - if { ac_try='./conftest$ac_cv_exeext' - { { case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; }; then - cross_compiling=no - else - if test "$cross_compiling" = maybe; then - cross_compiling=yes - else - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot run C compiled programs. -If you meant to cross compile, use \`--host'. -See \`config.log' for more details" "$LINENO" 5 ; } - fi - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 -$as_echo "$cross_compiling" >&6; } - -rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out -ac_clean_files=$ac_clean_files_save -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 -$as_echo_n "checking for suffix of object files... " >&6; } -if test "${ac_cv_objext+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.o conftest.obj -if { { ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_compile") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - for ac_file in conftest.o conftest.obj conftest.*; do - test -f "$ac_file" || continue; - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; - *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` - break;; - esac -done -else - $as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot compute suffix of object files: cannot compile -See \`config.log' for more details" "$LINENO" 5 ; } -fi -rm -f conftest.$ac_cv_objext conftest.$ac_ext -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 -$as_echo "$ac_cv_objext" >&6; } -OBJEXT=$ac_cv_objext -ac_objext=$OBJEXT { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 $as_echo_n "checking whether we are using the GNU C compiler... " >&6; } -if test "${ac_cv_c_compiler_gnu+set}" = set; then : +if ${ac_cv_c_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -20063,7 +20950,7 @@ ac_test_CFLAGS=${CFLAGS+set} ac_save_CFLAGS=$CFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 $as_echo_n "checking whether $CC accepts -g... " >&6; } -if test "${ac_cv_prog_cc_g+set}" = set; then : +if ${ac_cv_prog_cc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_c_werror_flag=$ac_c_werror_flag @@ -20141,7 +21028,7 @@ else fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 $as_echo_n "checking for $CC option to accept ISO C89... " >&6; } -if test "${ac_cv_prog_cc_c89+set}" = set; then : +if ${ac_cv_prog_cc_c89+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_prog_cc_c89=no @@ -20264,7 +21151,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TOOLS_DIR_CXX+set}" = set; then : +if ${ac_cv_path_TOOLS_DIR_CXX+:} false; then : $as_echo_n "(cached) " >&6 else case $TOOLS_DIR_CXX in @@ -20316,7 +21203,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_POTENTIAL_CXX+set}" = set; then : +if ${ac_cv_path_POTENTIAL_CXX+:} false; then : $as_echo_n "(cached) " >&6 else case $POTENTIAL_CXX in @@ -20729,7 +21616,7 @@ $as_echo "yes, trying to find proper $COMPILER_NAME compiler" >&6; } set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_PROPER_COMPILER_CXX+set}" = set; then : +if ${ac_cv_prog_PROPER_COMPILER_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$PROPER_COMPILER_CXX"; then @@ -20773,7 +21660,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_PROPER_COMPILER_CXX+set}" = set; then : +if ${ac_cv_prog_ac_ct_PROPER_COMPILER_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_PROPER_COMPILER_CXX"; then @@ -21227,7 +22114,7 @@ if test -z "$CXX"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CXX+set}" = set; then : +if ${ac_cv_prog_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CXX"; then @@ -21271,7 +22158,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then : +if ${ac_cv_prog_ac_ct_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CXX"; then @@ -21349,7 +22236,7 @@ done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C++ compiler" >&5 $as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } -if test "${ac_cv_cxx_compiler_gnu+set}" = set; then : +if ${ac_cv_cxx_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -21386,7 +22273,7 @@ ac_test_CXXFLAGS=${CXXFLAGS+set} ac_save_CXXFLAGS=$CXXFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 $as_echo_n "checking whether $CXX accepts -g... " >&6; } -if test "${ac_cv_prog_cxx_g+set}" = set; then : +if ${ac_cv_prog_cxx_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_cxx_werror_flag=$ac_cxx_werror_flag @@ -21484,7 +22371,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_OBJC+set}" = set; then : +if ${ac_cv_prog_OBJC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJC"; then @@ -21528,7 +22415,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_OBJC+set}" = set; then : +if ${ac_cv_prog_ac_ct_OBJC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJC"; then @@ -21604,7 +22491,7 @@ done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU Objective C compiler" >&5 $as_echo_n "checking whether we are using the GNU Objective C compiler... " >&6; } -if test "${ac_cv_objc_compiler_gnu+set}" = set; then : +if ${ac_cv_objc_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -21641,7 +22528,7 @@ ac_test_OBJCFLAGS=${OBJCFLAGS+set} ac_save_OBJCFLAGS=$OBJCFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $OBJC accepts -g" >&5 $as_echo_n "checking whether $OBJC accepts -g... " >&6; } -if test "${ac_cv_prog_objc_g+set}" = set; then : +if ${ac_cv_prog_objc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_objc_werror_flag=$ac_objc_werror_flag @@ -22017,7 +22904,7 @@ if test "x$OPENJDK_TARGET_OS" != xwindows; then set dummy ${ac_tool_prefix}ar; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_AR+set}" = set; then : +if ${ac_cv_prog_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AR"; then @@ -22057,7 +22944,7 @@ if test -z "$ac_cv_prog_AR"; then set dummy ar; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_AR+set}" = set; then : +if ${ac_cv_prog_ac_ct_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_AR"; then @@ -22399,7 +23286,7 @@ if test "x$OPENJDK_TARGET_OS" = xwindows; then : set dummy link; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_WINLD+set}" = set; then : +if ${ac_cv_prog_WINLD+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$WINLD"; then @@ -22738,7 +23625,7 @@ $as_echo "yes" >&6; } set dummy mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_MT+set}" = set; then : +if ${ac_cv_prog_MT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$MT"; then @@ -23059,7 +23946,7 @@ $as_echo "$as_me: Rewriting MT to \"$new_complete\"" >&6;} set dummy rc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_RC+set}" = set; then : +if ${ac_cv_prog_RC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$RC"; then @@ -23450,7 +24337,7 @@ fi set dummy lib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_WINAR+set}" = set; then : +if ${ac_cv_prog_WINAR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$WINAR"; then @@ -23756,7 +24643,7 @@ $as_echo "$as_me: Rewriting WINAR to \"$new_complete\"" >&6;} set dummy dumpbin; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_DUMPBIN+set}" = set; then : +if ${ac_cv_prog_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DUMPBIN"; then @@ -24075,7 +24962,7 @@ if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then - if test "${ac_cv_prog_CPP+set}" = set; then : + if ${ac_cv_prog_CPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CPP needs to be expanded @@ -24191,7 +25078,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=cpp @@ -24475,7 +25362,7 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C++ preprocessor" >&5 $as_echo_n "checking how to run the C++ preprocessor... " >&6; } if test -z "$CXXCPP"; then - if test "${ac_cv_prog_CXXCPP+set}" = set; then : + if ${ac_cv_prog_CXXCPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CXXCPP needs to be expanded @@ -24591,7 +25478,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C++ preprocessor \"$CXXCPP\" fails sanity check -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=cpp @@ -24893,7 +25780,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris; then set dummy as; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_AS+set}" = set; then : +if ${ac_cv_path_AS+:} false; then : $as_echo_n "(cached) " >&6 else case $AS in @@ -25205,7 +26092,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris; then set dummy nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_NM+set}" = set; then : +if ${ac_cv_path_NM+:} false; then : $as_echo_n "(cached) " >&6 else case $NM in @@ -25511,7 +26398,7 @@ $as_echo "$as_me: Rewriting NM to \"$new_complete\"" >&6;} set dummy gnm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_GNM+set}" = set; then : +if ${ac_cv_path_GNM+:} false; then : $as_echo_n "(cached) " >&6 else case $GNM in @@ -25817,7 +26704,7 @@ $as_echo "$as_me: Rewriting GNM to \"$new_complete\"" >&6;} set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_STRIP+set}" = set; then : +if ${ac_cv_path_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else case $STRIP in @@ -26123,7 +27010,7 @@ $as_echo "$as_me: Rewriting STRIP to \"$new_complete\"" >&6;} set dummy mcs; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MCS+set}" = set; then : +if ${ac_cv_path_MCS+:} false; then : $as_echo_n "(cached) " >&6 else case $MCS in @@ -26431,7 +27318,7 @@ elif test "x$OPENJDK_TARGET_OS" != xwindows; then set dummy ${ac_tool_prefix}nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_NM+set}" = set; then : +if ${ac_cv_prog_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NM"; then @@ -26471,7 +27358,7 @@ if test -z "$ac_cv_prog_NM"; then set dummy nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_NM+set}" = set; then : +if ${ac_cv_prog_ac_ct_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_NM"; then @@ -26791,7 +27678,7 @@ $as_echo "$as_me: Rewriting NM to \"$new_complete\"" >&6;} set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_STRIP+set}" = set; then : +if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then @@ -26831,7 +27718,7 @@ if test -z "$ac_cv_prog_STRIP"; then set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then : +if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then @@ -27156,7 +28043,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris || test "x$OPENJDK_TARGET_OS" = xlinux; set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_OBJCOPY+set}" = set; then : +if ${ac_cv_prog_OBJCOPY+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJCOPY"; then @@ -27200,7 +28087,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_OBJCOPY+set}" = set; then : +if ${ac_cv_prog_ac_ct_OBJCOPY+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJCOPY"; then @@ -27527,7 +28414,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_OBJDUMP+set}" = set; then : +if ${ac_cv_prog_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJDUMP"; then @@ -27571,7 +28458,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then : +if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJDUMP"; then @@ -27895,7 +28782,7 @@ if test "x$OPENJDK_TARGET_OS" = "xmacosx"; then set dummy lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LIPO+set}" = set; then : +if ${ac_cv_path_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else case $LIPO in @@ -28207,10 +29094,9 @@ PATH="$OLD_PATH" # And we can test some aspects on the target using configure macros. - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 $as_echo_n "checking for ANSI C header files... " >&6; } -if test "${ac_cv_header_stdc+set}" = set; then : +if ${ac_cv_header_stdc+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -28344,6 +29230,80 @@ done # (The JVM can use 32 or 64 bit Java pointers but that decision # is made at runtime.) # + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"-m${OPENJDK_TARGET_CPU_BITS}\"" >&5 +$as_echo_n "checking if compiler supports \"-m${OPENJDK_TARGET_CPU_BITS}\"... " >&6; } + supports=yes + + saved_cflags="$CFLAGS" + CFLAGS="$CFLAGS -m${OPENJDK_TARGET_CPU_BITS}" + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + CFLAGS="$saved_cflags" + + saved_cxxflags="$CXXFLAGS" + CXXFLAGS="$CXXFLAG -m${OPENJDK_TARGET_CPU_BITS}" + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + CXXFLAGS="$saved_cxxflags" + + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5 +$as_echo "$supports" >&6; } + if test "x$supports" = "xyes" ; then + COMPILER_SUPPORTS_TARGET_BITS_FLAG=true + else + COMPILER_SUPPORTS_TARGET_BITS_FLAG=false + fi + + + + if test "x$OPENJDK_TARGET_OS" = xsolaris; then # Always specify -m flags on Solaris @@ -28386,7 +29346,7 @@ fi for ac_header in stdio.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "stdio.h" "ac_cv_header_stdio_h" "$ac_includes_default" -if test "x$ac_cv_header_stdio_h" = x""yes; then : +if test "x$ac_cv_header_stdio_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_STDIO_H 1 _ACEOF @@ -28415,7 +29375,7 @@ done # This bug is HP SR number 8606223364. { $as_echo "$as_me:${as_lineno-$LINENO}: checking size of int *" >&5 $as_echo_n "checking size of int *... " >&6; } -if test "${ac_cv_sizeof_int_p+set}" = set; then : +if ${ac_cv_sizeof_int_p+:} false; then : $as_echo_n "(cached) " >&6 else if ac_fn_cxx_compute_int "$LINENO" "(long int) (sizeof (int *))" "ac_cv_sizeof_int_p" "$ac_includes_default"; then : @@ -28425,7 +29385,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (int *) -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } else ac_cv_sizeof_int_p=0 fi @@ -28472,7 +29432,7 @@ $as_echo "$OPENJDK_TARGET_CPU_BITS bits" >&6; } # { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether byte ordering is bigendian" >&5 $as_echo_n "checking whether byte ordering is bigendian... " >&6; } -if test "${ac_cv_c_bigendian+set}" = set; then : +if ${ac_cv_c_bigendian+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_c_bigendian=unknown @@ -29446,7 +30406,6 @@ fi - ############################################################################### # # Check for X Windows @@ -29484,8 +30443,8 @@ if test "x$with_x" = xno; then have_x=disabled else case $x_includes,$x_libraries in #( - *\'*) as_fn_error $? "cannot use X directory names containing '" "$LINENO" 5 ;; #( - *,NONE | NONE,*) if test "${ac_cv_have_x+set}" = set; then : + *\'*) as_fn_error $? "cannot use X directory names containing '" "$LINENO" 5;; #( + *,NONE | NONE,*) if ${ac_cv_have_x+:} false; then : $as_echo_n "(cached) " >&6 else # One or both of the vars are not set, and there is no cached value. @@ -29762,7 +30721,7 @@ if ac_fn_cxx_try_link "$LINENO"; then : else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet... " >&6; } -if test "${ac_cv_lib_dnet_dnet_ntoa+set}" = set; then : +if ${ac_cv_lib_dnet_dnet_ntoa+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -29796,14 +30755,14 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_dnet_ntoa" >&6; } -if test "x$ac_cv_lib_dnet_dnet_ntoa" = x""yes; then : +if test "x$ac_cv_lib_dnet_dnet_ntoa" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet" fi if test $ac_cv_lib_dnet_dnet_ntoa = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet_stub" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet_stub... " >&6; } -if test "${ac_cv_lib_dnet_stub_dnet_ntoa+set}" = set; then : +if ${ac_cv_lib_dnet_stub_dnet_ntoa+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -29837,7 +30796,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_stub_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_stub_dnet_ntoa" >&6; } -if test "x$ac_cv_lib_dnet_stub_dnet_ntoa" = x""yes; then : +if test "x$ac_cv_lib_dnet_stub_dnet_ntoa" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet_stub" fi @@ -29856,14 +30815,14 @@ rm -f core conftest.err conftest.$ac_objext \ # The functions gethostbyname, getservbyname, and inet_addr are # in -lbsd on LynxOS 3.0.1/i386, according to Lars Hecking. ac_fn_cxx_check_func "$LINENO" "gethostbyname" "ac_cv_func_gethostbyname" -if test "x$ac_cv_func_gethostbyname" = x""yes; then : +if test "x$ac_cv_func_gethostbyname" = xyes; then : fi if test $ac_cv_func_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lnsl" >&5 $as_echo_n "checking for gethostbyname in -lnsl... " >&6; } -if test "${ac_cv_lib_nsl_gethostbyname+set}" = set; then : +if ${ac_cv_lib_nsl_gethostbyname+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -29897,14 +30856,14 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_nsl_gethostbyname" >&5 $as_echo "$ac_cv_lib_nsl_gethostbyname" >&6; } -if test "x$ac_cv_lib_nsl_gethostbyname" = x""yes; then : +if test "x$ac_cv_lib_nsl_gethostbyname" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl" fi if test $ac_cv_lib_nsl_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lbsd" >&5 $as_echo_n "checking for gethostbyname in -lbsd... " >&6; } -if test "${ac_cv_lib_bsd_gethostbyname+set}" = set; then : +if ${ac_cv_lib_bsd_gethostbyname+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -29938,7 +30897,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_bsd_gethostbyname" >&5 $as_echo "$ac_cv_lib_bsd_gethostbyname" >&6; } -if test "x$ac_cv_lib_bsd_gethostbyname" = x""yes; then : +if test "x$ac_cv_lib_bsd_gethostbyname" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lbsd" fi @@ -29953,14 +30912,14 @@ fi # must be given before -lnsl if both are needed. We assume that # if connect needs -lnsl, so does gethostbyname. ac_fn_cxx_check_func "$LINENO" "connect" "ac_cv_func_connect" -if test "x$ac_cv_func_connect" = x""yes; then : +if test "x$ac_cv_func_connect" = xyes; then : fi if test $ac_cv_func_connect = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for connect in -lsocket" >&5 $as_echo_n "checking for connect in -lsocket... " >&6; } -if test "${ac_cv_lib_socket_connect+set}" = set; then : +if ${ac_cv_lib_socket_connect+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -29994,7 +30953,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_socket_connect" >&5 $as_echo "$ac_cv_lib_socket_connect" >&6; } -if test "x$ac_cv_lib_socket_connect" = x""yes; then : +if test "x$ac_cv_lib_socket_connect" = xyes; then : X_EXTRA_LIBS="-lsocket $X_EXTRA_LIBS" fi @@ -30002,14 +30961,14 @@ fi # Guillermo Gomez says -lposix is necessary on A/UX. ac_fn_cxx_check_func "$LINENO" "remove" "ac_cv_func_remove" -if test "x$ac_cv_func_remove" = x""yes; then : +if test "x$ac_cv_func_remove" = xyes; then : fi if test $ac_cv_func_remove = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for remove in -lposix" >&5 $as_echo_n "checking for remove in -lposix... " >&6; } -if test "${ac_cv_lib_posix_remove+set}" = set; then : +if ${ac_cv_lib_posix_remove+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30043,7 +31002,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_posix_remove" >&5 $as_echo "$ac_cv_lib_posix_remove" >&6; } -if test "x$ac_cv_lib_posix_remove" = x""yes; then : +if test "x$ac_cv_lib_posix_remove" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lposix" fi @@ -30051,14 +31010,14 @@ fi # BSDI BSD/OS 2.1 needs -lipc for XOpenDisplay. ac_fn_cxx_check_func "$LINENO" "shmat" "ac_cv_func_shmat" -if test "x$ac_cv_func_shmat" = x""yes; then : +if test "x$ac_cv_func_shmat" = xyes; then : fi if test $ac_cv_func_shmat = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shmat in -lipc" >&5 $as_echo_n "checking for shmat in -lipc... " >&6; } -if test "${ac_cv_lib_ipc_shmat+set}" = set; then : +if ${ac_cv_lib_ipc_shmat+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30092,7 +31051,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ipc_shmat" >&5 $as_echo "$ac_cv_lib_ipc_shmat" >&6; } -if test "x$ac_cv_lib_ipc_shmat" = x""yes; then : +if test "x$ac_cv_lib_ipc_shmat" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lipc" fi @@ -30110,7 +31069,7 @@ fi # John Interrante, Karl Berry { $as_echo "$as_me:${as_lineno-$LINENO}: checking for IceConnectionNumber in -lICE" >&5 $as_echo_n "checking for IceConnectionNumber in -lICE... " >&6; } -if test "${ac_cv_lib_ICE_IceConnectionNumber+set}" = set; then : +if ${ac_cv_lib_ICE_IceConnectionNumber+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30144,7 +31103,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ICE_IceConnectionNumber" >&5 $as_echo "$ac_cv_lib_ICE_IceConnectionNumber" >&6; } -if test "x$ac_cv_lib_ICE_IceConnectionNumber" = x""yes; then : +if test "x$ac_cv_lib_ICE_IceConnectionNumber" = xyes; then : X_PRE_LIBS="$X_PRE_LIBS -lSM -lICE" fi @@ -31157,7 +32116,7 @@ $as_echo "$FREETYPE2_FOUND" >&6; } LDFLAGS="$FREETYPE2_LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for FT_Init_FreeType in -lfreetype" >&5 $as_echo_n "checking for FT_Init_FreeType in -lfreetype... " >&6; } -if test "${ac_cv_lib_freetype_FT_Init_FreeType+set}" = set; then : +if ${ac_cv_lib_freetype_FT_Init_FreeType+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31191,7 +32150,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_freetype_FT_Init_FreeType" >&5 $as_echo "$ac_cv_lib_freetype_FT_Init_FreeType" >&6; } -if test "x$ac_cv_lib_freetype_FT_Init_FreeType" = x""yes; then : +if test "x$ac_cv_lib_freetype_FT_Init_FreeType" = xyes; then : FREETYPE2_FOUND=true else as_fn_error $? "Could not find freetype2! $HELP_MSG " "$LINENO" 5 @@ -31479,7 +32438,7 @@ fi for ac_header in alsa/asoundlib.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "alsa/asoundlib.h" "ac_cv_header_alsa_asoundlib_h" "$ac_includes_default" -if test "x$ac_cv_header_alsa_asoundlib_h" = x""yes; then : +if test "x$ac_cv_header_alsa_asoundlib_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_ALSA_ASOUNDLIB_H 1 _ACEOF @@ -31538,7 +32497,7 @@ fi USE_EXTERNAL_LIBJPEG=true { $as_echo "$as_me:${as_lineno-$LINENO}: checking for main in -ljpeg" >&5 $as_echo_n "checking for main in -ljpeg... " >&6; } -if test "${ac_cv_lib_jpeg_main+set}" = set; then : +if ${ac_cv_lib_jpeg_main+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31566,7 +32525,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_jpeg_main" >&5 $as_echo "$ac_cv_lib_jpeg_main" >&6; } -if test "x$ac_cv_lib_jpeg_main" = x""yes; then : +if test "x$ac_cv_lib_jpeg_main" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBJPEG 1 _ACEOF @@ -31615,7 +32574,7 @@ if test "x${with_giflib}" = "xbundled"; then USE_EXTERNAL_LIBGIF=false elif test "x${with_giflib}" = "xsystem"; then ac_fn_cxx_check_header_mongrel "$LINENO" "gif_lib.h" "ac_cv_header_gif_lib_h" "$ac_includes_default" -if test "x$ac_cv_header_gif_lib_h" = x""yes; then : +if test "x$ac_cv_header_gif_lib_h" = xyes; then : else as_fn_error $? "--with-giflib=system specified, but gif_lib.h not found!" "$LINENO" 5 @@ -31624,7 +32583,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for DGifGetCode in -lgif" >&5 $as_echo_n "checking for DGifGetCode in -lgif... " >&6; } -if test "${ac_cv_lib_gif_DGifGetCode+set}" = set; then : +if ${ac_cv_lib_gif_DGifGetCode+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31658,7 +32617,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_gif_DGifGetCode" >&5 $as_echo "$ac_cv_lib_gif_DGifGetCode" >&6; } -if test "x$ac_cv_lib_gif_DGifGetCode" = x""yes; then : +if test "x$ac_cv_lib_gif_DGifGetCode" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBGIF 1 _ACEOF @@ -31690,7 +32649,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for compress in -lz" >&5 $as_echo_n "checking for compress in -lz... " >&6; } -if test "${ac_cv_lib_z_compress+set}" = set; then : +if ${ac_cv_lib_z_compress+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31724,7 +32683,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_z_compress" >&5 $as_echo "$ac_cv_lib_z_compress" >&6; } -if test "x$ac_cv_lib_z_compress" = x""yes; then : +if test "x$ac_cv_lib_z_compress" = xyes; then : ZLIB_FOUND=yes else ZLIB_FOUND=no @@ -31817,7 +32776,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cos in -lm" >&5 $as_echo_n "checking for cos in -lm... " >&6; } -if test "${ac_cv_lib_m_cos+set}" = set; then : +if ${ac_cv_lib_m_cos+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31851,7 +32810,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_m_cos" >&5 $as_echo "$ac_cv_lib_m_cos" >&6; } -if test "x$ac_cv_lib_m_cos" = x""yes; then : +if test "x$ac_cv_lib_m_cos" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBM 1 _ACEOF @@ -31875,7 +32834,7 @@ save_LIBS="$LIBS" LIBS="" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } -if test "${ac_cv_lib_dl_dlopen+set}" = set; then : +if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31909,7 +32868,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } -if test "x$ac_cv_lib_dl_dlopen" = x""yes; then : +if test "x$ac_cv_lib_dl_dlopen" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBDL 1 _ACEOF @@ -32139,7 +33098,7 @@ and LIBFFI_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details. To get pkg-config, see . -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } else LIBFFI_CFLAGS=$pkg_cv_LIBFFI_CFLAGS LIBFFI_LIBS=$pkg_cv_LIBFFI_LIBS @@ -32155,7 +33114,7 @@ if test "x$JVM_VARIANT_ZEROSHARK" = xtrue; then set dummy llvm-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_LLVM_CONFIG+set}" = set; then : +if ${ac_cv_prog_LLVM_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$LLVM_CONFIG"; then @@ -32773,7 +33732,7 @@ fi set dummy ccache; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CCACHE+set}" = set; then : +if ${ac_cv_path_CCACHE+:} false; then : $as_echo_n "(cached) " >&6 else case $CCACHE in @@ -33034,10 +33993,21 @@ $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then - test "x$cache_file" != "x/dev/null" && + if test "x$cache_file" != "x/dev/null"; then { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 $as_echo "$as_me: updating cache $cache_file" >&6;} - cat confcache >$cache_file + if test ! -f "$cache_file" || test -h "$cache_file"; then + cat confcache >"$cache_file" + else + case $cache_file in #( + */* | ?:*) + mv -f confcache "$cache_file"$$ && + mv -f "$cache_file"$$ "$cache_file" ;; #( + *) + mv -f confcache "$cache_file" ;; + esac + fi + fi else { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 $as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} @@ -33069,7 +34039,7 @@ LTLIBOBJS=$ac_ltlibobjs -: ${CONFIG_STATUS=./config.status} +: "${CONFIG_STATUS=./config.status}" ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" @@ -33170,6 +34140,7 @@ fi IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. +as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR @@ -33477,7 +34448,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # values after options handling. ac_log=" This file was extended by OpenJDK $as_me jdk8, which was -generated by GNU Autoconf 2.67. Invocation command line was +generated by GNU Autoconf 2.68. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS @@ -33540,7 +34511,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ OpenJDK config.status jdk8 -configured by $0, generated by GNU Autoconf 2.67, +configured by $0, generated by GNU Autoconf 2.68, with options \\"\$ac_cs_config\\" Copyright (C) 2010 Free Software Foundation, Inc. @@ -33669,7 +34640,7 @@ do "$OUTPUT_ROOT/spec.sh") CONFIG_FILES="$CONFIG_FILES $OUTPUT_ROOT/spec.sh:$AUTOCONF_DIR/spec.sh.in" ;; "$OUTPUT_ROOT/Makefile") CONFIG_FILES="$CONFIG_FILES $OUTPUT_ROOT/Makefile:$AUTOCONF_DIR/Makefile.in" ;; - *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5 ;; + *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac done @@ -33691,9 +34662,10 @@ fi # after its creation but before its name has been assigned to `$tmp'. $debug || { - tmp= + tmp= ac_tmp= trap 'exit_status=$? - { test -z "$tmp" || test ! -d "$tmp" || rm -fr "$tmp"; } && exit $exit_status + : "${ac_tmp:=$tmp}" + { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } @@ -33701,12 +34673,13 @@ $debug || { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && - test -n "$tmp" && test -d "$tmp" + test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 +ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. @@ -33728,7 +34701,7 @@ else ac_cs_awk_cr=$ac_cr fi -echo 'BEGIN {' >"$tmp/subs1.awk" && +echo 'BEGIN {' >"$ac_tmp/subs1.awk" && _ACEOF @@ -33756,7 +34729,7 @@ done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -cat >>"\$tmp/subs1.awk" <<\\_ACAWK && +cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h @@ -33804,7 +34777,7 @@ t delim rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK -cat >>"\$tmp/subs1.awk" <<_ACAWK && +cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" @@ -33836,7 +34809,7 @@ if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat -fi < "$tmp/subs1.awk" > "$tmp/subs.awk" \ +fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF @@ -33870,7 +34843,7 @@ fi # test -n "$CONFIG_FILES" # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then -cat >"$tmp/defines.awk" <<\_ACAWK || +cat >"$ac_tmp/defines.awk" <<\_ACAWK || BEGIN { _ACEOF @@ -33882,8 +34855,8 @@ _ACEOF # handling of long lines. ac_delim='%!_!# ' for ac_last_try in false false :; do - ac_t=`sed -n "/$ac_delim/p" confdefs.h` - if test -z "$ac_t"; then + ac_tt=`sed -n "/$ac_delim/p" confdefs.h` + if test -z "$ac_tt"; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 @@ -33984,7 +34957,7 @@ do esac case $ac_mode$ac_tag in :[FHL]*:*);; - :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5 ;; + :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac @@ -34003,7 +34976,7 @@ do for ac_f do case $ac_f in - -) ac_f="$tmp/stdin";; + -) ac_f="$ac_tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. @@ -34012,7 +34985,7 @@ do [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || - as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5 ;; + as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; esac case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" @@ -34038,8 +35011,8 @@ $as_echo "$as_me: creating $ac_file" >&6;} esac case $ac_tag in - *:-:* | *:-) cat >"$tmp/stdin" \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; + *:-:* | *:-) cat >"$ac_tmp/stdin" \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac @@ -34164,21 +35137,22 @@ s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t $ac_datarootdir_hack " -eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$tmp/subs.awk" >$tmp/out \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 +eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ + >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && - { ac_out=`sed -n '/\${datarootdir}/p' "$tmp/out"`; test -n "$ac_out"; } && - { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' "$tmp/out"`; test -z "$ac_out"; } && + { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && + { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ + "$ac_tmp/out"`; test -z "$ac_out"; } && { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 $as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} - rm -f "$tmp/stdin" + rm -f "$ac_tmp/stdin" case $ac_file in - -) cat "$tmp/out" && rm -f "$tmp/out";; - *) rm -f "$ac_file" && mv "$tmp/out" "$ac_file";; + -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; + *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; @@ -34189,20 +35163,20 @@ which seems to be undefined. Please make sure it is defined" >&2;} if test x"$ac_file" != x-; then { $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" - } >"$tmp/config.h" \ + && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" + } >"$ac_tmp/config.h" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 - if diff "$ac_file" "$tmp/config.h" >/dev/null 2>&1; then + if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 $as_echo "$as_me: $ac_file is unchanged" >&6;} else rm -f "$ac_file" - mv "$tmp/config.h" "$ac_file" \ + mv "$ac_tmp/config.h" "$ac_file" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 fi else $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" \ + && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi ;; diff --git a/common/autoconf/platform.m4 b/common/autoconf/platform.m4 index 067650688c3..636b393078a 100644 --- a/common/autoconf/platform.m4 +++ b/common/autoconf/platform.m4 @@ -342,6 +342,7 @@ AC_DEFUN([PLATFORM_SETUP_LEGACY_VARS], *) ZERO_ARCHFLAG="-m${OPENJDK_TARGET_CPU_BITS}" esac + PLATFORM_COMPILER_CHECK_ARGUMENTS([$ZERO_ARCHFLAG], [], [ZERO_ARCHFLAG=""]) AC_SUBST(ZERO_ARCHFLAG) # ZERO_ARCHDEF is used to enable architecture-specific code @@ -417,6 +418,51 @@ AC_SUBST(OS_VERSION_MINOR) AC_SUBST(OS_VERSION_MICRO) ]) +# PLATFORM_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE], +# [RUN-IF-FALSE]) +# ------------------------------------------------------------ +# Check that the c and c++ compilers support an argument +AC_DEFUN([PLATFORM_COMPILER_CHECK_ARGUMENTS], +[ + AC_MSG_CHECKING([if compiler supports "$1"]) + supports=yes + + saved_cflags="$CFLAGS" + CFLAGS="$CFLAGS $1" + AC_LANG_PUSH([C]) + AC_COMPILE_IFELSE([ + AC_LANG_SOURCE([[int i;]]) + ], [], [supports=no]) + AC_LANG_POP([C]) + CFLAGS="$saved_cflags" + + saved_cxxflags="$CXXFLAGS" + CXXFLAGS="$CXXFLAG $1" + AC_LANG_PUSH([C++]) + AC_COMPILE_IFELSE([ + AC_LANG_SOURCE([[int i;]]) + ], [], [supports=no]) + AC_LANG_POP([C++]) + CXXFLAGS="$saved_cxxflags" + + AC_MSG_RESULT([$supports]) + if test "x$supports" = "xyes" ; then + m4_ifval([$2], [$2], [:]) + else + m4_ifval([$3], [$3], [:]) + fi +]) + +# Check that the compiler supports -mX flags +# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does +AC_DEFUN([PLATFORM_CHECK_COMPILER_TARGET_BITS_FLAGS], +[ + PLATFORM_COMPILER_CHECK_ARGUMENTS([-m${OPENJDK_TARGET_CPU_BITS}], + [COMPILER_SUPPORTS_TARGET_BITS_FLAG=true], + [COMPILER_SUPPORTS_TARGET_BITS_FLAG=false]) + AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG) +]) + # Support macro for PLATFORM_SETUP_OPENJDK_TARGET_BITS. # Add -mX to various FLAGS variables. AC_DEFUN([PLATFORM_SET_COMPILER_TARGET_BITS_FLAGS], @@ -444,6 +490,9 @@ AC_DEFUN_ONCE([PLATFORM_SETUP_OPENJDK_TARGET_BITS], # (The JVM can use 32 or 64 bit Java pointers but that decision # is made at runtime.) # + +PLATFORM_CHECK_COMPILER_TARGET_BITS_FLAGS + if test "x$OPENJDK_TARGET_OS" = xsolaris; then # Always specify -m flags on Solaris PLATFORM_SET_COMPILER_TARGET_BITS_FLAGS diff --git a/common/autoconf/spec.gmk.in b/common/autoconf/spec.gmk.in index 92b0c83017e..14a8ad34405 100644 --- a/common/autoconf/spec.gmk.in +++ b/common/autoconf/spec.gmk.in @@ -301,6 +301,8 @@ MACOSX_VERSION_MIN=@MACOSX_VERSION_MIN@ # CL is cl.exe only. COMPILER_TYPE:=@COMPILER_TYPE@ +COMPILER_SUPPORTS_TARGET_BITS_FLAG=@COMPILER_SUPPORTS_TARGET_BITS_FLAG@ + CC_OUT_OPTION:=@CC_OUT_OPTION@ EXE_OUT_OPTION:=@EXE_OUT_OPTION@ LD_OUT_OPTION:=@LD_OUT_OPTION@ From 6b7ee7010a25bdadd908e10793e210d72ba0470e Mon Sep 17 00:00:00 2001 From: Jesper Wilhelmsson Date: Thu, 25 Apr 2013 16:00:40 +0200 Subject: [PATCH 34/50] 7074926: create Solaris Studio IDE (Netbeans) project for hotspot sources Project files for hotspot delevopment in Solaris Studio and NetBeans. Also reviewed by vladimir.voskresensky@oracle.com Reviewed-by: erikj, dsamersoff --- common/nb_native/nbproject/configurations.xml | 41671 ++++++++++++++++ common/nb_native/nbproject/project.xml | 31 + 2 files changed, 41702 insertions(+) create mode 100644 common/nb_native/nbproject/configurations.xml create mode 100644 common/nb_native/nbproject/project.xml diff --git a/common/nb_native/nbproject/configurations.xml b/common/nb_native/nbproject/configurations.xml new file mode 100644 index 00000000000..b976a43ff1e --- /dev/null +++ b/common/nb_native/nbproject/configurations.xml @@ -0,0 +1,41671 @@ + + + + + + + + + + + ad_x86_64.cpp + ad_x86_64_clone.cpp + ad_x86_64_expand.cpp + ad_x86_64_format.cpp + ad_x86_64_gen.cpp + ad_x86_64_misc.cpp + ad_x86_64_peephole.cpp + ad_x86_64_pipeline.cpp + dfa_x86_64.cpp + + + bytecodeInterpreterWithChecks.cpp + jvmtiEnter.cpp + jvmtiEnterTrace.cpp + + + + + + + sizer.64.c + + + + + + + + + ad_x86_64.cpp + ad_x86_64_clone.cpp + ad_x86_64_expand.cpp + ad_x86_64_format.cpp + ad_x86_64_gen.cpp + ad_x86_64_misc.cpp + ad_x86_64_peephole.cpp + ad_x86_64_pipeline.cpp + dfa_x86_64.cpp + + + bytecodeInterpreterWithChecks.cpp + jvmtiEnter.cpp + jvmtiEnterTrace.cpp + + + + + + + sizer.64.c + + + + + + + + + ad_x86_64.cpp + ad_x86_64_clone.cpp + ad_x86_64_expand.cpp + ad_x86_64_format.cpp + ad_x86_64_gen.cpp + ad_x86_64_misc.cpp + ad_x86_64_peephole.cpp + ad_x86_64_pipeline.cpp + dfa_x86_64.cpp + + + bytecodeInterpreterWithChecks.cpp + jvmtiEnter.cpp + jvmtiEnterTrace.cpp + + + + JvmOffsets.cpp + + + + + + sizer.64.c + + + + + + + + + + LinuxDebuggerLocal.c + libproc_impl.c + ps_core.c + ps_proc.c + salibelf.c + symtab.c + + + + saproc.cpp + + + + + + sadis.c + + + + + + + + + assembler_x86.cpp + bytecodeInterpreter_x86.cpp + bytecodes_x86.cpp + c1_CodeStubs_x86.cpp + c1_FpuStackSim_x86.cpp + c1_FrameMap_x86.cpp + c1_LIRAssembler_x86.cpp + c1_LIRGenerator_x86.cpp + c1_LinearScan_x86.cpp + c1_MacroAssembler_x86.cpp + c1_Runtime1_x86.cpp + c2_init_x86.cpp + cppInterpreter_x86.cpp + debug_x86.cpp + depChecker_x86.cpp + frame_x86.cpp + icBuffer_x86.cpp + icache_x86.cpp + interp_masm_x86_64.cpp + interpreterRT_x86_64.cpp + interpreter_x86_64.cpp + jniFastGetField_x86_64.cpp + macroAssembler_x86.cpp + metaspaceShared_x86_64.cpp + methodHandles_x86.cpp + nativeInst_x86.cpp + register_definitions_x86.cpp + register_x86.cpp + relocInfo_x86.cpp + runtime_x86_64.cpp + sharedRuntime_x86_64.cpp + stubGenerator_x86_64.cpp + stubRoutines_x86_64.cpp + templateInterpreter_x86_64.cpp + templateTable_x86_64.cpp + vm_version_x86.cpp + vmreg_x86.cpp + vtableStubs_x86_64.cpp + + + + + + + attachListener_bsd.cpp + chaitin_bsd.cpp + decoder_machO.cpp + dtraceJSDT_bsd.cpp + jvm_bsd.cpp + mutex_bsd.cpp + osThread_bsd.cpp + os_bsd.cpp + perfMemory_bsd.cpp + stubRoutines_bsd.cpp + threadCritical_bsd.cpp + vmError_bsd.cpp + + + + + attachListener_linux.cpp + chaitin_linux.cpp + decoder_linux.cpp + dtraceJSDT_linux.cpp + jsig.c + jvm_linux.cpp + mutex_linux.cpp + osThread_linux.cpp + os_linux.cpp + perfMemory_linux.cpp + stubRoutines_linux.cpp + threadCritical_linux.cpp + vmError_linux.cpp + + + + + java_md.c + + + os_posix.cpp + + + + + add_gnu_debuglink.c + + + generateJvmOffsets.cpp + generateJvmOffsetsMain.c + jvm_dtrace.c + libjvm_db.c + + + fix_empty_sec_hdr_flags.c + + + attachListener_solaris.cpp + chaitin_solaris.cpp + decoder_solaris.cpp + dtraceJSDT_solaris.cpp + jsig.c + jvm_solaris.cpp + mutex_solaris.cpp + osThread_solaris.cpp + os_solaris.cpp + perfMemory_solaris.cpp + stubRoutines_solaris.cpp + threadCritical_solaris.cpp + vmError_solaris.cpp + + + + + + + assembler_bsd_x86.cpp + os_bsd_x86.cpp + threadLS_bsd_x86.cpp + thread_bsd_x86.cpp + vm_version_bsd_x86.cpp + + + + + assembler_linux_x86.cpp + os_linux_x86.cpp + threadLS_linux_x86.cpp + thread_linux_x86.cpp + vm_version_linux_x86.cpp + + + + + assembler_solaris_x86.cpp + os_solaris_x86.cpp + threadLS_solaris_x86.cpp + thread_solaris_x86.cpp + vm_version_solaris_x86.cpp + + + + + + + java.c + jli_util.c + wildcard.c + + + + + adlparse.cpp + archDesc.cpp + arena.cpp + dfa.cpp + dict2.cpp + filebuff.cpp + forms.cpp + formsopt.cpp + formssel.cpp + main.cpp + output_c.cpp + output_h.cpp + + + assembler.cpp + codeBuffer.cpp + register.cpp + + + c1_CFGPrinter.cpp + c1_Canonicalizer.cpp + c1_Compilation.cpp + c1_Compiler.cpp + c1_Defs.cpp + c1_FrameMap.cpp + c1_GraphBuilder.cpp + c1_IR.cpp + c1_Instruction.cpp + c1_InstructionPrinter.cpp + c1_LIR.cpp + c1_LIRAssembler.cpp + c1_LIRGenerator.cpp + c1_LinearScan.cpp + c1_Optimizer.cpp + c1_RangeCheckElimination.cpp + c1_Runtime1.cpp + c1_ValueMap.cpp + c1_ValueSet.cpp + c1_ValueStack.cpp + c1_ValueType.cpp + c1_globals.cpp + + + bcEscapeAnalyzer.cpp + ciArray.cpp + ciArrayKlass.cpp + ciBaseObject.cpp + ciCallSite.cpp + ciConstant.cpp + ciConstantPoolCache.cpp + ciEnv.cpp + ciExceptionHandler.cpp + ciField.cpp + ciFlags.cpp + ciInstance.cpp + ciInstanceKlass.cpp + ciKlass.cpp + ciMemberName.cpp + ciMetadata.cpp + ciMethod.cpp + ciMethodBlocks.cpp + ciMethodData.cpp + ciMethodHandle.cpp + ciNullObject.cpp + ciObjArray.cpp + ciObjArrayKlass.cpp + ciObject.cpp + ciObjectFactory.cpp + ciReplay.cpp + ciSignature.cpp + ciStreams.cpp + ciSymbol.cpp + ciType.cpp + ciTypeArray.cpp + ciTypeArrayKlass.cpp + ciTypeFlow.cpp + ciUtilities.cpp + + + altHashing.cpp + bytecodeAssembler.cpp + classFileError.cpp + classFileParser.cpp + classFileStream.cpp + classLoader.cpp + classLoaderData.cpp + defaultMethods.cpp + dictionary.cpp + genericSignatures.cpp + javaAssertions.cpp + javaClasses.cpp + loaderConstraints.cpp + metadataOnStackMark.cpp + placeholders.cpp + resolutionErrors.cpp + stackMapFrame.cpp + stackMapTable.cpp + symbolTable.cpp + systemDictionary.cpp + verificationType.cpp + verifier.cpp + vmSymbols.cpp + + + codeBlob.cpp + codeCache.cpp + compiledIC.cpp + compressedStream.cpp + debugInfo.cpp + debugInfoRec.cpp + dependencies.cpp + exceptionHandlerTable.cpp + icBuffer.cpp + location.cpp + nmethod.cpp + oopRecorder.cpp + pcDesc.cpp + relocInfo.cpp + scopeDesc.cpp + stubs.cpp + vmreg.cpp + vtableStubs.cpp + + + abstractCompiler.cpp + compileBroker.cpp + compileLog.cpp + compilerOracle.cpp + disassembler.cpp + methodLiveness.cpp + oopMap.cpp + + + + adaptiveFreeList.cpp + cmsAdaptiveSizePolicy.cpp + cmsCollectorPolicy.cpp + cmsGCAdaptivePolicyCounters.cpp + cmsLockVerifier.cpp + compactibleFreeListSpace.cpp + concurrentMarkSweepGeneration.cpp + concurrentMarkSweepThread.cpp + freeChunk.cpp + promotionInfo.cpp + vmCMSOperations.cpp + + + collectionSetChooser.cpp + concurrentG1Refine.cpp + concurrentG1RefineThread.cpp + concurrentMark.cpp + concurrentMarkThread.cpp + dirtyCardQueue.cpp + g1AllocRegion.cpp + g1BlockOffsetTable.cpp + g1CollectedHeap.cpp + g1CollectorPolicy.cpp + g1ErgoVerbose.cpp + g1GCPhaseTimes.cpp + g1HRPrinter.cpp + g1Log.cpp + g1MMUTracker.cpp + g1MarkSweep.cpp + g1MonitoringSupport.cpp + g1RemSet.cpp + g1SATBCardTableModRefBS.cpp + g1_globals.cpp + heapRegion.cpp + heapRegionRemSet.cpp + heapRegionSeq.cpp + heapRegionSet.cpp + heapRegionSets.cpp + ptrQueue.cpp + satbQueue.cpp + sparsePRT.cpp + survRateGroup.cpp + vm_operations_g1.cpp + + + adjoiningGenerations.cpp + adjoiningVirtualSpaces.cpp + asPSOldGen.cpp + asPSYoungGen.cpp + cardTableExtension.cpp + gcTaskManager.cpp + gcTaskThread.cpp + objectStartArray.cpp + parMarkBitMap.cpp + parallelScavengeHeap.cpp + pcTasks.cpp + psAdaptiveSizePolicy.cpp + psCompactionManager.cpp + psGCAdaptivePolicyCounters.cpp + psGenerationCounters.cpp + psMarkSweep.cpp + psMarkSweepDecorator.cpp + psOldGen.cpp + psParallelCompact.cpp + psPromotionLAB.cpp + psPromotionManager.cpp + psScavenge.cpp + psTasks.cpp + psVirtualspace.cpp + psYoungGen.cpp + vmPSOperations.cpp + + + asParNewGeneration.cpp + parCardTableModRefBS.cpp + parNewGeneration.cpp + + + adaptiveSizePolicy.cpp + ageTable.cpp + allocationStats.cpp + cSpaceCounters.cpp + collectorCounters.cpp + concurrentGCThread.cpp + gSpaceCounters.cpp + gcAdaptivePolicyCounters.cpp + gcPolicyCounters.cpp + gcStats.cpp + gcUtil.cpp + generationCounters.cpp + hSpaceCounters.cpp + immutableSpace.cpp + markSweep.cpp + mutableNUMASpace.cpp + mutableSpace.cpp + parGCAllocBuffer.cpp + spaceCounters.cpp + spaceDecorator.cpp + vmGCOperations.cpp + + + + collectedHeap.cpp + gcCause.cpp + + + bytecode.cpp + bytecodeHistogram.cpp + bytecodeInterpreter.cpp + bytecodeStream.cpp + bytecodeTracer.cpp + bytecodes.cpp + cppInterpreter.cpp + interpreter.cpp + interpreterRuntime.cpp + invocationCounter.cpp + linkResolver.cpp + oopMapCache.cpp + rewriter.cpp + templateInterpreter.cpp + templateTable.cpp + + + dict.cpp + port.cpp + set.cpp + vectset.cpp + + + allocation.cpp + barrierSet.cpp + binaryTreeDictionary.cpp + blockOffsetTable.cpp + cardTableModRefBS.cpp + cardTableRS.cpp + collectorPolicy.cpp + defNewGeneration.cpp + filemap.cpp + freeBlockDictionary.cpp + freeList.cpp + gcLocker.cpp + genCollectedHeap.cpp + genMarkSweep.cpp + genRemSet.cpp + generation.cpp + generationSpec.cpp + heap.cpp + heapInspection.cpp + iterator.cpp + memRegion.cpp + metablock.cpp + metachunk.cpp + metaspace.cpp + metaspaceCounters.cpp + metaspaceShared.cpp + oopFactory.cpp + referencePolicy.cpp + referenceProcessor.cpp + resourceArea.cpp + sharedHeap.cpp + space.cpp + specialized_oop_closures.cpp + tenuredGeneration.cpp + threadLocalAllocBuffer.cpp + universe.cpp + + + annotations.cpp + arrayKlass.cpp + arrayOop.cpp + compiledICHolder.cpp + constMethod.cpp + constantPool.cpp + cpCache.cpp + generateOopMap.cpp + instanceClassLoaderKlass.cpp + instanceKlass.cpp + instanceMirrorKlass.cpp + instanceOop.cpp + instanceRefKlass.cpp + klass.cpp + klassVtable.cpp + markOop.cpp + metadata.cpp + method.cpp + methodData.cpp + objArrayKlass.cpp + objArrayOop.cpp + oop.cpp + oopsHierarchy.cpp + symbol.cpp + typeArrayKlass.cpp + typeArrayOop.cpp + + + addnode.cpp + block.cpp + buildOopMap.cpp + bytecodeInfo.cpp + c2_globals.cpp + c2compiler.cpp + callGenerator.cpp + callnode.cpp + cfgnode.cpp + chaitin.cpp + classes.cpp + coalesce.cpp + compile.cpp + connode.cpp + divnode.cpp + doCall.cpp + domgraph.cpp + escape.cpp + gcm.cpp + generateOptoStub.cpp + graphKit.cpp + idealGraphPrinter.cpp + idealKit.cpp + ifg.cpp + ifnode.cpp + indexSet.cpp + lcm.cpp + library_call.cpp + live.cpp + locknode.cpp + loopPredicate.cpp + loopTransform.cpp + loopUnswitch.cpp + loopnode.cpp + loopopts.cpp + machnode.cpp + macro.cpp + matcher.cpp + memnode.cpp + mulnode.cpp + multnode.cpp + node.cpp + opcodes.cpp + output.cpp + parse1.cpp + parse2.cpp + parse3.cpp + parseHelper.cpp + phase.cpp + phaseX.cpp + postaloc.cpp + reg_split.cpp + regalloc.cpp + regmask.cpp + rootnode.cpp + runtime.cpp + split_if.cpp + stringopts.cpp + subnode.cpp + superword.cpp + type.cpp + vectornode.cpp + + + precompiled.hpp + + + + parserTests.cpp + + evmCompat.cpp + forte.cpp + jni.cpp + jniCheck.cpp + jniFastGetField.cpp + jvm.cpp + jvmtiClassFileReconstituter.cpp + jvmtiCodeBlobEvents.cpp + jvmtiEnv.cpp + jvmtiEnvBase.cpp + jvmtiEnvThreadState.cpp + jvmtiEventController.cpp + jvmtiExport.cpp + jvmtiExtensions.cpp + jvmtiGetLoadedClasses.cpp + jvmtiImpl.cpp + jvmtiManageCapabilities.cpp + jvmtiRawMonitor.cpp + jvmtiRedefineClasses.cpp + jvmtiTagMap.cpp + jvmtiThreadState.cpp + jvmtiTrace.cpp + jvmtiUtil.cpp + methodComparator.cpp + methodHandles.cpp + nativeLookup.cpp + perf.cpp + privilegedStack.cpp + unsafe.cpp + whitebox.cpp + + + advancedThresholdPolicy.cpp + aprofiler.cpp + arguments.cpp + atomic.cpp + basicLock.cpp + biasedLocking.cpp + compilationPolicy.cpp + deoptimization.cpp + dtraceJSDT.cpp + fieldDescriptor.cpp + fieldType.cpp + fprofiler.cpp + frame.cpp + globals.cpp + handles.cpp + icache.cpp + init.cpp + interfaceSupport.cpp + java.cpp + javaCalls.cpp + jniHandles.cpp + jniPeriodicChecker.cpp + memprofiler.cpp + monitorChunk.cpp + mutex.cpp + mutexLocker.cpp + objectMonitor.cpp + orderAccess.cpp + os.cpp + osThread.cpp + park.cpp + perfData.cpp + perfMemory.cpp + reflection.cpp + reflectionUtils.cpp + relocator.cpp + rframe.cpp + safepoint.cpp + serviceThread.cpp + sharedRuntime.cpp + sharedRuntimeTrans.cpp + sharedRuntimeTrig.cpp + signature.cpp + simpleThresholdPolicy.cpp + stackValue.cpp + stackValueCollection.cpp + statSampler.cpp + stubCodeGenerator.cpp + stubRoutines.cpp + sweeper.cpp + synchronizer.cpp + task.cpp + thread.cpp + threadLocalStorage.cpp + timer.cpp + unhandledOops.cpp + vframe.cpp + vframeArray.cpp + vframe_hp.cpp + virtualspace.cpp + vmStructs.cpp + vmThread.cpp + vm_operations.cpp + vm_version.cpp + + + attachListener.cpp + classLoadingService.cpp + diagnosticArgument.cpp + diagnosticCommand.cpp + diagnosticFramework.cpp + dtraceAttacher.cpp + g1MemoryPool.cpp + gcNotifier.cpp + heapDumper.cpp + lowMemoryDetector.cpp + management.cpp + memBaseline.cpp + memPtr.cpp + memRecorder.cpp + memReporter.cpp + memSnapshot.cpp + memTrackWorker.cpp + memTracker.cpp + memoryManager.cpp + memoryPool.cpp + memoryService.cpp + nmtDCmd.cpp + psMemoryPool.cpp + runtimeService.cpp + threadService.cpp + + + accessFlags.cpp + array.cpp + bitMap.cpp + constantTag.cpp + copy.cpp + debug.cpp + decoder.cpp + decoder_elf.cpp + elfFile.cpp + elfStringTable.cpp + elfSymbolTable.cpp + errorReporter.cpp + events.cpp + exceptions.cpp + globalDefinitions.cpp + growableArray.cpp + hashtable.cpp + histogram.cpp + intHisto.cpp + numberSeq.cpp + ostream.cpp + preserveException.cpp + quickSort.cpp + sizes.cpp + taskqueue.cpp + utf8.cpp + vmError.cpp + workgroup.cpp + xmlstream.cpp + yieldingWorkgroup.cpp + + + + + + + + + + add_gnu_debuglink.c + + + fix_empty_sec_hdr_flags.c + + + + + + + ArrayReferenceImpl.c + ArrayTypeImpl.c + ClassLoaderReferenceImpl.c + ClassObjectReferenceImpl.c + ClassTypeImpl.c + EventRequestImpl.c + FieldImpl.c + FrameID.c + MethodImpl.c + ObjectReferenceImpl.c + ReferenceTypeImpl.c + SDE.c + StackFrameImpl.c + StringReferenceImpl.c + ThreadGroupReferenceImpl.c + ThreadReferenceImpl.c + VirtualMachineImpl.c + bag.c + classTrack.c + commonRef.c + debugDispatch.c + debugInit.c + debugLoop.c + error_messages.c + eventFilter.c + eventHandler.c + eventHelper.c + inStream.c + invoker.c + log_messages.c + outStream.c + standardHandlers.c + stepControl.c + stream.c + threadControl.c + transport.c + util.c + + + java.c + jli_util.c + main.c + parse_manifest.c + splashscreen_stubs.c + version_comp.c + wildcard.c + + + + + agent_util.c + + + compiledMethodLoad.c + + + gctest.c + + + heapTracker.c + + + heapViewer.c + + + debug_malloc.c + hprof_blocks.c + hprof_check.c + hprof_class.c + hprof_cpu.c + hprof_error.c + hprof_event.c + hprof_frame.c + hprof_init.c + hprof_io.c + hprof_ioname.c + hprof_listener.c + hprof_loader.c + hprof_monitor.c + hprof_object.c + hprof_reference.c + hprof_site.c + hprof_stack.c + hprof_string.c + hprof_table.c + hprof_tag.c + hprof_tls.c + hprof_trace.c + hprof_tracker.c + hprof_util.c + + + java_crw_demo.c + + + minst.c + + + mtrace.c + + + versionCheck.c + + + Agent.cpp + Monitor.cpp + Thread.cpp + waiters.cpp + + + + + EncodingSupport.c + InstrumentationImplNativeMethods.c + InvocationAdapter.c + JPLISAgent.c + JPLISAssert.c + JarFacade.c + JavaExceptions.c + PathCharsValidator.c + Reentrancy.c + Utilities.c + + + + + + + + + bands.cpp + bytes.cpp + coding.cpp + jni.cpp + main.cpp + unpack.cpp + utils.cpp + zip.cpp + + + + + + + DirectAudioDevice.c + DirectAudioDeviceProvider.c + MidiInDevice.c + MidiInDeviceProvider.c + MidiOutDevice.c + MidiOutDeviceProvider.c + Platform.c + PlatformMidi.c + PortMixer.c + PortMixerProvider.c + Utilities.c + + + + + + check_code.c + check_format.c + check_version.c + jdk_util.c + jio.c + jni_util.c + verify_stub.c + + + + FileInputStream.c + ObjectInputStream.c + ObjectOutputStream.c + ObjectStreamClass.c + RandomAccessFile.c + io_util.c + + + + + e_acos.c + e_asin.c + e_atan2.c + e_atanh.c + e_cosh.c + e_exp.c + e_fmod.c + e_hypot.c + e_log.c + e_log10.c + e_pow.c + e_rem_pio2.c + e_remainder.c + e_scalb.c + e_sinh.c + e_sqrt.c + k_cos.c + k_rem_pio2.c + k_sin.c + k_standard.c + k_tan.c + s_atan.c + s_cbrt.c + s_ceil.c + s_copysign.c + s_cos.c + s_expm1.c + s_fabs.c + s_finite.c + s_floor.c + s_frexp.c + s_ilogb.c + s_isnan.c + s_ldexp.c + s_lib_version.c + s_log1p.c + s_logb.c + s_matherr.c + s_modf.c + s_nextafter.c + s_rint.c + s_scalbn.c + s_signgam.c + s_significand.c + s_sin.c + s_tan.c + s_tanh.c + w_acos.c + w_asin.c + w_atan2.c + w_atanh.c + w_cosh.c + w_exp.c + w_fmod.c + w_hypot.c + w_log.c + w_log10.c + w_pow.c + w_remainder.c + w_scalb.c + w_sinh.c + w_sqrt.c + + + + Finalizer.c + + + Array.c + Executable.c + Proxy.c + + Class.c + ClassLoader.c + Compiler.c + Double.c + Float.c + Object.c + Package.c + ResourceBundle.c + Runtime.c + SecurityManager.c + Shutdown.c + StrictMath.c + String.c + System.c + Thread.c + Throwable.c + + + DatagramPacket.c + Inet4Address.c + Inet6Address.c + InetAddress.c + net_util.c + + + Bits.c + + + AccessController.c + + + + + AtomicLong.c + + + + + compress.c + deflate.c + gzclose.c + gzlib.c + gzread.c + gzwrite.c + infback.c + inffast.c + inflate.c + inftrees.c + trees.c + uncompr.c + zadler32.c + zcrc32.c + zutil.c + + Adler32.c + CRC32.c + Deflater.c + Inflater.c + ZipFile.c + zip_util.c + + TimeZone.c + + + + + + debug_assert.c + debug_mem.c + debug_trace.c + debug_util.c + + + dgif_lib.c + gif_err.c + gifalloc.c + + + + img_colors.c + img_globals.c + + + gifdecoder.c + + + imageioJPEG.c + jcapimin.c + jcapistd.c + jccoefct.c + jccolor.c + jcdctmgr.c + jchuff.c + jcinit.c + jcmainct.c + jcmarker.c + jcmaster.c + jcomapi.c + jcparam.c + jcphuff.c + jcprepct.c + jcsample.c + jctrans.c + jdapimin.c + jdapistd.c + jdcoefct.c + jdcolor.c + jddctmgr.c + jdhuff.c + jdinput.c + jdmainct.c + jdmarker.c + jdmaster.c + jdmerge.c + jdphuff.c + jdpostct.c + jdsample.c + jdtrans.c + jerror.c + jfdctflt.c + jfdctfst.c + jfdctint.c + jidctflt.c + jidctfst.c + jidctint.c + jidctred.c + jmemmgr.c + jmemnobs.c + jpegdecoder.c + jquant1.c + jquant2.c + jutils.c + + BufImgSurfaceData.c + DataBufferNative.c + awt_ImageRep.c + awt_parseImage.c + dither.c + imageInitIDs.c + + + png.c + pngerror.c + pngget.c + pngmem.c + pngpread.c + pngread.c + pngrio.c + pngrtran.c + pngrutil.c + pngset.c + pngtrans.c + pngwio.c + pngwrite.c + pngwtran.c + pngwutil.c + + + awt_ImagingLib.c + mlib_ImageAffine.c + mlib_ImageAffineEdge.c + mlib_ImageAffine_BC_D64.c + mlib_ImageAffine_BC_F32.c + mlib_ImageAffine_BC_S32.c + mlib_ImageAffine_BL_D64.c + mlib_ImageAffine_BL_F32.c + mlib_ImageAffine_BL_S32.c + mlib_ImageAffine_NN.c + mlib_ImageAffine_NN_Bit.c + mlib_ImageClipping.c + mlib_ImageColorTrue2Index.c + mlib_ImageConv2x2_f.c + mlib_ImageConvClearEdge_Bit.c + mlib_ImageConvClearEdge_Fp.c + mlib_ImageConvCopyEdge_Bit.c + mlib_ImageConvKernelConvert.c + mlib_ImageConvMxN.c + mlib_ImageConvMxN_Fp.c + mlib_ImageConvMxN_ext.c + mlib_ImageConv_16ext.c + mlib_ImageConv_16nw.c + mlib_ImageConv_32nw.c + mlib_ImageConv_8ext.c + mlib_ImageConv_8nw.c + mlib_ImageConv_D64nw.c + mlib_ImageConv_F32nw.c + mlib_ImageConv_u16ext.c + mlib_ImageConv_u16nw.c + mlib_ImageCopy_Bit.c + mlib_ImageCreate.c + mlib_ImageDivTables.c + mlib_ImageFilters.c + mlib_ImageLookUp_64.c + mlib_ImageLookUp_Bit.c + mlib_ImageScanPoly.c + mlib_ImageUtils.c + mlib_c_ImageAffineIndex_BC.c + mlib_c_ImageAffineIndex_BL.c + mlib_c_ImageAffine_BC.c + mlib_c_ImageAffine_BC_S16.c + mlib_c_ImageAffine_BC_U16.c + mlib_c_ImageAffine_BL.c + mlib_c_ImageAffine_BL_S16.c + mlib_c_ImageAffine_BL_U16.c + mlib_c_ImageAffine_NN.c + mlib_c_ImageConvClearEdge.c + mlib_c_ImageConvCopyEdge.c + mlib_c_ImageConvVersion.c + mlib_c_ImageConv_f.c + mlib_c_ImageCopy.c + mlib_c_ImageLookUp.c + mlib_c_ImageLookUp_f.c + mlib_c_ImageThresh1_U8.c + mlib_sys.c + + + java_awt_SplashScreen.c + splashscreen_gfx_impl.c + splashscreen_gif.c + splashscreen_impl.c + splashscreen_jpeg.c + splashscreen_png.c + + + rect.c + + + + + AlternateSubstSubtables.cpp + AnchorTables.cpp + ArabicLayoutEngine.cpp + ArabicShaping.cpp + CanonData.cpp + CanonShaping.cpp + ClassDefinitionTables.cpp + ContextualGlyphSubstProc.cpp + ContextualSubstSubtables.cpp + CoverageTables.cpp + CursiveAttachmentSubtables.cpp + DeviceTables.cpp + ExtensionSubtables.cpp + Features.cpp + GDEFMarkFilter.cpp + GXLayoutEngine.cpp + GlyphDefinitionTables.cpp + GlyphIterator.cpp + GlyphLookupTables.cpp + GlyphPositionAdjustments.cpp + GlyphPositioningTables.cpp + GlyphPosnLookupProc.cpp + GlyphSubstLookupProc.cpp + GlyphSubstitutionTables.cpp + HanLayoutEngine.cpp + HangulLayoutEngine.cpp + IndicClassTables.cpp + IndicLayoutEngine.cpp + IndicRearrangementProcessor.cpp + IndicReordering.cpp + KernTable.cpp + KhmerLayoutEngine.cpp + KhmerReordering.cpp + LEFontInstance.cpp + LEGlyphStorage.cpp + LEInsertionList.cpp + LayoutEngine.cpp + LigatureSubstProc.cpp + LigatureSubstSubtables.cpp + LookupProcessor.cpp + LookupTables.cpp + Lookups.cpp + MPreFixups.cpp + MarkArrays.cpp + MarkToBasePosnSubtables.cpp + MarkToLigaturePosnSubtables.cpp + MarkToMarkPosnSubtables.cpp + MirroredCharData.cpp + MorphTables.cpp + MultipleSubstSubtables.cpp + NonContextualGlyphSubstProc.cpp + OpenTypeLayoutEngine.cpp + OpenTypeUtilities.cpp + PairPositioningSubtables.cpp + ScriptAndLanguage.cpp + ScriptAndLanguageTags.cpp + SegmentArrayProcessor.cpp + SegmentSingleProcessor.cpp + ShapingTypeData.cpp + SimpleArrayProcessor.cpp + SinglePositioningSubtables.cpp + SingleSubstitutionSubtables.cpp + SingleTableProcessor.cpp + StateTableProcessor.cpp + SubstitutionLookups.cpp + SubtableProcessor.cpp + SunLayoutEngine.cpp + ThaiLayoutEngine.cpp + ThaiShaping.cpp + ThaiStateTables.cpp + TibetanLayoutEngine.cpp + TibetanReordering.cpp + TrimmedArrayProcessor.cpp + ValueRecords.cpp + + AccelGlyphCache.c + DrawGlyphList.c + FontInstanceAdapter.cpp + freetypeScaler.c + sunFont.c + + + + + LCMS.c + cmscam02.c + cmscgats.c + cmscnvrt.c + cmserr.c + cmsgamma.c + cmsgmt.c + cmshalf.c + cmsintrp.c + cmsio0.c + cmsio1.c + cmslut.c + cmsmd5.c + cmsmtrx.c + cmsnamed.c + cmsopt.c + cmspack.c + cmspcs.c + cmsplugin.c + cmsps2.c + cmssamp.c + cmssm.c + cmstypes.c + cmsvirt.c + cmswtpnt.c + cmsxform.c + + + + AlphaMacros.c + AlphaMath.c + Any3Byte.c + Any4Byte.c + AnyByte.c + AnyInt.c + AnyShort.c + Blit.c + BlitBg.c + ByteBinary1Bit.c + ByteBinary2Bit.c + ByteBinary4Bit.c + ByteGray.c + ByteIndexed.c + DrawLine.c + DrawParallelogram.c + DrawPath.c + DrawPolygons.c + DrawRect.c + FillParallelogram.c + FillPath.c + FillRect.c + FillSpans.c + FourByteAbgr.c + FourByteAbgrPre.c + GraphicsPrimitiveMgr.c + Index12Gray.c + Index8Gray.c + IntArgb.c + IntArgbBm.c + IntArgbPre.c + IntBgr.c + IntRgb.c + IntRgbx.c + MapAccelFunc.c + MaskBlit.c + MaskFill.c + ProcessPath.c + ScaledBlit.c + ThreeByteBgr.c + TransformHelper.c + Ushort4444Argb.c + Ushort555Rgb.c + Ushort555Rgbx.c + Ushort565Rgb.c + UshortGray.c + UshortIndexed.c + + + OGLBlitLoops.c + OGLBufImgOps.c + OGLContext.c + OGLFuncs.c + OGLMaskBlit.c + OGLMaskFill.c + OGLPaints.c + OGLRenderQueue.c + OGLRenderer.c + OGLSurfaceData.c + OGLTextRenderer.c + OGLVertexCache.c + + + BufferedMaskBlit.c + BufferedRenderPipe.c + Region.c + ShapeSpanIterator.c + SpanClipRenderer.c + + Disposer.c + SurfaceData.c + Trace.c + + + ClassLoadingImpl.c + Flag.c + GarbageCollectorImpl.c + GcInfoBuilder.c + HotSpotDiagnostic.c + HotspotThread.c + MemoryImpl.c + MemoryManagerImpl.c + MemoryPoolImpl.c + ThreadImpl.c + VMManagementImpl.c + management.c + + + GC.c + MessageUtils.c + NativeSignalHandler.c + Signal.c + VM.c + VMSupport.c + Version.c + + + + genSocketOptionRegistry.c + + + + ConstantPool.c + NativeAccessors.c + Reflection.c + + + + + ec.c + ec2_163.c + ec2_193.c + ec2_233.c + ec2_aff.c + ec2_mont.c + ec_naf.c + ecdecode.c + ecl.c + ecl_curve.c + ecl_gf.c + ecl_mult.c + ecp_192.c + ecp_224.c + ecp_256.c + ecp_384.c + ecp_521.c + ecp_aff.c + ecp_jac.c + ecp_jm.c + ecp_mont.c + mp_gf2m.c + mpi.c + mplogic.c + mpmontg.c + oid.c + secitem.c + + ECC_JNI.cpp + + + + GSSLibStub.c + NativeUtil.c + + + + + p11_convert.c + p11_crypt.c + p11_digest.c + p11_dual.c + p11_general.c + p11_keymgmt.c + p11_mutex.c + p11_objmgmt.c + p11_sessmgmt.c + p11_sign.c + p11_util.c + + j2secmod.c + + + pcsc.c + + + + + JVM.c + + + + + + npt.c + utf.c + + + + socketTransport.c + + + + + + exec_md.c + linker_md.c + + + ergo.c + ergo_i586.c + java_md_common.c + java_md_solinux.c + jexec.c + + + + + Poller.c + + + + + hprof_md.c + + + + + EncodingSupport_md.c + FileSystemSupport_md.c + + + + + + LinuxOperatingSystem.c + SolarisOperatingSystem.c + UnixOperatingSystem_md.c + + + + PLATFORM_API_LinuxOS_ALSA_CommonUtils.c + PLATFORM_API_LinuxOS_ALSA_MidiIn.c + PLATFORM_API_LinuxOS_ALSA_MidiOut.c + PLATFORM_API_LinuxOS_ALSA_MidiUtils.c + PLATFORM_API_LinuxOS_ALSA_PCM.c + PLATFORM_API_LinuxOS_ALSA_PCMUtils.c + PLATFORM_API_LinuxOS_ALSA_Ports.c + PLATFORM_API_SolarisOS_PCM.c + PLATFORM_API_SolarisOS_Ports.c + PLATFORM_API_SolarisOS_Utils.c + + + + + + Solaris.c + Unix.c + + + + + + + jdk_util_md.c + jni_util_md.c + + + + Console_md.c + FileDescriptor_md.c + FileInputStream_md.c + FileOutputStream_md.c + RandomAccessFile_md.c + UnixFileSystem_md.c + canonicalize_md.c + io_util_md.c + + + ProcessEnvironment_md.c + UNIXProcess_md.c + java_props_md.c + + + Inet4AddressImpl.c + Inet6AddressImpl.c + InetAddressImplFactory.c + NetworkInterface.c + PlainDatagramSocketImpl.c + PlainSocketImpl.c + SocketInputStream.c + SocketOutputStream.c + linux_close.c + net_util_md.c + + + MappedByteBuffer.c + + + FileSystemPreferences.c + TimeZone_md.c + logging.c + + + + + + splashscreen_sys.c + + CUPSfuncs.c + HeadlessToolkit.c + VDrawingArea.c + X11Color.c + awt_AWTEvent.c + awt_DrawingSurface.c + awt_Event.c + awt_Font.c + awt_GraphicsEnv.c + awt_InputMethod.c + awt_Insets.c + awt_LoadLibrary.c + awt_Mlib.c + awt_Plugin.c + awt_Robot.c + awt_UNIXToolkit.c + awt_util.c + fontpath.c + gtk2_interface.c + initIDs.c + jawt.c + list.c + multiVis.c + multi_font.c + robot_common.c + sun_awt_X11_GtkFileDialogPeer.c + swing_GTKEngine.c + swing_GTKStyle.c + + + X11FontScaler.c + X11TextRenderer.c + + + + GLXGraphicsConfig.c + GLXSurfaceData.c + + + X11FontScaler_md.c + X11PMBlitLoops.c + X11Renderer.c + X11SurfaceData.c + X11TextRenderer_md.c + XRBackendNative.c + XRSurfaceData.c + + + + FileSystemImpl.c + + + + ResolverConfigurationImpl.c + + + SdpSupport.c + + + DefaultProxySelector.c + + + + + + SctpChannelImpl.c + SctpNet.c + SctpServerChannelImpl.c + + DatagramChannelImpl.c + DatagramDispatcher.c + DevPollArrayWrapper.c + EPoll.c + EPollArrayWrapper.c + EPollPort.c + FileChannelImpl.c + FileDispatcherImpl.c + FileKey.c + IOUtil.c + InheritedChannel.c + NativeThread.c + Net.c + PollArrayWrapper.c + ServerSocketChannelImpl.c + SocketChannelImpl.c + SocketDispatcher.c + SolarisEventPort.c + UnixAsynchronousServerSocketChannelImpl.c + UnixAsynchronousSocketChannelImpl.c + + + GnomeFileTypeDetector.c + LinuxNativeDispatcher.c + LinuxWatchService.c + MagicFileTypeDetector.c + SolarisNativeDispatcher.c + SolarisWatchService.c + UnixCopyFile.c + UnixNativeDispatcher.c + genSolarisConstants.c + genUnixConstants.c + + + + + + NativeFunc.c + + + + + p11_md.c + + j2secmod_md.c + + + pcsc_md.c + + + + + LinuxVirtualMachine.c + SolarisVirtualMachine.c + + + + + jvm_symbols_md.c + + + + + + HostLocaleProviderAdapter_md.c + + + + + XToolkit.c + XWindow.c + XlibWrapper.c + awt_Desktop.c + gnome_interface.c + + + + + utf_md.c + + + + socket_md.c + + + + + + + + ../../Makefile + + + ^(nbproject)$ + + ../.. + + ../../Makefile + + + + LOCAL_SOURCES + default + + + + IDE_ALT_BOOTDIR + + + FULL_VERSION="version" + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_RELEASE_VERSION="version" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + JRE_RELEASE_VERSION="version" + + + + + ../.. + ${MAKE} -f Makefile LOG=debug images + ${MAKE} -f Makefile clean + + + + ../../build/macosx-x86_64-normal-server-release/hotspot/bsd_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/bsd_amd64_compiler2/generated + + + AMD64 + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + PRODUCT + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _XOPEN_SOURCE + + + __EXCEPTIONS + __GXX_RTTI + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + JRE_RELEASE_VERSION="version" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + /usr/X11/include + ../../build/macosx-x86_64-normal-server-release/jdk/include + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/image/cvutils + + + + + + + LINUX + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + _REENTRANT + + + + + + + ../../hotspot/src/os/posix/launcher + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/tools/launcher + ../../build/macosx-x86_64-normal-server-release/hotspot/bsd_amd64_compiler2/product + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/bsd_amd64_compiler2/generated + + + AMD64 + ARCH="amd64" + FULL_VERSION="version" + GAMMA + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + JDK_MAJOR_VERSION="version" + JDK_MINOR_VERSION="minor" + LAUNCHER_TYPE="gamma" + LINK_INTO_LIBJVM + PRODUCT + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + _ALLBSD_SOURCE + _GNU_SOURCE + + + + + + + ../../hotspot/agent/src/os/linux + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ${IDE_ALT_BOOTDIR}include + ${IDE_ALT_BOOTDIR}include/linux + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + _FILE_OFFSET_BITS=64 + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + _REENTRANT + + + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_RELEASE_VERSION="version" + LINUX + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + _REENTRANT + + + + + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_RELEASE_VERSION="version" + LINUX + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + _REENTRANT + + + + + + + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/share/vm/adlc + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + ASSERT + LINUX + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + _REENTRANT + + + + + + + THIS_FILE="ArrayReferenceImpl.c" + + + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="Agent.cpp" + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/export + ../../jdk/src/share/back/export + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/back + ../../jdk/src/solaris/back + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers + ../../jdk/makefiles + + + ARCH="amd64" + JDWP_LOGGING + LINUX + NDEBUG + RELEASE="" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + ARCH="amd64" + LIBARCHNAME="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="java.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="agent_util.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/src/share/demo/jvmti/waiters + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/demo/jvmti/heapTracker + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/demo/jvmti/compiledMethodLoad + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="compiledMethodLoad.c" + + + + + + + ../../jdk/src/share/demo/jvmti/gctest + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="gctest.c" + + + + + + + ../../jdk/src/share/demo/jvmti/heapTracker + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="heapTracker.c" + + + + + + + ../../jdk/src/share/demo/jvmti/heapViewer + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="heapViewer.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="debug_malloc.c" + + + + + + + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/solaris/demo/jvmti/hprof + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + THIS_FILE="java_crw_demo.c" + + + + + + + ../../jdk/src/share/demo/jvmti/minst + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="minst.c" + + + + + + + ../../jdk/src/share/demo/jvmti/mtrace + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="mtrace.c" + + + + + + + ../../jdk/src/share/demo/jvmti/versionCheck + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="versionCheck.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/instrument + ../../jdk/src/solaris/instrument + ../../jdk/src/share/bin + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + NO_JPLIS_LOGGING + RELEASE="" + THIS_FILE="EncodingSupport.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + THIS_FILE="DirectAudioDevice.c" + + + + + THIS_FILE="bands.cpp" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/com/sun/media/sound + ../../jdk/src/solaris/native/com/sun/media/sound + ../../jdk/makefiles + + + ARCH="amd64" + EXTRA_SOUND_JNI_LIBS=" jsoundalsa" + LINUX + NDEBUG + RELEASE="" + X_ARCH=X_AMD64 + X_PLATFORM=X_LINUX + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + FULL + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="check_code.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="FileInputStream.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="e_acos.c" + + + + + + + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Finalizer.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Array.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="DatagramPacket.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Bits.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="AccessController.c" + + + + + + + THIS_FILE="AtomicLong.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + THIS_FILE="compress.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + WITH_X11 + + + + + + + THIS_FILE="debug_assert.c" + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="AlternateSubstSubtables.cpp" + + + + + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="dgif_lib.c" + WITH_X11 + + + + + + + THIS_FILE="img_colors.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="gifdecoder.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + THIS_FILE="imageioJPEG.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="png.c" + WITH_X11 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_ImagingLib.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="java_awt_SplashScreen.c" + WITH_X11 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="rect.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="AccelGlyphCache.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="LCMS.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="AlphaMacros.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="OGLBlitLoops.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="BufferedMaskBlit.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="ClassLoadingImpl.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="GC.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../jdk/makefiles + + + THIS_FILE="genSocketOptionRegistry.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="ConstantPool.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="ec.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + ../../jdk/src/share/native/sun/security/ec + ../../jdk/src/share/native/sun/security/ec/impl + ../../jdk/makefiles + + + THIS_FILE="ECC_JNI.cpp" + + + + + + + ../../jdk/src/share/native/sun/security/ec + ../../jdk/src/share/native/sun/security/ec/impl + ../../jdk/makefiles + + + MP_API_COMPATIBLE + NSS_ECC_MORE_THAN_SUITE_B + + + + + + + ../../jdk/src/share/native/sun/security/jgss/wrapper + ../../jdk/src/solaris/native/sun/security/jgss/wrapper + ../../jdk/makefiles + + + THIS_FILE="GSSLibStub.c" + + + + + + + ../../jdk/src/share/native/sun/security/pkcs11 + ../../jdk/src/solaris/native/sun/security/pkcs11 + ../../jdk/src/share/native/sun/security/pkcs11/wrapper + ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper + ../../jdk/makefiles + + + THIS_FILE="p11_convert.c" + + + + + + + ../../jdk/src/share/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE + ../../jdk/makefiles + + + THIS_FILE="pcsc.c" + __sun_jdk + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/tracing/dtrace + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="JVM.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="npt.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/socket + ../../jdk/src/solaris/transport/socket + ../../jdk/src/share/back/export + ../../jdk/src/share/back + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="socketTransport.c" + USE_MMAP + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="exec_md.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/export + ../../jdk/src/share/back/export + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/back + ../../jdk/src/solaris/back + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers + ../../jdk/makefiles + + + JDWP_LOGGING + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + THIS_FILE="ergo.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="hprof_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/instrument + ../../jdk/src/solaris/instrument + ../../jdk/src/share/bin + ../../jdk/makefiles + + + NO_JPLIS_LOGGING + THIS_FILE="EncodingSupport_md.c" + + + + + + + THIS_FILE="LinuxOperatingSystem.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + + + + + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/com/sun/media/sound + ../../jdk/src/solaris/native/com/sun/media/sound + ../../jdk/makefiles + + + EXTRA_SOUND_JNI_LIBS=" jsoundalsa" + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_CommonUtils.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + X_ARCH=X_AMD64 + X_PLATFORM=X_LINUX + + + + + + + ../../jdk/makefiles + + + THIS_FILE="Unix.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jdk_util_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="Console_md.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="ProcessEnvironment_md.c" + + + + + + + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="Inet4AddressImpl.c" + + + + + + + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="MappedByteBuffer.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="FileSystemPreferences.c" + + + + + + + THIS_FILE="splashscreen_sys.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + WITH_X11 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="X11FontScaler.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="GLXGraphicsConfig.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + THIS_FILE="X11FontScaler_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + THIS_FILE="FileSystemImpl.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="ResolverConfigurationImpl.c" + + + + + + + THIS_FILE="SdpSupport.c" + + + + + + + THIS_FILE="DefaultProxySelector.c" + + + + + + + THIS_FILE="SctpChannelImpl.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + + + + + + + ../../jdk/src/share/native/sun/nio/ch/sctp + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/sun/nio/ch + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + + + + + THIS_FILE="GnomeFileTypeDetector.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="NativeFunc.c" + + + + + + + ../../jdk/src/share/native/sun/security/jgss/wrapper + ../../jdk/src/solaris/native/sun/security/jgss/wrapper + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/security/pkcs11 + ../../jdk/src/solaris/native/sun/security/pkcs11 + ../../jdk/src/share/native/sun/security/pkcs11/wrapper + ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper + ../../jdk/makefiles + + + THIS_FILE="p11_md.c" + + + + + + + ../../jdk/src/share/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE + ../../jdk/makefiles + + + THIS_FILE="pcsc_md.c" + __sun_jdk + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + THIS_FILE="LinuxVirtualMachine.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/tracing/dtrace + ../../jdk/makefiles + + + THIS_FILE="jvm_symbols_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="HostLocaleProviderAdapter_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="XToolkit.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + THIS_FILE="utf_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/socket + ../../jdk/src/solaris/transport/socket + ../../jdk/src/share/back/export + ../../jdk/src/share/back + ../../jdk/makefiles + + + THIS_FILE="socket_md.c" + USE_MMAP + + + + + + + LOCAL_SOURCES + default + + + + IDE_ALT_BOOTDIR + + + FULL_VERSION="version" + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_RELEASE_VERSION="version" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + JRE_RELEASE_VERSION="version" + + + + + ../.. + ${MAKE} -f Makefile images + ${MAKE} -f Makefile clean + + + + LINUX + _GNU_SOURCE + _REENTRANT + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + JRE_RELEASE_VERSION="version" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="ArrayTypeImpl.c" + + + + + + + THIS_FILE="ClassLoaderReferenceImpl.c" + + + + + + + THIS_FILE="ClassObjectReferenceImpl.c" + + + + + + + THIS_FILE="ClassTypeImpl.c" + + + + + + + THIS_FILE="EventRequestImpl.c" + + + + + + + THIS_FILE="FieldImpl.c" + + + + + + + THIS_FILE="FrameID.c" + + + + + + + THIS_FILE="MethodImpl.c" + + + + + + + THIS_FILE="ObjectReferenceImpl.c" + + + + + + + THIS_FILE="ReferenceTypeImpl.c" + + + + + + + THIS_FILE="SDE.c" + + + + + + + THIS_FILE="StackFrameImpl.c" + + + + + + + THIS_FILE="StringReferenceImpl.c" + + + + + + + THIS_FILE="ThreadGroupReferenceImpl.c" + + + + + + + THIS_FILE="ThreadReferenceImpl.c" + + + + + + + THIS_FILE="VirtualMachineImpl.c" + + + + + + + THIS_FILE="bag.c" + + + + + + + THIS_FILE="classTrack.c" + + + + + + + THIS_FILE="commonRef.c" + + + + + + + THIS_FILE="debugDispatch.c" + + + + + + + THIS_FILE="debugInit.c" + + + + + + + THIS_FILE="debugLoop.c" + + + + + + + THIS_FILE="error_messages.c" + + + + + + + THIS_FILE="eventFilter.c" + + + + + + + THIS_FILE="eventHandler.c" + + + + + + + THIS_FILE="eventHelper.c" + + + + + + + THIS_FILE="inStream.c" + + + + + + + THIS_FILE="invoker.c" + + + + + + + THIS_FILE="log_messages.c" + + + + + + + THIS_FILE="outStream.c" + + + + + + + THIS_FILE="standardHandlers.c" + + + + + + + THIS_FILE="stepControl.c" + + + + + + + THIS_FILE="stream.c" + + + + + + + THIS_FILE="threadControl.c" + + + + + + + THIS_FILE="transport.c" + + + + + + + THIS_FILE="util.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + THIS_FILE="jli_util.c" + + + + + + + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/linux/bin + ../../jdk/makefiles + + + EXPAND_CLASSPATH_WILDCARDS + FULL_VERSION="version" + JAVA_ARGS={ "-J-ms8m", "com.sun.tools.javac.Main", } + JDK_MAJOR_VERSION="version" + JDK_MINOR_VERSION="minor" + LAUNCHER_NAME="openjdk" + NEVER_ACT_AS_SERVER_CLASS_MACHINE + PROGNAME="javac" + THIS_FILE="main.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + THIS_FILE="parse_manifest.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + THIS_FILE="splashscreen_stubs.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + THIS_FILE="version_comp.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + THIS_FILE="wildcard.c" + + + + + + + + + + + + + + + + + + + THIS_FILE="hprof_blocks.c" + + + + + + + THIS_FILE="hprof_check.c" + + + + + + + THIS_FILE="hprof_class.c" + + + + + + + THIS_FILE="hprof_cpu.c" + + + + + + + THIS_FILE="hprof_error.c" + + + + + + + THIS_FILE="hprof_event.c" + + + + + + + THIS_FILE="hprof_frame.c" + + + + + + + THIS_FILE="hprof_init.c" + + + + + + + THIS_FILE="hprof_io.c" + + + + + + + THIS_FILE="hprof_ioname.c" + + + + + + + THIS_FILE="hprof_listener.c" + + + + + + + THIS_FILE="hprof_loader.c" + + + + + + + THIS_FILE="hprof_monitor.c" + + + + + + + THIS_FILE="hprof_object.c" + + + + + + + THIS_FILE="hprof_reference.c" + + + + + + + THIS_FILE="hprof_site.c" + + + + + + + THIS_FILE="hprof_stack.c" + + + + + + + THIS_FILE="hprof_string.c" + + + + + + + THIS_FILE="hprof_table.c" + + + + + + + THIS_FILE="hprof_tag.c" + + + + + + + THIS_FILE="hprof_tls.c" + + + + + + + THIS_FILE="hprof_trace.c" + + + + + + + THIS_FILE="hprof_tracker.c" + + + + + + + THIS_FILE="hprof_util.c" + + + + + + + + + + + + + + + + + THIS_FILE="Monitor.cpp" + + + + + + + THIS_FILE="Thread.cpp" + + + + + + + THIS_FILE="waiters.cpp" + + + + + + + + + THIS_FILE="InstrumentationImplNativeMethods.c" + + + + + + + THIS_FILE="InvocationAdapter.c" + + + + + + + THIS_FILE="JPLISAgent.c" + + + + + + + THIS_FILE="JPLISAssert.c" + + + + + + + THIS_FILE="JarFacade.c" + + + + + + + THIS_FILE="JavaExceptions.c" + + + + + + + THIS_FILE="PathCharsValidator.c" + + + + + + + THIS_FILE="Reentrancy.c" + + + + + + + THIS_FILE="Utilities.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + UNPACK_JNI + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="bytes.cpp" + UNPACK_JNI + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="coding.cpp" + UNPACK_JNI + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="jni.cpp" + UNPACK_JNI + + + + + + + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/makefiles + + + THIS_FILE="main.cpp" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="unpack.cpp" + UNPACK_JNI + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="utils.cpp" + UNPACK_JNI + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="zip.cpp" + UNPACK_JNI + + + + + + + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="DirectAudioDeviceProvider.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="MidiInDevice.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="MidiInDeviceProvider.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="MidiOutDevice.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="MidiOutDeviceProvider.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="Platform.c" + + + + + + + THIS_FILE="PlatformMidi.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="PortMixer.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="PortMixerProvider.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + THIS_FILE="Utilities.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + + + + + + + ../../jdk/makefiles + + + + + + + ../../jdk/makefiles + + + THIS_FILE="check_format.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="check_version.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jdk_util.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jio.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jni_util.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="verify_stub.c" + + + + + + + + + THIS_FILE="ObjectInputStream.c" + + + + + + + THIS_FILE="ObjectOutputStream.c" + + + + + + + THIS_FILE="ObjectStreamClass.c" + + + + + + + THIS_FILE="RandomAccessFile.c" + + + + + + + THIS_FILE="io_util.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Class.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="ClassLoader.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Compiler.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Double.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Float.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Object.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Package.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="ResourceBundle.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Runtime.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="SecurityManager.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Shutdown.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="StrictMath.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="String.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="System.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Thread.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Throwable.c" + + + + + + + + + THIS_FILE="e_asin.c" + + + + + + + THIS_FILE="e_atan2.c" + + + + + + + THIS_FILE="e_atanh.c" + + + + + + + THIS_FILE="e_cosh.c" + + + + + + + THIS_FILE="e_exp.c" + + + + + + + THIS_FILE="e_fmod.c" + + + + + + + THIS_FILE="e_hypot.c" + + + + + + + THIS_FILE="e_log.c" + + + + + + + THIS_FILE="e_log10.c" + + + + + + + THIS_FILE="e_pow.c" + + + + + + + THIS_FILE="e_rem_pio2.c" + + + + + + + THIS_FILE="e_remainder.c" + + + + + + + THIS_FILE="e_scalb.c" + + + + + + + THIS_FILE="e_sinh.c" + + + + + + + THIS_FILE="e_sqrt.c" + + + + + + + THIS_FILE="k_cos.c" + + + + + + + THIS_FILE="k_rem_pio2.c" + + + + + + + THIS_FILE="k_sin.c" + + + + + + + THIS_FILE="k_standard.c" + + + + + + + THIS_FILE="k_tan.c" + + + + + + + THIS_FILE="s_atan.c" + + + + + + + THIS_FILE="s_cbrt.c" + + + + + + + THIS_FILE="s_ceil.c" + + + + + + + THIS_FILE="s_copysign.c" + + + + + + + THIS_FILE="s_cos.c" + + + + + + + THIS_FILE="s_expm1.c" + + + + + + + THIS_FILE="s_fabs.c" + + + + + + + THIS_FILE="s_finite.c" + + + + + + + THIS_FILE="s_floor.c" + + + + + + + THIS_FILE="s_frexp.c" + + + + + + + THIS_FILE="s_ilogb.c" + + + + + + + THIS_FILE="s_isnan.c" + + + + + + + THIS_FILE="s_ldexp.c" + + + + + + + THIS_FILE="s_lib_version.c" + + + + + + + THIS_FILE="s_log1p.c" + + + + + + + THIS_FILE="s_logb.c" + + + + + + + THIS_FILE="s_matherr.c" + + + + + + + THIS_FILE="s_modf.c" + + + + + + + THIS_FILE="s_nextafter.c" + + + + + + + THIS_FILE="s_rint.c" + + + + + + + THIS_FILE="s_scalbn.c" + + + + + + + THIS_FILE="s_signgam.c" + + + + + + + THIS_FILE="s_significand.c" + + + + + + + THIS_FILE="s_sin.c" + + + + + + + THIS_FILE="s_tan.c" + + + + + + + THIS_FILE="s_tanh.c" + + + + + + + THIS_FILE="w_acos.c" + + + + + + + THIS_FILE="w_asin.c" + + + + + + + THIS_FILE="w_atan2.c" + + + + + + + THIS_FILE="w_atanh.c" + + + + + + + THIS_FILE="w_cosh.c" + + + + + + + THIS_FILE="w_exp.c" + + + + + + + THIS_FILE="w_fmod.c" + + + + + + + THIS_FILE="w_hypot.c" + + + + + + + THIS_FILE="w_log.c" + + + + + + + THIS_FILE="w_log10.c" + + + + + + + THIS_FILE="w_pow.c" + + + + + + + THIS_FILE="w_remainder.c" + + + + + + + THIS_FILE="w_scalb.c" + + + + + + + THIS_FILE="w_sinh.c" + + + + + + + THIS_FILE="w_sqrt.c" + + + + + + + + + + + THIS_FILE="Executable.c" + + + + + + + THIS_FILE="Proxy.c" + + + + + + + + + THIS_FILE="Inet4Address.c" + + + + + + + THIS_FILE="Inet6Address.c" + + + + + + + THIS_FILE="InetAddress.c" + + + + + + + THIS_FILE="net_util.c" + + + + + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="TimeZone.c" + + + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="Adler32.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="CRC32.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="Deflater.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="Inflater.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="ZipFile.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="zip_util.c" + USE_MMAP + + + DEBUG + + + + + + + + + THIS_FILE="deflate.c" + + + + + + + THIS_FILE="gzclose.c" + + + + + + + THIS_FILE="gzlib.c" + + + + + + + THIS_FILE="gzread.c" + + + + + + + THIS_FILE="gzwrite.c" + + + + + + + THIS_FILE="infback.c" + + + + + + + THIS_FILE="inffast.c" + + + + + + + THIS_FILE="inflate.c" + + + + + + + THIS_FILE="inftrees.c" + + + + + + + THIS_FILE="trees.c" + + + + + + + THIS_FILE="uncompr.c" + + + + + + + THIS_FILE="zadler32.c" + + + + + + + THIS_FILE="zcrc32.c" + + + + + + + THIS_FILE="zutil.c" + + + + + + + + + THIS_FILE="debug_mem.c" + + + + + + + THIS_FILE="debug_trace.c" + + + + + + + THIS_FILE="debug_util.c" + + + + + + + + + THIS_FILE="gif_err.c" + + + + + + + THIS_FILE="gifalloc.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="BufImgSurfaceData.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="DataBufferNative.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_ImageRep.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_parseImage.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + + + THIS_FILE="img_globals.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="dither.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="imageInitIDs.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapimin.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapistd.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccoefct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccolor.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcdctmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jchuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcinit.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmainct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmarker.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmaster.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcomapi.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcparam.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcphuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcprepct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcsample.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jctrans.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapimin.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapistd.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcoefct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcolor.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jddctmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdhuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdinput.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmainct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmarker.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmaster.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmerge.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdphuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdpostct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdsample.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdtrans.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jerror.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctflt.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctfst.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctint.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctflt.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctfst.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctint.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctred.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemnobs.c" + WITH_X11 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/makefiles + + + THIS_FILE="jpegdecoder.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant1.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant2.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jutils.c" + WITH_X11 + + + + + + + + + THIS_FILE="pngerror.c" + + + + + + + THIS_FILE="pngget.c" + + + + + + + THIS_FILE="pngmem.c" + + + + + + + THIS_FILE="pngpread.c" + + + + + + + THIS_FILE="pngread.c" + + + + + + + THIS_FILE="pngrio.c" + + + + + + + THIS_FILE="pngrtran.c" + + + + + + + THIS_FILE="pngrutil.c" + + + + + + + THIS_FILE="pngset.c" + + + + + + + THIS_FILE="pngtrans.c" + + + + + + + THIS_FILE="pngwio.c" + + + + + + + THIS_FILE="pngwrite.c" + + + + + + + THIS_FILE="pngwtran.c" + + + + + + + THIS_FILE="pngwutil.c" + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffineEdge.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BC_D64.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BC_F32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BC_S32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BL_D64.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BL_F32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BL_S32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_NN.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_NN_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageClipping.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageColorTrue2Index.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv2x2_f.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvClearEdge_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvClearEdge_Fp.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvCopyEdge_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvKernelConvert.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvMxN.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvMxN_Fp.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvMxN_ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_16ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_16nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_32nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_8ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_8nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_D64nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_F32nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_u16ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_u16nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageCopy_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageCreate.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageDivTables.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageFilters.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageLookUp_64.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageLookUp_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageScanPoly.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageUtils.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffineIndex_BC.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffineIndex_BL.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BC.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BC_S16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BC_U16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BL.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BL_S16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BL_U16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_NN.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConvClearEdge.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConvCopyEdge.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConvVersion.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConv_f.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageCopy.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageLookUp.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageLookUp_f.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageThresh1_U8.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_OS64BIT + THIS_FILE="mlib_sys.c" + + + + + + + + + THIS_FILE="splashscreen_gfx_impl.c" + + + + + + + THIS_FILE="splashscreen_gif.c" + + + + + + + THIS_FILE="splashscreen_impl.c" + + + + + + + THIS_FILE="splashscreen_jpeg.c" + + + + + + + THIS_FILE="splashscreen_png.c" + + + + + + + + + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="DrawGlyphList.c" + + + + + + + THIS_FILE="FontInstanceAdapter.cpp" + + + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="freetypeScaler.c" + + + + + + + + + THIS_FILE="AnchorTables.cpp" + + + + + + + THIS_FILE="ArabicLayoutEngine.cpp" + + + + + + + THIS_FILE="ArabicShaping.cpp" + + + + + + + THIS_FILE="CanonData.cpp" + + + + + + + THIS_FILE="CanonShaping.cpp" + + + + + + + THIS_FILE="ClassDefinitionTables.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="ContextualSubstSubtables.cpp" + + + + + + + THIS_FILE="CoverageTables.cpp" + + + + + + + THIS_FILE="CursiveAttachmentSubtables.cpp" + + + + + + + THIS_FILE="DeviceTables.cpp" + + + + + + + THIS_FILE="ExtensionSubtables.cpp" + + + + + + + THIS_FILE="Features.cpp" + + + + + + + THIS_FILE="GDEFMarkFilter.cpp" + + + + + + + THIS_FILE="GXLayoutEngine.cpp" + + + + + + + THIS_FILE="GlyphDefinitionTables.cpp" + + + + + + + THIS_FILE="GlyphIterator.cpp" + + + + + + + THIS_FILE="GlyphLookupTables.cpp" + + + + + + + THIS_FILE="GlyphPositionAdjustments.cpp" + + + + + + + THIS_FILE="GlyphPositioningTables.cpp" + + + + + + + THIS_FILE="GlyphPosnLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstitutionTables.cpp" + + + + + + + THIS_FILE="HanLayoutEngine.cpp" + + + + + + + THIS_FILE="HangulLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicClassTables.cpp" + + + + + + + THIS_FILE="IndicLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor.cpp" + + + + + + + THIS_FILE="IndicReordering.cpp" + + + + + + + THIS_FILE="KernTable.cpp" + + + + + + + THIS_FILE="KhmerLayoutEngine.cpp" + + + + + + + THIS_FILE="KhmerReordering.cpp" + + + + + + + THIS_FILE="LEFontInstance.cpp" + + + + + + + THIS_FILE="LEGlyphStorage.cpp" + + + + + + + THIS_FILE="LEInsertionList.cpp" + + + + + + + THIS_FILE="LayoutEngine.cpp" + + + + + + + THIS_FILE="LigatureSubstProc.cpp" + + + + + + + THIS_FILE="LigatureSubstSubtables.cpp" + + + + + + + THIS_FILE="LookupProcessor.cpp" + + + + + + + THIS_FILE="LookupTables.cpp" + + + + + + + THIS_FILE="Lookups.cpp" + + + + + + + THIS_FILE="MPreFixups.cpp" + + + + + + + THIS_FILE="MarkArrays.cpp" + + + + + + + THIS_FILE="MarkToBasePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToLigaturePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToMarkPosnSubtables.cpp" + + + + + + + THIS_FILE="MirroredCharData.cpp" + + + + + + + THIS_FILE="MorphTables.cpp" + + + + + + + THIS_FILE="MultipleSubstSubtables.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="OpenTypeLayoutEngine.cpp" + + + + + + + THIS_FILE="OpenTypeUtilities.cpp" + + + + + + + THIS_FILE="PairPositioningSubtables.cpp" + + + + + + + THIS_FILE="ScriptAndLanguage.cpp" + + + + + + + THIS_FILE="ScriptAndLanguageTags.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor.cpp" + + + + + + + THIS_FILE="ShapingTypeData.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor.cpp" + + + + + + + THIS_FILE="SinglePositioningSubtables.cpp" + + + + + + + THIS_FILE="SingleSubstitutionSubtables.cpp" + + + + + + + THIS_FILE="SingleTableProcessor.cpp" + + + + + + + THIS_FILE="StateTableProcessor.cpp" + + + + + + + THIS_FILE="SubstitutionLookups.cpp" + + + + + + + THIS_FILE="SubtableProcessor.cpp" + + + + + + + THIS_FILE="SunLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiShaping.cpp" + + + + + + + THIS_FILE="ThaiStateTables.cpp" + + + + + + + THIS_FILE="TibetanLayoutEngine.cpp" + + + + + + + THIS_FILE="TibetanReordering.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor.cpp" + + + + + + + THIS_FILE="ValueRecords.cpp" + + + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="sunFont.c" + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="Disposer.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="SurfaceData.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="Trace.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + + + THIS_FILE="cmscam02.c" + + + + + + + THIS_FILE="cmscgats.c" + + + + + + + THIS_FILE="cmscnvrt.c" + + + + + + + THIS_FILE="cmserr.c" + + + + + + + THIS_FILE="cmsgamma.c" + + + + + + + THIS_FILE="cmsgmt.c" + + + + + + + THIS_FILE="cmshalf.c" + + + + + + + THIS_FILE="cmsintrp.c" + + + + + + + THIS_FILE="cmsio0.c" + + + + + + + THIS_FILE="cmsio1.c" + + + + + + + THIS_FILE="cmslut.c" + + + + + + + THIS_FILE="cmsmd5.c" + + + + + + + THIS_FILE="cmsmtrx.c" + + + + + + + THIS_FILE="cmsnamed.c" + + + + + + + THIS_FILE="cmsopt.c" + + + + + + + THIS_FILE="cmspack.c" + + + + + + + THIS_FILE="cmspcs.c" + + + + + + + THIS_FILE="cmsplugin.c" + + + + + + + THIS_FILE="cmsps2.c" + + + + + + + THIS_FILE="cmssamp.c" + + + + + + + THIS_FILE="cmssm.c" + + + + + + + THIS_FILE="cmstypes.c" + + + + + + + THIS_FILE="cmsvirt.c" + + + + + + + THIS_FILE="cmswtpnt.c" + + + + + + + THIS_FILE="cmsxform.c" + + + + + + + + + THIS_FILE="AlphaMath.c" + + + + + + + THIS_FILE="Any3Byte.c" + + + + + + + THIS_FILE="Any4Byte.c" + + + + + + + THIS_FILE="AnyByte.c" + + + + + + + THIS_FILE="AnyInt.c" + + + + + + + THIS_FILE="AnyShort.c" + + + + + + + THIS_FILE="Blit.c" + + + + + + + THIS_FILE="BlitBg.c" + + + + + + + THIS_FILE="ByteBinary1Bit.c" + + + + + + + THIS_FILE="ByteBinary2Bit.c" + + + + + + + THIS_FILE="ByteBinary4Bit.c" + + + + + + + THIS_FILE="ByteGray.c" + + + + + + + THIS_FILE="ByteIndexed.c" + + + + + + + THIS_FILE="DrawLine.c" + + + + + + + THIS_FILE="DrawParallelogram.c" + + + + + + + THIS_FILE="DrawPath.c" + + + + + + + THIS_FILE="DrawPolygons.c" + + + + + + + THIS_FILE="DrawRect.c" + + + + + + + THIS_FILE="FillParallelogram.c" + + + + + + + THIS_FILE="FillPath.c" + + + + + + + THIS_FILE="FillRect.c" + + + + + + + THIS_FILE="FillSpans.c" + + + + + + + THIS_FILE="FourByteAbgr.c" + + + + + + + THIS_FILE="FourByteAbgrPre.c" + + + + + + + THIS_FILE="GraphicsPrimitiveMgr.c" + + + + + + + THIS_FILE="Index12Gray.c" + + + + + + + THIS_FILE="Index8Gray.c" + + + + + + + THIS_FILE="IntArgb.c" + + + + + + + THIS_FILE="IntArgbBm.c" + + + + + + + THIS_FILE="IntArgbPre.c" + + + + + + + THIS_FILE="IntBgr.c" + + + + + + + THIS_FILE="IntRgb.c" + + + + + + + THIS_FILE="IntRgbx.c" + + + + + + + THIS_FILE="MapAccelFunc.c" + + + + + + + THIS_FILE="MaskBlit.c" + + + + + + + THIS_FILE="MaskFill.c" + + + + + + + THIS_FILE="ProcessPath.c" + + + + + + + THIS_FILE="ScaledBlit.c" + + + + + + + THIS_FILE="ThreeByteBgr.c" + + + + + + + THIS_FILE="TransformHelper.c" + + + + + + + THIS_FILE="Ushort4444Argb.c" + + + + + + + THIS_FILE="Ushort555Rgb.c" + + + + + + + THIS_FILE="Ushort555Rgbx.c" + + + + + + + THIS_FILE="Ushort565Rgb.c" + + + + + + + THIS_FILE="UshortGray.c" + + + + + + + THIS_FILE="UshortIndexed.c" + + + + + + + + + THIS_FILE="OGLBufImgOps.c" + + + + + + + THIS_FILE="OGLContext.c" + + + + + + + THIS_FILE="OGLFuncs.c" + + + + + + + THIS_FILE="OGLMaskBlit.c" + + + + + + + THIS_FILE="OGLMaskFill.c" + + + + + + + THIS_FILE="OGLPaints.c" + + + + + + + THIS_FILE="OGLRenderQueue.c" + + + + + + + THIS_FILE="OGLRenderer.c" + + + + + + + THIS_FILE="OGLSurfaceData.c" + + + + + + + THIS_FILE="OGLTextRenderer.c" + + + + + + + THIS_FILE="OGLVertexCache.c" + + + + + + + + + THIS_FILE="BufferedRenderPipe.c" + + + + + + + THIS_FILE="Region.c" + + + + + + + THIS_FILE="ShapeSpanIterator.c" + + + + + + + THIS_FILE="SpanClipRenderer.c" + + + + + + + + + THIS_FILE="Flag.c" + + + + + + + THIS_FILE="GarbageCollectorImpl.c" + + + + + + + THIS_FILE="GcInfoBuilder.c" + + + + + + + THIS_FILE="HotSpotDiagnostic.c" + + + + + + + THIS_FILE="HotspotThread.c" + + + + + + + THIS_FILE="MemoryImpl.c" + + + + + + + THIS_FILE="MemoryManagerImpl.c" + + + + + + + THIS_FILE="MemoryPoolImpl.c" + + + + + + + THIS_FILE="ThreadImpl.c" + + + + + + + THIS_FILE="VMManagementImpl.c" + + + + + + + THIS_FILE="management.c" + + + + + + + + + THIS_FILE="MessageUtils.c" + + + + + + + THIS_FILE="NativeSignalHandler.c" + + + + + + + THIS_FILE="Signal.c" + + + + + + + THIS_FILE="VM.c" + + + + + + + THIS_FILE="VMSupport.c" + + + + + + + THIS_FILE="Version.c" + + + + + + + + + + + THIS_FILE="NativeAccessors.c" + + + + + + + THIS_FILE="Reflection.c" + + + + + + + + + + + THIS_FILE="ec2_163.c" + + + + + + + THIS_FILE="ec2_193.c" + + + + + + + THIS_FILE="ec2_233.c" + + + + + + + THIS_FILE="ec2_aff.c" + + + + + + + THIS_FILE="ec2_mont.c" + + + + + + + THIS_FILE="ec_naf.c" + + + + + + + THIS_FILE="ecdecode.c" + + + + + + + THIS_FILE="ecl.c" + + + + + + + THIS_FILE="ecl_curve.c" + + + + + + + THIS_FILE="ecl_gf.c" + + + + + + + THIS_FILE="ecl_mult.c" + + + + + + + THIS_FILE="ecp_192.c" + + + + + + + THIS_FILE="ecp_224.c" + + + + + + + THIS_FILE="ecp_256.c" + + + + + + + THIS_FILE="ecp_384.c" + + + + + + + THIS_FILE="ecp_521.c" + + + + + + + THIS_FILE="ecp_aff.c" + + + + + + + THIS_FILE="ecp_jac.c" + + + + + + + THIS_FILE="ecp_jm.c" + + + + + + + THIS_FILE="ecp_mont.c" + + + + + + + THIS_FILE="mp_gf2m.c" + + + + + + + THIS_FILE="mpi.c" + + + + + + + THIS_FILE="mplogic.c" + + + + + + + THIS_FILE="mpmontg.c" + + + + + + + THIS_FILE="oid.c" + + + + + + + THIS_FILE="secitem.c" + + + + + + + + + THIS_FILE="NativeUtil.c" + + + + + + + THIS_FILE="j2secmod.c" + + + + + + + + + THIS_FILE="p11_crypt.c" + + + + + + + THIS_FILE="p11_digest.c" + + + + + + + THIS_FILE="p11_dual.c" + + + + + + + THIS_FILE="p11_general.c" + + + + + + + THIS_FILE="p11_keymgmt.c" + + + + + + + THIS_FILE="p11_mutex.c" + + + + + + + THIS_FILE="p11_objmgmt.c" + + + + + + + THIS_FILE="p11_sessmgmt.c" + + + + + + + THIS_FILE="p11_sign.c" + + + + + + + THIS_FILE="p11_util.c" + + + + + + + + + + + + + THIS_FILE="utf.c" + + + + + + + + + + + THIS_FILE="linker_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCHNAME="amd64" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCHNAME="amd64" + THIS_FILE="ergo_i586.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCHNAME="amd64" + THIS_FILE="java_md_common.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCHNAME="amd64" + THIS_FILE="java_md_solinux.c" + + + + + + + ../../jdk/src/share/bin + ../../jdk/makefiles + + + THIS_FILE="jexec.c" + + + + + + + + + + + THIS_FILE="FileSystemSupport_md.c" + + + + + + + + + THIS_FILE="UnixOperatingSystem_md.c" + + + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiIn.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiOut.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiUtils.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_PCM.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_PCMUtils.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_Ports.c" + + + + + + + + + + + THIS_FILE="jni_util_md.c" + + + + + + + + + THIS_FILE="FileDescriptor_md.c" + + + + + + + THIS_FILE="FileInputStream_md.c" + + + + + + + THIS_FILE="FileOutputStream_md.c" + + + + + + + THIS_FILE="RandomAccessFile_md.c" + + + + + + + THIS_FILE="UnixFileSystem_md.c" + + + + + + + THIS_FILE="canonicalize_md.c" + + + + + + + THIS_FILE="io_util_md.c" + + + + + + + + + THIS_FILE="UNIXProcess_md.c" + + + + + + + THIS_FILE="java_props_md.c" + + + + + + + + + THIS_FILE="Inet6AddressImpl.c" + + + + + + + THIS_FILE="InetAddressImplFactory.c" + + + + + + + THIS_FILE="NetworkInterface.c" + + + + + + + THIS_FILE="PlainDatagramSocketImpl.c" + + + + + + + THIS_FILE="PlainSocketImpl.c" + + + + + + + THIS_FILE="SocketInputStream.c" + + + + + + + THIS_FILE="SocketOutputStream.c" + + + + + + + THIS_FILE="linux_close.c" + + + + + + + THIS_FILE="net_util_md.c" + + + + + + + + + + + THIS_FILE="TimeZone_md.c" + + + + + + + THIS_FILE="logging.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="CUPSfuncs.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + HEADLESS=true + PACKAGE_PATH="/opt/local" + THIS_FILE="HeadlessToolkit.c" + X11_PATH="/usr/X11R6" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + HEADLESS=true + PACKAGE_PATH="/opt/local" + THIS_FILE="VDrawingArea.c" + X11_PATH="/usr/X11R6" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="X11Color.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_AWTEvent.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_DrawingSurface.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Event.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Font.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_GraphicsEnv.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_InputMethod.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Insets.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_LoadLibrary.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_Mlib.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Plugin.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Robot.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_UNIXToolkit.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_util.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="fontpath.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="gtk2_interface.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="initIDs.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="jawt.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="list.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="multiVis.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="multi_font.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="robot_common.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="sun_awt_X11_GtkFileDialogPeer.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="swing_GTKEngine.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="swing_GTKStyle.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + + + THIS_FILE="X11TextRenderer.c" + + + + + + + + + THIS_FILE="GLXSurfaceData.c" + + + + + + + + + THIS_FILE="X11PMBlitLoops.c" + + + + + + + THIS_FILE="X11Renderer.c" + + + + + + + THIS_FILE="X11SurfaceData.c" + + + + + + + THIS_FILE="X11TextRenderer_md.c" + + + + + + + THIS_FILE="XRBackendNative.c" + + + + + + + THIS_FILE="XRSurfaceData.c" + + + + + + + + + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="DatagramChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="DatagramDispatcher.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="EPoll.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="EPollArrayWrapper.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="EPollPort.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="FileChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="FileDispatcherImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="FileKey.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="IOUtil.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="InheritedChannel.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="NativeThread.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="Net.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="PollArrayWrapper.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="ServerSocketChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="SocketChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="SocketDispatcher.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="UnixAsynchronousServerSocketChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="UnixAsynchronousSocketChannelImpl.c" + + + + + + + + + THIS_FILE="SctpNet.c" + + + + + + + THIS_FILE="SctpServerChannelImpl.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="LinuxNativeDispatcher.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="LinuxWatchService.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="MagicFileTypeDetector.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="UnixCopyFile.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="UnixNativeDispatcher.c" + + + + + + + ../../jdk/makefiles + + + THIS_FILE="genUnixConstants.c" + + + + + + + + + THIS_FILE="j2secmod_md.c" + + + + + + + + + + + + + + + + + + + THIS_FILE="XWindow.c" + + + + + + + THIS_FILE="XlibWrapper.c" + + + + + + + THIS_FILE="awt_Desktop.c" + + + + + + + THIS_FILE="gnome_interface.c" + + + + + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/image/cvutils + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + AMD64 + COMPILER1 + COMPILER2 + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + VM_LITTLE_ENDIAN + _LP64=1 + + + __EXCEPTIONS + __GXX_RTTI + + + + + + + _GNU_SOURCE + + + + + AMD64 + COMPILER1 + COMPILER2 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + + + __EXCEPTIONS + __GXX_RTTI + + + + + + + ../../hotspot/agent/src/os/linux + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ${IDE_ALT_BOOTDIR}/include + ${IDE_ALT_BOOTDIR}/include/linux + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + _FILE_OFFSET_BITS=64 + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + _REENTRANT + + + + + + + ../../hotspot/src/os/posix/launcher + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/tools/launcher + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + AMD64 + ARCH="amd64" + FULL_VERSION="version" + GAMMA + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + JDK_MAJOR_VERSION="version" + JDK_MINOR_VERSION="minor" + LAUNCHER_TYPE="gamma" + LINK_INTO_LIBJVM + LINUX + PRODUCT + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../hotspot/src/os/posix/launcher + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/tools/launcher + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + AMD64 + ARCH="amd64" + FULL_VERSION="version" + GAMMA + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + JDK_MAJOR_VERSION="version" + JDK_MINOR_VERSION="minor" + LAUNCHER_TYPE="gamma" + LINK_INTO_LIBJVM + LINUX + PRODUCT + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_linux_x86_64 + TARGET_OS_ARCH_linux_x86 + TARGET_OS_FAMILY_linux + + + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/share/vm/adlc + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + ASSERT + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + _LP64=1 + + + + + + + THIS_FILE="ArrayReferenceImpl.c" + + + + + ARCH="amd64" + NDEBUG + RELEASE="" + THIS_FILE="Agent.cpp" + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/export + ../../jdk/src/share/back/export + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/back + ../../jdk/src/solaris/back + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers + ../../jdk/makefiles + + + ARCH="amd64" + JDWP_LOGGING + LINUX + NDEBUG + RELEASE="" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + ARCH="amd64" + LIBARCHNAME="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="java.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="agent_util.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/src/share/demo/jvmti/waiters + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/demo/jvmti/heapTracker + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/demo/jvmti/compiledMethodLoad + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="compiledMethodLoad.c" + + + + + + + ../../jdk/src/share/demo/jvmti/gctest + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="gctest.c" + + + + + + + ../../jdk/src/share/demo/jvmti/heapTracker + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="heapTracker.c" + + + + + + + ../../jdk/src/share/demo/jvmti/heapViewer + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="heapViewer.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="debug_malloc.c" + + + + + + + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/solaris/demo/jvmti/hprof + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + THIS_FILE="java_crw_demo.c" + + + + + + + ../../jdk/src/share/demo/jvmti/minst + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="minst.c" + + + + + + + ../../jdk/src/share/demo/jvmti/mtrace + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="mtrace.c" + + + + + + + ../../jdk/src/share/demo/jvmti/versionCheck + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="versionCheck.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/instrument + ../../jdk/src/solaris/instrument + ../../jdk/src/share/bin + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + NO_JPLIS_LOGGING + RELEASE="" + THIS_FILE="EncodingSupport.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + THIS_FILE="DirectAudioDevice.c" + + + + + THIS_FILE="bands.cpp" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/com/sun/media/sound + ../../jdk/src/solaris/native/com/sun/media/sound + ../../jdk/makefiles + + + ARCH="amd64" + EXTRA_SOUND_JNI_LIBS=" jsoundalsa" + LINUX + NDEBUG + RELEASE="" + X_ARCH=X_AMD64 + X_PLATFORM=X_LINUX + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + FULL + PRODUCT + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="check_code.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="FileInputStream.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="e_acos.c" + + + + + + + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Finalizer.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Array.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="DatagramPacket.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Bits.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="AccessController.c" + + + + + + + THIS_FILE="AtomicLong.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + THIS_FILE="compress.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + WITH_X11 + + + + + + + THIS_FILE="debug_assert.c" + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="AlternateSubstSubtables.cpp" + + + + + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="dgif_lib.c" + WITH_X11 + + + + + + + THIS_FILE="img_colors.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="gifdecoder.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + THIS_FILE="imageioJPEG.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="png.c" + WITH_X11 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_ImagingLib.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="java_awt_SplashScreen.c" + WITH_X11 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="rect.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="AccelGlyphCache.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="LCMS.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="AlphaMacros.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="OGLBlitLoops.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + MLIB_NO_LIBSUNMATH + THIS_FILE="BufferedMaskBlit.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="ClassLoadingImpl.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="GC.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../jdk/makefiles + + + THIS_FILE="genSocketOptionRegistry.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="ConstantPool.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="ec.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + ../../jdk/src/share/native/sun/security/ec + ../../jdk/src/share/native/sun/security/ec/impl + ../../jdk/makefiles + + + THIS_FILE="ECC_JNI.cpp" + + + + + + + ../../jdk/src/share/native/sun/security/ec + ../../jdk/src/share/native/sun/security/ec/impl + ../../jdk/makefiles + + + MP_API_COMPATIBLE + NSS_ECC_MORE_THAN_SUITE_B + + + + + + + ../../jdk/src/share/native/sun/security/jgss/wrapper + ../../jdk/src/solaris/native/sun/security/jgss/wrapper + ../../jdk/makefiles + + + THIS_FILE="GSSLibStub.c" + + + + + + + ../../jdk/src/share/native/sun/security/pkcs11 + ../../jdk/src/solaris/native/sun/security/pkcs11 + ../../jdk/src/share/native/sun/security/pkcs11/wrapper + ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper + ../../jdk/makefiles + + + THIS_FILE="p11_convert.c" + + + + + + + ../../jdk/src/share/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE + ../../jdk/makefiles + + + THIS_FILE="pcsc.c" + __sun_jdk + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/tracing/dtrace + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="JVM.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="npt.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/socket + ../../jdk/src/solaris/transport/socket + ../../jdk/src/share/back/export + ../../jdk/src/share/back + ../../jdk/makefiles + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="socketTransport.c" + USE_MMAP + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ARCH="amd64" + LINUX + NDEBUG + RELEASE="" + THIS_FILE="exec_md.c" + _GNU_SOURCE + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 + _REENTRANT + amd64 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/export + ../../jdk/src/share/back/export + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/back + ../../jdk/src/solaris/back + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers + ../../jdk/makefiles + + + JDWP_LOGGING + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + THIS_FILE="ergo.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="hprof_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/instrument + ../../jdk/src/solaris/instrument + ../../jdk/src/share/bin + ../../jdk/makefiles + + + NO_JPLIS_LOGGING + THIS_FILE="EncodingSupport_md.c" + + + + + + + THIS_FILE="LinuxOperatingSystem.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + + + + + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/com/sun/media/sound + ../../jdk/src/solaris/native/com/sun/media/sound + ../../jdk/makefiles + + + EXTRA_SOUND_JNI_LIBS=" jsoundalsa" + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_CommonUtils.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + X_ARCH=X_AMD64 + X_PLATFORM=X_LINUX + + + + + + + ../../jdk/makefiles + + + THIS_FILE="Unix.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jdk_util_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="Console_md.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="ProcessEnvironment_md.c" + + + + + + + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="Inet4AddressImpl.c" + + + + + + + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="MappedByteBuffer.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="FileSystemPreferences.c" + + + + + + + THIS_FILE="splashscreen_sys.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/include + /usr/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + WITH_X11 + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="X11FontScaler.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="GLXGraphicsConfig.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + THIS_FILE="X11FontScaler_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + THIS_FILE="FileSystemImpl.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="ResolverConfigurationImpl.c" + + + + + + + THIS_FILE="SdpSupport.c" + + + + + + + THIS_FILE="DefaultProxySelector.c" + + + + + + + THIS_FILE="SctpChannelImpl.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + + + + + + + ../../jdk/src/share/native/sun/nio/ch/sctp + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/sun/nio/ch + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + + + + + THIS_FILE="GnomeFileTypeDetector.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="NativeFunc.c" + + + + + + + ../../jdk/src/share/native/sun/security/jgss/wrapper + ../../jdk/src/solaris/native/sun/security/jgss/wrapper + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/security/pkcs11 + ../../jdk/src/solaris/native/sun/security/pkcs11 + ../../jdk/src/share/native/sun/security/pkcs11/wrapper + ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper + ../../jdk/makefiles + + + THIS_FILE="p11_md.c" + + + + + + + ../../jdk/src/share/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE + ../../jdk/makefiles + + + THIS_FILE="pcsc_md.c" + __sun_jdk + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + THIS_FILE="LinuxVirtualMachine.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/tracing/dtrace + ../../jdk/makefiles + + + THIS_FILE="jvm_symbols_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="HostLocaleProviderAdapter_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="XToolkit.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + THIS_FILE="utf_md.c" + + + + + + + ../../build/linux-x86_64-normal-server-release/jdk/include + ../../build/linux-x86_64-normal-server-release/jdk/include/linux + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/socket + ../../jdk/src/solaris/transport/socket + ../../jdk/src/share/back/export + ../../jdk/src/share/back + ../../jdk/makefiles + + + THIS_FILE="socket_md.c" + USE_MMAP + + + + + + + LOCAL_SOURCES + default + + + + IDE_ALT_BOOTDIR + + + FULL_VERSION="version" + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_RELEASE_VERSION="version" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + JRE_RELEASE_VERSION="version" + + + + + ../.. + gmake -f Makefile images + gmake -f Makefile clean + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + VM_LITTLE_ENDIAN + _Crun_inline_placement + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../hotspot/src/share/vm/adlc + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + ASSERT + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + JRE_RELEASE_VERSION="version" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="ArrayTypeImpl.c" + + + + + + + THIS_FILE="ClassLoaderReferenceImpl.c" + + + + + + + THIS_FILE="ClassObjectReferenceImpl.c" + + + + + + + THIS_FILE="ClassTypeImpl.c" + + + + + + + THIS_FILE="EventRequestImpl.c" + + + + + + + THIS_FILE="FieldImpl.c" + + + + + + + THIS_FILE="FrameID.c" + + + + + + + THIS_FILE="MethodImpl.c" + + + + + + + THIS_FILE="ObjectReferenceImpl.c" + + + + + + + THIS_FILE="ReferenceTypeImpl.c" + + + + + + + THIS_FILE="SDE.c" + + + + + + + THIS_FILE="StackFrameImpl.c" + + + + + + + THIS_FILE="StringReferenceImpl.c" + + + + + + + THIS_FILE="ThreadGroupReferenceImpl.c" + + + + + + + THIS_FILE="ThreadReferenceImpl.c" + + + + + + + THIS_FILE="VirtualMachineImpl.c" + + + + + + + THIS_FILE="bag.c" + + + + + + + THIS_FILE="classTrack.c" + + + + + + + THIS_FILE="commonRef.c" + + + + + + + THIS_FILE="debugDispatch.c" + + + + + + + THIS_FILE="debugInit.c" + + + + + + + THIS_FILE="debugLoop.c" + + + + + + + THIS_FILE="error_messages.c" + + + + + + + THIS_FILE="eventFilter.c" + + + + + + + THIS_FILE="eventHandler.c" + + + + + + + THIS_FILE="eventHelper.c" + + + + + + + THIS_FILE="inStream.c" + + + + + + + THIS_FILE="invoker.c" + + + + + + + THIS_FILE="log_messages.c" + + + + + + + THIS_FILE="outStream.c" + + + + + + + THIS_FILE="standardHandlers.c" + + + + + + + THIS_FILE="stepControl.c" + + + + + + + THIS_FILE="stream.c" + + + + + + + THIS_FILE="threadControl.c" + + + + + + + THIS_FILE="transport.c" + + + + + + + THIS_FILE="util.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + THIS_FILE="jli_util.c" + + + + + + + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/makefiles + + + EXPAND_CLASSPATH_WILDCARDS + FULL_VERSION="version" + HAVE_GETHRTIME + JAVA_ARGS={ "-J-ms8m", "com.sun.tools.javac.Main", } + JDK_MAJOR_VERSION="version" + JDK_MINOR_VERSION="minor" + LAUNCHER_NAME="openjdk" + NEVER_ACT_AS_SERVER_CLASS_MACHINE + PROGNAME="javac" + THIS_FILE="main.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + THIS_FILE="parse_manifest.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + THIS_FILE="splashscreen_stubs.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + THIS_FILE="version_comp.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + THIS_FILE="wildcard.c" + + + + + + + + + + + + + + + + + + + THIS_FILE="hprof_blocks.c" + + + + + + + THIS_FILE="hprof_check.c" + + + + + + + THIS_FILE="hprof_class.c" + + + + + + + THIS_FILE="hprof_cpu.c" + + + + + + + THIS_FILE="hprof_error.c" + + + + + + + THIS_FILE="hprof_event.c" + + + + + + + THIS_FILE="hprof_frame.c" + + + + + + + THIS_FILE="hprof_init.c" + + + + + + + THIS_FILE="hprof_io.c" + + + + + + + THIS_FILE="hprof_ioname.c" + + + + + + + THIS_FILE="hprof_listener.c" + + + + + + + THIS_FILE="hprof_loader.c" + + + + + + + THIS_FILE="hprof_monitor.c" + + + + + + + THIS_FILE="hprof_object.c" + + + + + + + THIS_FILE="hprof_reference.c" + + + + + + + THIS_FILE="hprof_site.c" + + + + + + + THIS_FILE="hprof_stack.c" + + + + + + + THIS_FILE="hprof_string.c" + + + + + + + THIS_FILE="hprof_table.c" + + + + + + + THIS_FILE="hprof_tag.c" + + + + + + + THIS_FILE="hprof_tls.c" + + + + + + + THIS_FILE="hprof_trace.c" + + + + + + + THIS_FILE="hprof_tracker.c" + + + + + + + THIS_FILE="hprof_util.c" + + + + + + + + + + + + + + + + + THIS_FILE="Monitor.cpp" + + + + + + + THIS_FILE="Thread.cpp" + + + + + + + THIS_FILE="waiters.cpp" + + + + + + + + + THIS_FILE="InstrumentationImplNativeMethods.c" + + + + + + + THIS_FILE="InvocationAdapter.c" + + + + + + + THIS_FILE="JPLISAgent.c" + + + + + + + THIS_FILE="JPLISAssert.c" + + + + + + + THIS_FILE="JarFacade.c" + + + + + + + THIS_FILE="JavaExceptions.c" + + + + + + + THIS_FILE="PathCharsValidator.c" + + + + + + + THIS_FILE="Reentrancy.c" + + + + + + + THIS_FILE="Utilities.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + UNPACK_JNI + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="bytes.cpp" + UNPACK_JNI + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="coding.cpp" + UNPACK_JNI + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="jni.cpp" + UNPACK_JNI + + + + + + + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/makefiles + + + THIS_FILE="main.cpp" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="unpack.cpp" + UNPACK_JNI + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="utils.cpp" + UNPACK_JNI + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + NO_ZLIB + THIS_FILE="zip.cpp" + UNPACK_JNI + + + + + + + + + THIS_FILE="DirectAudioDeviceProvider.c" + + + + + + + THIS_FILE="MidiInDevice.c" + + + + + + + THIS_FILE="MidiInDeviceProvider.c" + + + + + + + THIS_FILE="MidiOutDevice.c" + + + + + + + THIS_FILE="MidiOutDeviceProvider.c" + + + + + + + THIS_FILE="Platform.c" + + + + + + + THIS_FILE="PlatformMidi.c" + + + + + + + THIS_FILE="PortMixer.c" + + + + + + + THIS_FILE="PortMixerProvider.c" + + + + + + + THIS_FILE="Utilities.c" + + + + + + + ../../jdk/makefiles + + + + + + + ../../jdk/makefiles + + + THIS_FILE="check_format.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="check_version.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jdk_util.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jio.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="jni_util.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="verify_stub.c" + + + + + + + + + THIS_FILE="ObjectInputStream.c" + + + + + + + THIS_FILE="ObjectOutputStream.c" + + + + + + + THIS_FILE="ObjectStreamClass.c" + + + + + + + THIS_FILE="RandomAccessFile.c" + + + + + + + THIS_FILE="io_util.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Class.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="ClassLoader.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Compiler.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Double.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Float.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Object.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Package.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="ResourceBundle.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Runtime.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="SecurityManager.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Shutdown.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="StrictMath.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="String.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="System.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Thread.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Throwable.c" + + + + + + + + + THIS_FILE="e_asin.c" + + + + + + + THIS_FILE="e_atan2.c" + + + + + + + THIS_FILE="e_atanh.c" + + + + + + + THIS_FILE="e_cosh.c" + + + + + + + THIS_FILE="e_exp.c" + + + + + + + THIS_FILE="e_fmod.c" + + + + + + + THIS_FILE="e_hypot.c" + + + + + + + THIS_FILE="e_log.c" + + + + + + + THIS_FILE="e_log10.c" + + + + + + + THIS_FILE="e_pow.c" + + + + + + + THIS_FILE="e_rem_pio2.c" + + + + + + + THIS_FILE="e_remainder.c" + + + + + + + THIS_FILE="e_scalb.c" + + + + + + + THIS_FILE="e_sinh.c" + + + + + + + THIS_FILE="e_sqrt.c" + + + + + + + THIS_FILE="k_cos.c" + + + + + + + THIS_FILE="k_rem_pio2.c" + + + + + + + THIS_FILE="k_sin.c" + + + + + + + THIS_FILE="k_standard.c" + + + + + + + THIS_FILE="k_tan.c" + + + + + + + THIS_FILE="s_atan.c" + + + + + + + THIS_FILE="s_cbrt.c" + + + + + + + THIS_FILE="s_ceil.c" + + + + + + + THIS_FILE="s_copysign.c" + + + + + + + THIS_FILE="s_cos.c" + + + + + + + THIS_FILE="s_expm1.c" + + + + + + + THIS_FILE="s_fabs.c" + + + + + + + THIS_FILE="s_finite.c" + + + + + + + THIS_FILE="s_floor.c" + + + + + + + THIS_FILE="s_frexp.c" + + + + + + + THIS_FILE="s_ilogb.c" + + + + + + + THIS_FILE="s_isnan.c" + + + + + + + THIS_FILE="s_ldexp.c" + + + + + + + THIS_FILE="s_lib_version.c" + + + + + + + THIS_FILE="s_log1p.c" + + + + + + + THIS_FILE="s_logb.c" + + + + + + + THIS_FILE="s_matherr.c" + + + + + + + THIS_FILE="s_modf.c" + + + + + + + THIS_FILE="s_nextafter.c" + + + + + + + THIS_FILE="s_rint.c" + + + + + + + THIS_FILE="s_scalbn.c" + + + + + + + THIS_FILE="s_signgam.c" + + + + + + + THIS_FILE="s_significand.c" + + + + + + + THIS_FILE="s_sin.c" + + + + + + + THIS_FILE="s_tan.c" + + + + + + + THIS_FILE="s_tanh.c" + + + + + + + THIS_FILE="w_acos.c" + + + + + + + THIS_FILE="w_asin.c" + + + + + + + THIS_FILE="w_atan2.c" + + + + + + + THIS_FILE="w_atanh.c" + + + + + + + THIS_FILE="w_cosh.c" + + + + + + + THIS_FILE="w_exp.c" + + + + + + + THIS_FILE="w_fmod.c" + + + + + + + THIS_FILE="w_hypot.c" + + + + + + + THIS_FILE="w_log.c" + + + + + + + THIS_FILE="w_log10.c" + + + + + + + THIS_FILE="w_pow.c" + + + + + + + THIS_FILE="w_remainder.c" + + + + + + + THIS_FILE="w_scalb.c" + + + + + + + THIS_FILE="w_sinh.c" + + + + + + + THIS_FILE="w_sqrt.c" + + + + + + + + + + + THIS_FILE="Executable.c" + + + + + + + THIS_FILE="Proxy.c" + + + + + + + + + THIS_FILE="Inet4Address.c" + + + + + + + THIS_FILE="Inet6Address.c" + + + + + + + THIS_FILE="InetAddress.c" + + + + + + + THIS_FILE="net_util.c" + + + + + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="TimeZone.c" + + + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="Adler32.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="CRC32.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="Deflater.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="Inflater.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="ZipFile.c" + USE_MMAP + + + DEBUG + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/makefiles + + + THIS_FILE="zip_util.c" + USE_MMAP + + + DEBUG + + + + + + + + + THIS_FILE="deflate.c" + + + + + + + THIS_FILE="gzclose.c" + + + + + + + THIS_FILE="gzlib.c" + + + + + + + THIS_FILE="gzread.c" + + + + + + + THIS_FILE="gzwrite.c" + + + + + + + THIS_FILE="infback.c" + + + + + + + THIS_FILE="inffast.c" + + + + + + + THIS_FILE="inflate.c" + + + + + + + THIS_FILE="inftrees.c" + + + + + + + THIS_FILE="trees.c" + + + + + + + THIS_FILE="uncompr.c" + + + + + + + THIS_FILE="zadler32.c" + + + + + + + THIS_FILE="zcrc32.c" + + + + + + + THIS_FILE="zutil.c" + + + + + + + + + THIS_FILE="debug_mem.c" + + + + + + + THIS_FILE="debug_trace.c" + + + + + + + THIS_FILE="debug_util.c" + + + + + + + + + THIS_FILE="gif_err.c" + + + + + + + THIS_FILE="gifalloc.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="BufImgSurfaceData.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="DataBufferNative.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="awt_ImageRep.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="awt_parseImage.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + + + THIS_FILE="img_globals.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="dither.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="imageInitIDs.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapimin.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapistd.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccoefct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccolor.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcdctmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jchuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcinit.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmainct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmarker.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmaster.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcomapi.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcparam.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcphuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcprepct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcsample.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jctrans.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapimin.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapistd.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcoefct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcolor.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jddctmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdhuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdinput.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmainct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmarker.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmaster.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmerge.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdphuff.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdpostct.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdsample.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdtrans.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jerror.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctflt.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctfst.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctint.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctflt.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctfst.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctint.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctred.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemnobs.c" + WITH_X11 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/makefiles + + + THIS_FILE="jpegdecoder.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant1.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant2.c" + WITH_X11 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jutils.c" + WITH_X11 + + + + + + + + + THIS_FILE="pngerror.c" + + + + + + + THIS_FILE="pngget.c" + + + + + + + THIS_FILE="pngmem.c" + + + + + + + THIS_FILE="pngpread.c" + + + + + + + THIS_FILE="pngread.c" + + + + + + + THIS_FILE="pngrio.c" + + + + + + + THIS_FILE="pngrtran.c" + + + + + + + THIS_FILE="pngrutil.c" + + + + + + + THIS_FILE="pngset.c" + + + + + + + THIS_FILE="pngtrans.c" + + + + + + + THIS_FILE="pngwio.c" + + + + + + + THIS_FILE="pngwrite.c" + + + + + + + THIS_FILE="pngwtran.c" + + + + + + + THIS_FILE="pngwutil.c" + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffineEdge.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BC_D64.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BC_F32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BC_S32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BL_D64.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BL_F32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_BL_S32.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_NN.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine_NN_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageClipping.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageColorTrue2Index.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv2x2_f.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvClearEdge_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvClearEdge_Fp.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvCopyEdge_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvKernelConvert.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvMxN.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvMxN_Fp.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConvMxN_ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_16ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_16nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_32nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_8ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_8nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_D64nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_F32nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_u16ext.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageConv_u16nw.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageCopy_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageCreate.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageDivTables.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageFilters.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageLookUp_64.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageLookUp_Bit.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageScanPoly.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageUtils.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffineIndex_BC.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffineIndex_BL.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BC.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BC_S16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BC_U16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BL.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BL_S16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_BL_U16.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageAffine_NN.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConvClearEdge.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConvCopyEdge.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConvVersion.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageConv_f.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageCopy.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageLookUp.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageLookUp_f.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_c_ImageThresh1_U8.c" + + + + + + + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/solaris/native/sun/awt/medialib + ../../jdk/makefiles + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_sys.c" + + + + + + + + + THIS_FILE="splashscreen_gfx_impl.c" + + + + + + + THIS_FILE="splashscreen_gif.c" + + + + + + + THIS_FILE="splashscreen_impl.c" + + + + + + + THIS_FILE="splashscreen_jpeg.c" + + + + + + + THIS_FILE="splashscreen_png.c" + + + + + + + + + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="DrawGlyphList.c" + + + + + + + THIS_FILE="FontInstanceAdapter.cpp" + + + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="freetypeScaler.c" + + + + + + + + + THIS_FILE="AnchorTables.cpp" + + + + + + + THIS_FILE="ArabicLayoutEngine.cpp" + + + + + + + THIS_FILE="ArabicShaping.cpp" + + + + + + + THIS_FILE="CanonData.cpp" + + + + + + + THIS_FILE="CanonShaping.cpp" + + + + + + + THIS_FILE="ClassDefinitionTables.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="ContextualSubstSubtables.cpp" + + + + + + + THIS_FILE="CoverageTables.cpp" + + + + + + + THIS_FILE="CursiveAttachmentSubtables.cpp" + + + + + + + THIS_FILE="DeviceTables.cpp" + + + + + + + THIS_FILE="ExtensionSubtables.cpp" + + + + + + + THIS_FILE="Features.cpp" + + + + + + + THIS_FILE="GDEFMarkFilter.cpp" + + + + + + + THIS_FILE="GXLayoutEngine.cpp" + + + + + + + THIS_FILE="GlyphDefinitionTables.cpp" + + + + + + + THIS_FILE="GlyphIterator.cpp" + + + + + + + THIS_FILE="GlyphLookupTables.cpp" + + + + + + + THIS_FILE="GlyphPositionAdjustments.cpp" + + + + + + + THIS_FILE="GlyphPositioningTables.cpp" + + + + + + + THIS_FILE="GlyphPosnLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstitutionTables.cpp" + + + + + + + THIS_FILE="HanLayoutEngine.cpp" + + + + + + + THIS_FILE="HangulLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicClassTables.cpp" + + + + + + + THIS_FILE="IndicLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor.cpp" + + + + + + + THIS_FILE="IndicReordering.cpp" + + + + + + + THIS_FILE="KernTable.cpp" + + + + + + + THIS_FILE="KhmerLayoutEngine.cpp" + + + + + + + THIS_FILE="KhmerReordering.cpp" + + + + + + + THIS_FILE="LEFontInstance.cpp" + + + + + + + THIS_FILE="LEGlyphStorage.cpp" + + + + + + + THIS_FILE="LEInsertionList.cpp" + + + + + + + THIS_FILE="LayoutEngine.cpp" + + + + + + + THIS_FILE="LigatureSubstProc.cpp" + + + + + + + THIS_FILE="LigatureSubstSubtables.cpp" + + + + + + + THIS_FILE="LookupProcessor.cpp" + + + + + + + THIS_FILE="LookupTables.cpp" + + + + + + + THIS_FILE="Lookups.cpp" + + + + + + + THIS_FILE="MPreFixups.cpp" + + + + + + + THIS_FILE="MarkArrays.cpp" + + + + + + + THIS_FILE="MarkToBasePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToLigaturePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToMarkPosnSubtables.cpp" + + + + + + + THIS_FILE="MirroredCharData.cpp" + + + + + + + THIS_FILE="MorphTables.cpp" + + + + + + + THIS_FILE="MultipleSubstSubtables.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="OpenTypeLayoutEngine.cpp" + + + + + + + THIS_FILE="OpenTypeUtilities.cpp" + + + + + + + THIS_FILE="PairPositioningSubtables.cpp" + + + + + + + THIS_FILE="ScriptAndLanguage.cpp" + + + + + + + THIS_FILE="ScriptAndLanguageTags.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor.cpp" + + + + + + + THIS_FILE="ShapingTypeData.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor.cpp" + + + + + + + THIS_FILE="SinglePositioningSubtables.cpp" + + + + + + + THIS_FILE="SingleSubstitutionSubtables.cpp" + + + + + + + THIS_FILE="SingleTableProcessor.cpp" + + + + + + + THIS_FILE="StateTableProcessor.cpp" + + + + + + + THIS_FILE="SubstitutionLookups.cpp" + + + + + + + THIS_FILE="SubtableProcessor.cpp" + + + + + + + THIS_FILE="SunLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiShaping.cpp" + + + + + + + THIS_FILE="ThaiStateTables.cpp" + + + + + + + THIS_FILE="TibetanLayoutEngine.cpp" + + + + + + + THIS_FILE="TibetanReordering.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor.cpp" + + + + + + + THIS_FILE="ValueRecords.cpp" + + + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + THIS_FILE="sunFont.c" + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="Disposer.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="SurfaceData.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="Trace.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + + + THIS_FILE="cmscam02.c" + + + + + + + THIS_FILE="cmscgats.c" + + + + + + + THIS_FILE="cmscnvrt.c" + + + + + + + THIS_FILE="cmserr.c" + + + + + + + THIS_FILE="cmsgamma.c" + + + + + + + THIS_FILE="cmsgmt.c" + + + + + + + THIS_FILE="cmshalf.c" + + + + + + + THIS_FILE="cmsintrp.c" + + + + + + + THIS_FILE="cmsio0.c" + + + + + + + THIS_FILE="cmsio1.c" + + + + + + + THIS_FILE="cmslut.c" + + + + + + + THIS_FILE="cmsmd5.c" + + + + + + + THIS_FILE="cmsmtrx.c" + + + + + + + THIS_FILE="cmsnamed.c" + + + + + + + THIS_FILE="cmsopt.c" + + + + + + + THIS_FILE="cmspack.c" + + + + + + + THIS_FILE="cmspcs.c" + + + + + + + THIS_FILE="cmsplugin.c" + + + + + + + THIS_FILE="cmsps2.c" + + + + + + + THIS_FILE="cmssamp.c" + + + + + + + THIS_FILE="cmssm.c" + + + + + + + THIS_FILE="cmstypes.c" + + + + + + + THIS_FILE="cmsvirt.c" + + + + + + + THIS_FILE="cmswtpnt.c" + + + + + + + THIS_FILE="cmsxform.c" + + + + + + + + + THIS_FILE="AlphaMath.c" + + + + + + + THIS_FILE="Any3Byte.c" + + + + + + + THIS_FILE="Any4Byte.c" + + + + + + + THIS_FILE="AnyByte.c" + + + + + + + THIS_FILE="AnyInt.c" + + + + + + + THIS_FILE="AnyShort.c" + + + + + + + THIS_FILE="Blit.c" + + + + + + + THIS_FILE="BlitBg.c" + + + + + + + THIS_FILE="ByteBinary1Bit.c" + + + + + + + THIS_FILE="ByteBinary2Bit.c" + + + + + + + THIS_FILE="ByteBinary4Bit.c" + + + + + + + THIS_FILE="ByteGray.c" + + + + + + + THIS_FILE="ByteIndexed.c" + + + + + + + THIS_FILE="DrawLine.c" + + + + + + + THIS_FILE="DrawParallelogram.c" + + + + + + + THIS_FILE="DrawPath.c" + + + + + + + THIS_FILE="DrawPolygons.c" + + + + + + + THIS_FILE="DrawRect.c" + + + + + + + THIS_FILE="FillParallelogram.c" + + + + + + + THIS_FILE="FillPath.c" + + + + + + + THIS_FILE="FillRect.c" + + + + + + + THIS_FILE="FillSpans.c" + + + + + + + THIS_FILE="FourByteAbgr.c" + + + + + + + THIS_FILE="FourByteAbgrPre.c" + + + + + + + THIS_FILE="GraphicsPrimitiveMgr.c" + + + + + + + THIS_FILE="Index12Gray.c" + + + + + + + THIS_FILE="Index8Gray.c" + + + + + + + THIS_FILE="IntArgb.c" + + + + + + + THIS_FILE="IntArgbBm.c" + + + + + + + THIS_FILE="IntArgbPre.c" + + + + + + + THIS_FILE="IntBgr.c" + + + + + + + THIS_FILE="IntRgb.c" + + + + + + + THIS_FILE="IntRgbx.c" + + + + + + + THIS_FILE="MapAccelFunc.c" + + + + + + + THIS_FILE="MaskBlit.c" + + + + + + + THIS_FILE="MaskFill.c" + + + + + + + THIS_FILE="ProcessPath.c" + + + + + + + THIS_FILE="ScaledBlit.c" + + + + + + + THIS_FILE="ThreeByteBgr.c" + + + + + + + THIS_FILE="TransformHelper.c" + + + + + + + THIS_FILE="Ushort4444Argb.c" + + + + + + + THIS_FILE="Ushort555Rgb.c" + + + + + + + THIS_FILE="Ushort555Rgbx.c" + + + + + + + THIS_FILE="Ushort565Rgb.c" + + + + + + + THIS_FILE="UshortGray.c" + + + + + + + THIS_FILE="UshortIndexed.c" + + + + + + + + + THIS_FILE="OGLBufImgOps.c" + + + + + + + THIS_FILE="OGLContext.c" + + + + + + + THIS_FILE="OGLFuncs.c" + + + + + + + THIS_FILE="OGLMaskBlit.c" + + + + + + + THIS_FILE="OGLMaskFill.c" + + + + + + + THIS_FILE="OGLPaints.c" + + + + + + + THIS_FILE="OGLRenderQueue.c" + + + + + + + THIS_FILE="OGLRenderer.c" + + + + + + + THIS_FILE="OGLSurfaceData.c" + + + + + + + THIS_FILE="OGLTextRenderer.c" + + + + + + + THIS_FILE="OGLVertexCache.c" + + + + + + + + + THIS_FILE="BufferedRenderPipe.c" + + + + + + + THIS_FILE="Region.c" + + + + + + + THIS_FILE="ShapeSpanIterator.c" + + + + + + + THIS_FILE="SpanClipRenderer.c" + + + + + + + + + THIS_FILE="Flag.c" + + + + + + + THIS_FILE="GarbageCollectorImpl.c" + + + + + + + THIS_FILE="GcInfoBuilder.c" + + + + + + + THIS_FILE="HotSpotDiagnostic.c" + + + + + + + THIS_FILE="HotspotThread.c" + + + + + + + THIS_FILE="MemoryImpl.c" + + + + + + + THIS_FILE="MemoryManagerImpl.c" + + + + + + + THIS_FILE="MemoryPoolImpl.c" + + + + + + + THIS_FILE="ThreadImpl.c" + + + + + + + THIS_FILE="VMManagementImpl.c" + + + + + + + THIS_FILE="management.c" + + + + + + + + + THIS_FILE="MessageUtils.c" + + + + + + + THIS_FILE="NativeSignalHandler.c" + + + + + + + THIS_FILE="Signal.c" + + + + + + + THIS_FILE="VM.c" + + + + + + + THIS_FILE="VMSupport.c" + + + + + + + THIS_FILE="Version.c" + + + + + + + + + + + THIS_FILE="NativeAccessors.c" + + + + + + + THIS_FILE="Reflection.c" + + + + + + + + + + + THIS_FILE="ec2_163.c" + + + + + + + THIS_FILE="ec2_193.c" + + + + + + + THIS_FILE="ec2_233.c" + + + + + + + THIS_FILE="ec2_aff.c" + + + + + + + THIS_FILE="ec2_mont.c" + + + + + + + THIS_FILE="ec_naf.c" + + + + + + + THIS_FILE="ecdecode.c" + + + + + + + THIS_FILE="ecl.c" + + + + + + + THIS_FILE="ecl_curve.c" + + + + + + + THIS_FILE="ecl_gf.c" + + + + + + + THIS_FILE="ecl_mult.c" + + + + + + + THIS_FILE="ecp_192.c" + + + + + + + THIS_FILE="ecp_224.c" + + + + + + + THIS_FILE="ecp_256.c" + + + + + + + THIS_FILE="ecp_384.c" + + + + + + + THIS_FILE="ecp_521.c" + + + + + + + THIS_FILE="ecp_aff.c" + + + + + + + THIS_FILE="ecp_jac.c" + + + + + + + THIS_FILE="ecp_jm.c" + + + + + + + THIS_FILE="ecp_mont.c" + + + + + + + THIS_FILE="mp_gf2m.c" + + + + + + + THIS_FILE="mpi.c" + + + + + + + THIS_FILE="mplogic.c" + + + + + + + THIS_FILE="mpmontg.c" + + + + + + + THIS_FILE="oid.c" + + + + + + + THIS_FILE="secitem.c" + + + + + + + + + THIS_FILE="NativeUtil.c" + + + + + + + THIS_FILE="j2secmod.c" + + + + + + + + + THIS_FILE="p11_crypt.c" + + + + + + + THIS_FILE="p11_digest.c" + + + + + + + THIS_FILE="p11_dual.c" + + + + + + + THIS_FILE="p11_general.c" + + + + + + + THIS_FILE="p11_keymgmt.c" + + + + + + + THIS_FILE="p11_mutex.c" + + + + + + + THIS_FILE="p11_objmgmt.c" + + + + + + + THIS_FILE="p11_sessmgmt.c" + + + + + + + THIS_FILE="p11_sign.c" + + + + + + + THIS_FILE="p11_util.c" + + + + + + + + + + + + + THIS_FILE="utf.c" + + + + + + + + + + + THIS_FILE="linker_md.c" + + + + + + + + + THIS_FILE="ergo_i586.c" + + + + + + + THIS_FILE="java_md_common.c" + + + + + + + THIS_FILE="java_md_solinux.c" + + + + + + + + + + + + + THIS_FILE="FileSystemSupport_md.c" + + + + + + + + + THIS_FILE="UnixOperatingSystem_md.c" + + + + + + + + + THIS_FILE="PLATFORM_API_SolarisOS_Ports.c" + + + + + + + THIS_FILE="PLATFORM_API_SolarisOS_Utils.c" + + + + + + + + + THIS_FILE="Unix.c" + + + + + + + + + THIS_FILE="jni_util_md.c" + + + + + + + + + THIS_FILE="FileDescriptor_md.c" + + + + + + + THIS_FILE="FileInputStream_md.c" + + + + + + + THIS_FILE="FileOutputStream_md.c" + + + + + + + THIS_FILE="RandomAccessFile_md.c" + + + + + + + THIS_FILE="UnixFileSystem_md.c" + + + + + + + THIS_FILE="canonicalize_md.c" + + + + + + + THIS_FILE="io_util_md.c" + + + + + + + + + THIS_FILE="UNIXProcess_md.c" + + + + + + + THIS_FILE="java_props_md.c" + + + + + + + + + THIS_FILE="Inet6AddressImpl.c" + + + + + + + THIS_FILE="InetAddressImplFactory.c" + + + + + + + THIS_FILE="NetworkInterface.c" + + + + + + + THIS_FILE="PlainDatagramSocketImpl.c" + + + + + + + THIS_FILE="PlainSocketImpl.c" + + + + + + + THIS_FILE="SocketInputStream.c" + + + + + + + THIS_FILE="SocketOutputStream.c" + + + + + + + THIS_FILE="net_util_md.c" + + + + + + + + + + + THIS_FILE="TimeZone_md.c" + + + + + + + THIS_FILE="logging.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="CUPSfuncs.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + HEADLESS=true + PACKAGE_PATH="/opt/local" + THIS_FILE="HeadlessToolkit.c" + X11_PATH="/usr/X11R6" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + HEADLESS=true + PACKAGE_PATH="/opt/local" + THIS_FILE="VDrawingArea.c" + X11_PATH="/usr/X11R6" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="X11Color.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_AWTEvent.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_DrawingSurface.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Event.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Font.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_GraphicsEnv.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_InputMethod.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Insets.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="awt_LoadLibrary.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="awt_Mlib.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Plugin.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_Robot.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_UNIXToolkit.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_util.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="fontpath.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="gtk2_interface.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="initIDs.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="jawt.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="list.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="multiVis.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="multi_font.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="robot_common.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="sun_awt_X11_GtkFileDialogPeer.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="swing_GTKEngine.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="swing_GTKStyle.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + + + THIS_FILE="X11TextRenderer.c" + + + + + + + + + THIS_FILE="GLXSurfaceData.c" + + + + + + + + + THIS_FILE="X11PMBlitLoops.c" + + + + + + + THIS_FILE="X11Renderer.c" + + + + + + + THIS_FILE="X11SurfaceData.c" + + + + + + + THIS_FILE="X11TextRenderer_md.c" + + + + + + + THIS_FILE="XRBackendNative.c" + + + + + + + THIS_FILE="XRSurfaceData.c" + + + + + + + + + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="DatagramChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="DatagramDispatcher.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="DevPollArrayWrapper.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="FileChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="FileDispatcherImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="FileKey.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="IOUtil.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="InheritedChannel.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="NativeThread.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="Net.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="PollArrayWrapper.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="ServerSocketChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="SocketChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="SocketDispatcher.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="SolarisEventPort.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="UnixAsynchronousServerSocketChannelImpl.c" + + + + + + + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="UnixAsynchronousSocketChannelImpl.c" + + + + + + + + + THIS_FILE="SctpNet.c" + + + + + + + THIS_FILE="SctpServerChannelImpl.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="SolarisNativeDispatcher.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="SolarisWatchService.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="UnixCopyFile.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="UnixNativeDispatcher.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/makefiles + + + THIS_FILE="genSolarisConstants.c" + + + + + + + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="genUnixConstants.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + + + THIS_FILE="j2secmod_md.c" + + + + + + + + + + + + + + + + + + + THIS_FILE="XWindow.c" + + + + + + + THIS_FILE="XlibWrapper.c" + + + + + + + THIS_FILE="awt_Desktop.c" + + + + + + + THIS_FILE="gnome_interface.c" + + + + + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/image/cvutils + + + __sparcv9 + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + __EXCEPTIONS + __GXX_RTTI + + + + + + + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + VM_LITTLE_ENDIAN + _Crun_inline_placement + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + TIERED + + + + + + + _GNU_SOURCE + + + + + __EXCEPTIONS + __GXX_RTTI + + + + + + + ../../hotspot/agent/src/os/solaris/proc + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ${IDE_ALT_BOOTDIR}/include + ${IDE_ALT_BOOTDIR}/include/solaris + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + SOLARIS_11_B159_OR_LATER + + + + + ../../hotspot/agent/src/os/solaris/proc + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ${IDE_ALT_BOOTDIR}/include + ${IDE_ALT_BOOTDIR}/include/solaris + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + SOLARIS_11_B159_OR_LATER + + + + + + + ${IDE_ALT_BOOTDIR}/include/linux + + + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + VM_LITTLE_ENDIAN + _Crun_inline_placement + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + _REENTRANT + + + + + LINUX + _GNU_SOURCE + _REENTRANT + + + + + + + ../../hotspot/src/os/posix/launcher + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/tools/launcher + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + ARCH="amd64" + FULL_VERSION="version" + GAMMA + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + JDK_MAJOR_VERSION="version" + JDK_MINOR_VERSION="minor" + LAUNCHER_TYPE="gamma" + LINK_INTO_LIBJVM + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + + + + + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + VM_LITTLE_ENDIAN + _Crun_inline_placement + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + + + + + TIERED + + + + + + + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + VM_LITTLE_ENDIAN + _Crun_inline_placement + + + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + VM_LITTLE_ENDIAN + _Crun_inline_placement + + + + + + + LINUX + _GNU_SOURCE + _LP64=1 + _REENTRANT + + + + + + + ../../hotspot/src/os/posix/launcher + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/tools/launcher + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + AMD64 + ARCH="amd64" + FULL_VERSION="version" + GAMMA + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + JDK_MAJOR_VERSION="version" + JDK_MINOR_VERSION="minor" + LAUNCHER_TYPE="gamma" + LINK_INTO_LIBJVM + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + + + AMD64 + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + _Crun_inline_placement + + + + + + + ../../hotspot/src/share/vm/adlc + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + ASSERT + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + LINUX + PRODUCT + VM_LITTLE_ENDIAN + _GNU_SOURCE + _LP64=1 + _REENTRANT + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + + + DTRACE_ENABLED + HAVE_DTRACE_H + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + INCLUDE_TRACE + PRODUCT + VM_LITTLE_ENDIAN + + + + + + + THIS_FILE="add_gnu_debuglink.c" + + + + + ARCH="amd64" + BREAKPTS + CC_NOEX + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="Agent.cpp" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/makefiles + + + + + + + THIS_FILE="fix_empty_sec_hdr_flags.c" + + + + + + + THIS_FILE="ArrayReferenceImpl.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/export + ../../jdk/src/share/back/export + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/back + ../../jdk/src/solaris/back + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_jdwp_headers + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + JDWP_LOGGING + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + ARCH="amd64" + BREAKPTS + LIBARCHNAME="amd64" + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="java.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="agent_util.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../jdk/src/share/demo/jvmti/waiters + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/demo/jvmti/heapTracker + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/demo/jvmti/compiledMethodLoad + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="compiledMethodLoad.c" + + + + + + + ../../jdk/src/share/demo/jvmti/gctest + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="gctest.c" + + + + + + + ../../jdk/src/share/demo/jvmti/heapTracker + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="heapTracker.c" + + + + + + + ../../jdk/src/share/demo/jvmti/heapViewer + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="heapViewer.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="debug_malloc.c" + + + + + + + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/solaris/demo/jvmti/hprof + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + THIS_FILE="java_crw_demo.c" + + + + + + + ../../jdk/src/share/demo/jvmti/minst + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="minst.c" + + + + + + + ../../jdk/src/share/demo/jvmti/mtrace + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="mtrace.c" + + + + + + + ../../jdk/src/share/demo/jvmti/versionCheck + ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/makefiles + + + THIS_FILE="versionCheck.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/instrument + ../../jdk/src/solaris/instrument + ../../jdk/src/share/bin + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + NO_JPLIS_LOGGING + RELEASE="" + SOLARIS + THIS_FILE="EncodingSupport.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + THIS_FILE="DirectAudioDevice.c" + + + + + THIS_FILE="bands.cpp" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/com/sun/media/sound + ../../jdk/src/solaris/native/com/sun/media/sound + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + EXTRA_SOUND_JNI_LIBS="" + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + USE_DAUDIO=TRUE + USE_PORTS=TRUE + X_ARCH=X_AMD64 + X_PLATFORM=X_SOLARIS + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + FULL + PRODUCT + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="check_code.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="FileInputStream.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="e_acos.c" + + + + + + + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Finalizer.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Array.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="DatagramPacket.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="Bits.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="AccessController.c" + + + + + + + THIS_FILE="AtomicLong.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + THIS_FILE="compress.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + WITH_X11 + + + + + + + THIS_FILE="debug_assert.c" + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="AlternateSubstSubtables.cpp" + + + + + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="dgif_lib.c" + WITH_X11 + + + + + + + THIS_FILE="img_colors.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="gifdecoder.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + THIS_FILE="imageioJPEG.c" + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="png.c" + WITH_X11 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + THIS_FILE="awt_ImagingLib.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="java_awt_SplashScreen.c" + WITH_X11 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="rect.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="AccelGlyphCache.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + HEADLESS + LE_STANDALONE + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="LCMS.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="AlphaMacros.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + FUNCPROTO=15 + INTERNAL_BUILD + PACKAGE_PATH="/opt/local" + THIS_FILE="OGLBlitLoops.c" + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/share/native/sun/awt + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/gif + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/share/native/sun/awt/medialib + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/makefiles + + + INTERNAL_BUILD + THIS_FILE="BufferedMaskBlit.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="ClassLoadingImpl.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + BREAKPTS + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="GC.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/makefiles + + + THIS_FILE="genSocketOptionRegistry.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + BREAKPTS + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="ConstantPool.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="ec.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + ../../jdk/src/share/native/sun/security/ec + ../../jdk/src/share/native/sun/security/ec/impl + ../../jdk/makefiles + + + THIS_FILE="ECC_JNI.cpp" + + + + + + + ../../jdk/src/share/native/sun/security/ec + ../../jdk/src/share/native/sun/security/ec/impl + ../../jdk/makefiles + + + MP_API_COMPATIBLE + NSS_ECC_MORE_THAN_SUITE_B + + + + + + + ../../jdk/src/share/native/sun/security/jgss/wrapper + ../../jdk/src/solaris/native/sun/security/jgss/wrapper + ../../jdk/makefiles + + + THIS_FILE="GSSLibStub.c" + + + + + + + ../../jdk/src/share/native/sun/security/pkcs11 + ../../jdk/src/solaris/native/sun/security/pkcs11 + ../../jdk/src/share/native/sun/security/pkcs11/wrapper + ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper + ../../jdk/makefiles + + + THIS_FILE="p11_convert.c" + + + + + + + ../../jdk/src/share/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE + ../../jdk/makefiles + + + THIS_FILE="pcsc.c" + __sun_jdk + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/tracing/dtrace + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="JVM.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="npt.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/socket + ../../jdk/src/solaris/transport/socket + ../../jdk/src/share/back/export + ../../jdk/src/share/back + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="socketTransport.c" + TRACING + TRIMMED + USE_MMAP + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + THIS_FILE="exec_md.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/export + ../../jdk/src/share/back/export + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/back + ../../jdk/src/solaris/back + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_jdwp_headers + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + JDWP_LOGGING + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/bin + ../../jdk/src/solaris/bin + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + LIBARCHNAME="amd64" + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="ergo.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="Poller.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/democlasses/jni/Poller + ../../jdk/makefiles + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/demo/jvmti/hprof + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/makefiles + + + THIS_FILE="hprof_md.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/instrument + ../../jdk/src/solaris/instrument + ../../jdk/src/share/bin + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + NO_JPLIS_LOGGING + RELEASE="" + SOLARIS + THIS_FILE="EncodingSupport_md.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + THIS_FILE="SolarisOperatingSystem.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/com/sun/media/sound + ../../jdk/src/solaris/native/com/sun/media/sound + ../../jdk/makefiles + + + EXTRA_SOUND_JNI_LIBS="" + THIS_FILE="PLATFORM_API_SolarisOS_PCM.c" + USE_DAUDIO=TRUE + USE_PORTS=TRUE + X_ARCH=X_AMD64 + X_PLATFORM=X_SOLARIS + + + + + + + ../../jdk/makefiles + + + THIS_FILE="Solaris.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + BREAKPTS + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="jdk_util_md.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="Console_md.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="ProcessEnvironment_md.c" + + + + + + + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + THIS_FILE="Inet4AddressImpl.c" + + + + + + + ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/share/native/java/io + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + THIS_FILE="MappedByteBuffer.c" + + + + + + + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCHPROPNAME="amd64" + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + THIS_FILE="FileSystemPreferences.c" + + + + + + + THIS_FILE="splashscreen_sys.c" + + + + + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/src/share/native/sun/awt/image/jpeg + ../../jdk/src/share/native/sun/awt/libpng + ../../jdk/src/share/native/sun/awt/splashscreen + ../../jdk/src/share/native/sun/awt/giflib + ../../jdk/src/solaris/native/sun/awt/splashscreen + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + PNG_NO_MMX_CODE + SPLASHSCREEN + WITH_X11 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + /usr/include/freetype2 + ../../jdk/src/share/native/sun/font + ../../jdk/src/share/native/sun/font/layout + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + HEADLESS + LE_STANDALONE + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="X11FontScaler.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + FUNCPROTO=15 + INTERNAL_BUILD + MACRO_MEMSYS_OPS + NDEBUG + PACKAGE_PATH="/opt/local" + RELEASE="" + SOLARIS + THIS_FILE="GLXGraphicsConfig.c" + TRACING + TRIMMED + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + THIS_FILE="X11FontScaler_md.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/management + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="FileSystemImpl.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/java/net + ../../jdk/src/solaris/native/sun/net/dns + ../../jdk/src/solaris/native/sun/net/spi + ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="ResolverConfigurationImpl.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + THIS_FILE="SdpSupport.c" + + + + + + + THIS_FILE="DefaultProxySelector.c" + + + + + + + THIS_FILE="SctpChannelImpl.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/nio/ch + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/src/share/native/sun/nio/ch/sctp + ../../jdk/src/share/native/java/net + ../../jdk/src/solaris/native/sun/nio/ch + ../../jdk/src/solaris/native/java/net + ../../jdk/makefiles + + + + + + + THIS_FILE="GnomeFileTypeDetector.c" + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="NativeFunc.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../jdk/src/share/native/sun/security/jgss/wrapper + ../../jdk/src/solaris/native/sun/security/jgss/wrapper + ../../jdk/makefiles + + + + + + + ../../jdk/src/share/native/sun/security/pkcs11 + ../../jdk/src/solaris/native/sun/security/pkcs11 + ../../jdk/src/share/native/sun/security/pkcs11/wrapper + ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper + ../../jdk/makefiles + + + THIS_FILE="p11_md.c" + + + + + + + ../../jdk/src/share/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio + ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE + ../../jdk/makefiles + + + THIS_FILE="pcsc_md.c" + __sun_jdk + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="SolarisVirtualMachine.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/tracing/dtrace + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="jvm_symbols_md.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/solaris/native/java/lang + ../../jdk/src/share/native/java/lang + ../../jdk/src/share/native/java/lang/ref + ../../jdk/src/share/native/java/lang/reflect + ../../jdk/src/share/native/java/io + ../../jdk/src/solaris/native/java/io + ../../jdk/src/share/native/java/nio + ../../jdk/src/share/native/java/security + ../../jdk/src/share/native/sun/misc + ../../jdk/src/share/native/sun/reflect + ../../jdk/src/share/native/java/util + ../../jdk/src/share/native/java/util/concurrent/atomic + ../../jdk/src/solaris/native/java/util + ../../jdk/src/solaris/native/sun/util/locale/provider + ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/makefiles + + + ARCH="amd64" + ARCHPROPNAME="amd64" + BREAKPTS + JDK_BUILD_NUMBER="nn" + JDK_MAJOR_VERSION="version" + JDK_MICRO_VERSION="version" + JDK_MINOR_VERSION="minor" + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="HostLocaleProviderAdapter_md.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/native/sun/awt/debug + ../../jdk/src/share/native/sun/awt/utility + ../../jdk/src/share/native/sun/font + ../../jdk/src/solaris/native/sun/font + ../../jdk/src/share/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/awt + ../../jdk/src/solaris/native/sun/java2d/opengl + ../../jdk/src/solaris/native/sun/java2d/x11 + ../../jdk/src/solaris/native/sun/xawt + ../../jdk/src/share/native/sun/java2d + ../../jdk/src/solaris/native/sun/java2d + ../../jdk/src/share/native/sun/java2d/loops + ../../jdk/src/share/native/sun/java2d/pipe + ../../jdk/src/share/native/sun/awt/image + ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/solaris/native/sun/jdga + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + FUNCPROTO=15 + INTERNAL_BUILD + MACRO_MEMSYS_OPS + NDEBUG + PACKAGE_PATH="/opt/local" + RELEASE="" + SOLARIS + THIS_FILE="XToolkit.c" + TRACING + TRIMMED + X11_PATH="/usr/X11R6" + XAWT + XAWT_HACK + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/npt + ../../jdk/src/solaris/npt + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="utf_md.c" + TRACING + TRIMMED + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + + ../../build/solaris-x86_64-normal-server-release/jdk/include + ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris + ../../jdk/src/share/javavm/export + ../../jdk/src/solaris/javavm/export + ../../jdk/src/share/native/common + ../../jdk/src/solaris/native/common + ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/share/transport/socket + ../../jdk/src/solaris/transport/socket + ../../jdk/src/share/back/export + ../../jdk/src/share/back + ../../jdk/makefiles + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + NDEBUG + RELEASE="" + SOLARIS + THIS_FILE="socket_md.c" + TRACING + TRIMMED + USE_MMAP + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + + diff --git a/common/nb_native/nbproject/project.xml b/common/nb_native/nbproject/project.xml new file mode 100644 index 00000000000..0f248c751ed --- /dev/null +++ b/common/nb_native/nbproject/project.xml @@ -0,0 +1,31 @@ + + + org.netbeans.modules.cnd.makeproject + + + OpenJDK (Native) + c,m + cc,cpp + ad,h,hpp,in_out + UTF-8 + + + ../.. + + + + Mac_64 + 0 + + + Linux_64 + 0 + + + Solaris_64 + 0 + + + + + From 03a7499322544d8c3e48cd3b0c23d864e545bee2 Mon Sep 17 00:00:00 2001 From: Sean Mullan Date: Thu, 25 Apr 2013 11:18:29 -0400 Subject: [PATCH 35/50] 8011313: OCSP timeout set to wrong value if com.sun.security.ocsp.timeout not defined Reviewed-by: vinnie --- .../classes/sun/security/provider/certpath/OCSP.java | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/jdk/src/share/classes/sun/security/provider/certpath/OCSP.java b/jdk/src/share/classes/sun/security/provider/certpath/OCSP.java index 03c910b8897..ca82ef598a0 100644 --- a/jdk/src/share/classes/sun/security/provider/certpath/OCSP.java +++ b/jdk/src/share/classes/sun/security/provider/certpath/OCSP.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -85,10 +85,9 @@ public final class OCSP { * value is negative, set the timeout length to the default. */ private static int initializeTimeout() { - int tmp = java.security.AccessController.doPrivileged( - new GetIntegerAction("com.sun.security.ocsp.timeout", - DEFAULT_CONNECT_TIMEOUT)); - if (tmp < 0) { + Integer tmp = java.security.AccessController.doPrivileged( + new GetIntegerAction("com.sun.security.ocsp.timeout")); + if (tmp == null || tmp < 0) { return DEFAULT_CONNECT_TIMEOUT; } // Convert to milliseconds, as the system property will be From 460b288196fc9220f8b98f8187a8b6e5e3a4a81d Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:23:51 -0700 Subject: [PATCH 36/50] Added tag jdk8-b87 for changeset faa51a420c63 --- .hgtags-top-repo | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags-top-repo b/.hgtags-top-repo index ab78580039e..f4e2d650e69 100644 --- a/.hgtags-top-repo +++ b/.hgtags-top-repo @@ -208,3 +208,4 @@ fd1a5574cf68af24bfd52decc37ac6361afb278a jdk8-b78 01f631f89fa392b4e484d0812c40ea8f9d2353aa jdk8-b84 7fc358f5943676b82f1dccd3152b1ac07d92e38b jdk8-b85 df9b5240f0a76c91cfe1a5b39da4d08df56e05be jdk8-b86 +b9415faa7066a4d3b16d466556d5428446918d95 jdk8-b87 From 45a0a50f2d8861539da062d4378b3199c8b03d3f Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:23:53 -0700 Subject: [PATCH 37/50] Added tag jdk8-b87 for changeset c11b147126a1 --- corba/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/corba/.hgtags b/corba/.hgtags index 3425d15c044..152c37569a8 100644 --- a/corba/.hgtags +++ b/corba/.hgtags @@ -208,3 +208,4 @@ a45bb25a67c7517b45f00c9682e317f46fecbba9 jdk8-b83 928f8b888deb785cbd7bbd5f951cd6880f11f14e jdk8-b84 9583a6431596bac1959d2d8828f5ea217843dd12 jdk8-b85 44a8ce4a759f2668ff434661a93ff462ea472478 jdk8-b86 +f1709874d55a06bc3d5dfa02dbcdfbc59f4cba34 jdk8-b87 From 5863dae579cbdef55f7917b34b9253b36baf4897 Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:24:00 -0700 Subject: [PATCH 38/50] Added tag jdk8-b87 for changeset b6607ce9fa8d --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index 6a4db95d041..87b9de77c9f 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -334,3 +334,4 @@ a947f40fb536e5b9e0aa210cf26abb430f80887a hs25-b26 09b0d3e9ba6cdf7da07d4010d2d1df14596f6864 hs25-b27 6d88a566d369f6a1f86912cad7d0912686b2fda1 hs25-b28 86db4847f195c0ecceea646431f1ff22d56282e8 jdk8-b86 +d4c2667846607042370760e23f64c3ab9350e60d jdk8-b87 From 6a018e8d704f712b05cccae7e30b3acedd2f55f2 Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:24:11 -0700 Subject: [PATCH 39/50] Added tag jdk8-b87 for changeset ed19c1288d5b --- jaxp/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jaxp/.hgtags b/jaxp/.hgtags index 9ed1efe7e2f..51afd2eef9a 100644 --- a/jaxp/.hgtags +++ b/jaxp/.hgtags @@ -208,3 +208,4 @@ a46d69a1a8ec9652a48114823535372e1c980799 jdk8-b83 f5f40094ffcc1230e2a5f76ea4c968645369be6c jdk8-b84 41b50e2c5ea3f4aa1af729e1deb1678cb3e1ef9c jdk8-b85 ca71ec37b2efc9c3f0971ebabb3a6eb1213d76de jdk8-b86 +eddbc8ad2435a89f64729512337c9f2669e4dd85 jdk8-b87 From b5ab96c56a0802aec21f463a68dad2afed4bcbdf Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:24:14 -0700 Subject: [PATCH 40/50] Added tag jdk8-b87 for changeset 76e8f6a063b4 --- jaxws/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jaxws/.hgtags b/jaxws/.hgtags index a5716c58186..c129b5def61 100644 --- a/jaxws/.hgtags +++ b/jaxws/.hgtags @@ -208,3 +208,4 @@ a1dcc0d83da1e07f3ada60ef110dd105d95d3554 jdk8-b83 5773e3fc83803f392234ba54c3a437ba176f1ead jdk8-b84 8c0b6bccfe474576d6b30d1582c4329029330150 jdk8-b85 a5e7c2f093c9996ab3419db1565094a07b059e9c jdk8-b86 +72e03566f0a61282cc48ebc869803b256cccd66c jdk8-b87 From a664982c79afd9687aa5b598e889c15127e0fa78 Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:24:24 -0700 Subject: [PATCH 41/50] Added tag jdk8-b87 for changeset 2871326c0383 --- jdk/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jdk/.hgtags b/jdk/.hgtags index cc1dd780285..1c4e24bef66 100644 --- a/jdk/.hgtags +++ b/jdk/.hgtags @@ -208,3 +208,4 @@ ac519af51769e92c51b597a730974e8607357709 jdk8-b83 7b4721e4edb4e1c65e9c839a70d7cc67f81c7632 jdk8-b84 296676d534c52888c36e305a2bf7f345c4ca70f8 jdk8-b85 7989cd0cc3a9149864589438ee2c949015d8aa9a jdk8-b86 +d5228e624826a10ccc5b05f30ad8d839b58fe48d jdk8-b87 From 080fcf080e7d2ae535b772b37a5ba09f36252e1d Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:24:40 -0700 Subject: [PATCH 42/50] Added tag jdk8-b87 for changeset c4b5ab25b20c --- langtools/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/langtools/.hgtags b/langtools/.hgtags index c2d0fcb8c8a..03ad6e96b7b 100644 --- a/langtools/.hgtags +++ b/langtools/.hgtags @@ -208,3 +208,4 @@ ed69d087fdfd394491657a28ba9bc58e7849b7db jdk8-b81 cfb65ca92082b2412aed66c8422c2466bde544ef jdk8-b84 4a48f31735349782ad13980267358c97076adc66 jdk8-b85 6ab578e141dfd17c4dc03869bb204aafa490c9f4 jdk8-b86 +1329f9c38d93c8caf339d7687df8371d06fe9e56 jdk8-b87 From 1418f59c79e7812d38f0435021e42376958fe44f Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 25 Apr 2013 09:24:44 -0700 Subject: [PATCH 43/50] Added tag jdk8-b87 for changeset 5884314a2095 --- nashorn/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/nashorn/.hgtags b/nashorn/.hgtags index 6f149c63938..213a1bd2ce8 100644 --- a/nashorn/.hgtags +++ b/nashorn/.hgtags @@ -196,3 +196,4 @@ b8a1b238c77c7c00024daaa2cb7d10838e017b5f jdk8-b69 999cc1bf55203f51b2985feae6378932667ecff2 jdk8-b84 e0378f0a50dafdcfb7b04f6401d320f89884baa1 jdk8-b85 002ad9d6735f36d1204e133324c73058c8abb1b0 jdk8-b86 +774aeaa89bc15f4365e3c2fc36f6a3a0da70ba28 jdk8-b87 From a618ff7cf99fbc932ca148458ea3bc8bd70c2e1c Mon Sep 17 00:00:00 2001 From: Sean Mullan Date: Thu, 25 Apr 2013 15:48:11 -0400 Subject: [PATCH 44/50] 8013228: Create new system properties to control allowable OCSP clock skew and CRL connection timeout Reviewed-by: vinnie --- .../provider/certpath/CertPathHelper.java | 2 +- .../certpath/DistributionPointFetcher.java | 17 +++++----- .../provider/certpath/OCSPResponse.java | 31 ++++++++++++++++--- .../provider/certpath/URICertStore.java | 31 ++++++++++++++++++- 4 files changed, 67 insertions(+), 14 deletions(-) diff --git a/jdk/src/share/classes/sun/security/provider/certpath/CertPathHelper.java b/jdk/src/share/classes/sun/security/provider/certpath/CertPathHelper.java index 517e91167ee..bd3a34281ba 100644 --- a/jdk/src/share/classes/sun/security/provider/certpath/CertPathHelper.java +++ b/jdk/src/share/classes/sun/security/provider/certpath/CertPathHelper.java @@ -64,7 +64,7 @@ public abstract class CertPathHelper { instance.implSetPathToNames(sel, names); } - static void setDateAndTime(X509CRLSelector sel, Date date, long skew) { + public static void setDateAndTime(X509CRLSelector sel, Date date, long skew) { instance.implSetDateAndTime(sel, date, skew); } } diff --git a/jdk/src/share/classes/sun/security/provider/certpath/DistributionPointFetcher.java b/jdk/src/share/classes/sun/security/provider/certpath/DistributionPointFetcher.java index ab784524546..bee12e43bee 100644 --- a/jdk/src/share/classes/sun/security/provider/certpath/DistributionPointFetcher.java +++ b/jdk/src/share/classes/sun/security/provider/certpath/DistributionPointFetcher.java @@ -50,7 +50,7 @@ import sun.security.x509.*; * @author Sean Mullan * @since 1.4.2 */ -class DistributionPointFetcher { +public class DistributionPointFetcher { private static final Debug debug = Debug.getInstance("certpath"); @@ -66,13 +66,14 @@ class DistributionPointFetcher { * Return the X509CRLs matching this selector. The selector must be * an X509CRLSelector with certificateChecking set. */ - static Collection getCRLs(X509CRLSelector selector, - boolean signFlag, PublicKey prevKey, - String provider, - List certStores, - boolean[] reasonsMask, - Set trustAnchors, - Date validity) + public static Collection getCRLs(X509CRLSelector selector, + boolean signFlag, + PublicKey prevKey, + String provider, + List certStores, + boolean[] reasonsMask, + Set trustAnchors, + Date validity) throws CertStoreException { X509Certificate cert = selector.getCertificateChecking(); diff --git a/jdk/src/share/classes/sun/security/provider/certpath/OCSPResponse.java b/jdk/src/share/classes/sun/security/provider/certpath/OCSPResponse.java index 78802bf79bd..2cd437dc263 100644 --- a/jdk/src/share/classes/sun/security/provider/certpath/OCSPResponse.java +++ b/jdk/src/share/classes/sun/security/provider/certpath/OCSPResponse.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -43,6 +43,7 @@ import java.util.Map; import javax.security.auth.x500.X500Principal; import sun.misc.HexDumpEncoder; +import sun.security.action.GetIntegerAction; import sun.security.x509.*; import sun.security.util.*; @@ -144,9 +145,31 @@ public final class OCSPResponse { // Object identifier for the OCSPSigning key purpose private static final String KP_OCSP_SIGNING_OID = "1.3.6.1.5.5.7.3.9"; - // Maximum clock skew in milliseconds (15 minutes) allowed when checking - // validity of OCSP responses - private static final long MAX_CLOCK_SKEW = 900000; + // Default maximum clock skew in milliseconds (15 minutes) + // allowed when checking validity of OCSP responses + private static final int DEFAULT_MAX_CLOCK_SKEW = 900000; + + /** + * Integer value indicating the maximum allowable clock skew, in seconds, + * to be used for the OCSP check. + */ + private static final int MAX_CLOCK_SKEW = initializeClockSkew(); + + /** + * Initialize the maximum allowable clock skew by getting the OCSP + * clock skew system property. If the property has not been set, or if its + * value is negative, set the skew to the default. + */ + private static int initializeClockSkew() { + Integer tmp = java.security.AccessController.doPrivileged( + new GetIntegerAction("com.sun.security.ocsp.clockSkew")); + if (tmp == null || tmp < 0) { + return DEFAULT_MAX_CLOCK_SKEW; + } + // Convert to milliseconds, as the system property will be + // specified in seconds + return tmp * 1000; + } // an array of all of the CRLReasons (used in SingleResponse) private static CRLReason[] values = CRLReason.values(); diff --git a/jdk/src/share/classes/sun/security/provider/certpath/URICertStore.java b/jdk/src/share/classes/sun/security/provider/certpath/URICertStore.java index 33694ab51fb..a5ec5d36e8d 100644 --- a/jdk/src/share/classes/sun/security/provider/certpath/URICertStore.java +++ b/jdk/src/share/classes/sun/security/provider/certpath/URICertStore.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -51,6 +51,7 @@ import java.util.Collection; import java.util.Collections; import java.util.List; import java.util.Locale; +import sun.security.action.GetIntegerAction; import sun.security.x509.AccessDescription; import sun.security.x509.GeneralNameInterface; import sun.security.x509.URIName; @@ -121,6 +122,33 @@ class URICertStore extends CertStoreSpi { private CertStore ldapCertStore; private String ldapPath; + // Default maximum connect timeout in milliseconds (15 seconds) + // allowed when downloading CRLs + private static final int DEFAULT_CRL_CONNECT_TIMEOUT = 15000; + + /** + * Integer value indicating the connect timeout, in seconds, to be + * used for the CRL download. A timeout of zero is interpreted as + * an infinite timeout. + */ + private static final int CRL_CONNECT_TIMEOUT = initializeTimeout(); + + /** + * Initialize the timeout length by getting the CRL timeout + * system property. If the property has not been set, or if its + * value is negative, set the timeout length to the default. + */ + private static int initializeTimeout() { + Integer tmp = java.security.AccessController.doPrivileged( + new GetIntegerAction("com.sun.security.crl.timeout")); + if (tmp == null || tmp < 0) { + return DEFAULT_CRL_CONNECT_TIMEOUT; + } + // Convert to milliseconds, as the system property will be + // specified in seconds + return tmp * 1000; + } + /** * Creates a URICertStore. * @@ -364,6 +392,7 @@ class URICertStore extends CertStoreSpi { connection.setIfModifiedSince(lastModified); } long oldLastModified = lastModified; + connection.setConnectTimeout(CRL_CONNECT_TIMEOUT); try (InputStream in = connection.getInputStream()) { lastModified = connection.getLastModified(); if (oldLastModified != 0) { From dcb3f25f4591478f570ab75b7a9a0ac05187ac68 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Fri, 26 Apr 2013 00:29:12 -0700 Subject: [PATCH 45/50] Added tag hs25-b30 for changeset 18be17ecfd6c --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index 07ab07f14f1..f433c6708ea 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -336,3 +336,4 @@ a947f40fb536e5b9e0aa210cf26abb430f80887a hs25-b26 86db4847f195c0ecceea646431f1ff22d56282e8 jdk8-b86 d4c2667846607042370760e23f64c3ab9350e60d jdk8-b87 01d5f04e64dc2d64625b2db2056f5ed4de918a45 hs25-b29 +c4af77d2045476c56fbf3f914b336bb1b7cd18af hs25-b30 From c3f688a4e21ab484176a980e2b51594649a8c53c Mon Sep 17 00:00:00 2001 From: Omair Majid Date: Mon, 29 Apr 2013 12:34:53 -0400 Subject: [PATCH 46/50] 8013480: fix zero build on arm Reviewed-by: erikj --- jdk/makefiles/GensrcX11Wrappers.gmk | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/jdk/makefiles/GensrcX11Wrappers.gmk b/jdk/makefiles/GensrcX11Wrappers.gmk index 6a183d783ec..934ddbed32b 100644 --- a/jdk/makefiles/GensrcX11Wrappers.gmk +++ b/jdk/makefiles/GensrcX11Wrappers.gmk @@ -86,10 +86,15 @@ ifneq ($(COMPILE_TYPE),cross) $(MKDIR) -p $(@D) $(TOOL_WRAPPERGENERATOR) $(@D) $(GENSRC_SIZER_DIR)/xlibtypes.txt "sizer" $* + # use -m32/-m64 only if the compiler supports it + ifeq ($(COMPILER_SUPPORTS_TARGET_BITS_FLAG),true) + MEMORY_MODEL_FLAG="-m$*" + endif + # Compile the C code into an executable. $(GENSRC_X11WRAPPERS_TMP)/sizer.%.exe : $(GENSRC_X11WRAPPERS_TMP)/sizer.%.c $(MKDIR) -p $(@D) - (cd $(@D) && $(CC) -m$* -o $@ $< \ + (cd $(@D) && $(CC) $(MEMORY_MODEL_FLAG) -o $@ $< \ $(X_CFLAGS) \ $(X_LIBS) \ -I$(JDK_OUTPUTDIR)/include \ From e44f5ce0ae45157b55211a394ba5b87215cc0f26 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Thu, 2 May 2013 15:46:38 +0200 Subject: [PATCH 47/50] 8013786: JDK-8013480 broke configure on solaris Reviewed-by: tbell --- common/autoconf/configure.ac | 1 + common/autoconf/generated-configure.sh | 2132 ++++++++---------------- common/autoconf/platform.m4 | 59 - common/autoconf/toolchain.m4 | 58 + 4 files changed, 715 insertions(+), 1535 deletions(-) diff --git a/common/autoconf/configure.ac b/common/autoconf/configure.ac index 5e632c4ecb8..fcaf12fc422 100644 --- a/common/autoconf/configure.ac +++ b/common/autoconf/configure.ac @@ -166,6 +166,7 @@ PLATFORM_SETUP_OPENJDK_TARGET_ENDIANNESS TOOLCHAIN_SETUP_COMPILER_FLAGS_FOR_LIBS TOOLCHAIN_SETUP_COMPILER_FLAGS_FOR_OPTIMIZATION TOOLCHAIN_SETUP_COMPILER_FLAGS_FOR_JDK +TOOLCHAIN_SETUP_COMPILER_FLAGS_MISC # Setup debug symbols (need objcopy from the toolchain for that) JDKOPT_SETUP_DEBUG_SYMBOLS diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index eee1f4c4e54..a7c9e7a8f77 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.68 for OpenJDK jdk8. +# Generated by GNU Autoconf 2.67 for OpenJDK jdk8. # # Report bugs to . # @@ -91,7 +91,6 @@ fi IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. -as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR @@ -217,18 +216,11 @@ IFS=$as_save_IFS # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. - # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV export CONFIG_SHELL - case $- in # (((( - *v*x* | *x*v* ) as_opts=-vx ;; - *v* ) as_opts=-v ;; - *x* ) as_opts=-x ;; - * ) as_opts= ;; - esac - exec "$CONFIG_SHELL" $as_opts "$as_myself" ${1+"$@"} + exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"} fi if test x$as_have_required = xno; then : @@ -647,6 +639,8 @@ CXXFLAGS_DEBUG_SYMBOLS CFLAGS_DEBUG_SYMBOLS ZIP_DEBUGINFO_FILES ENABLE_DEBUG_SYMBOLS +COMPILER_SUPPORTS_TARGET_BITS_FLAG +ZERO_ARCHFLAG LDFLAGS_CXX_JDK LDFLAGS_JDKEXE_SUFFIX LDFLAGS_JDKLIB_SUFFIX @@ -687,7 +681,6 @@ LIBRARY_PREFIX STATIC_LIBRARY SHARED_LIBRARY OBJ_SUFFIX -COMPILER_SUPPORTS_TARGET_BITS_FLAG LIPO ac_ct_OBJDUMP OBJDUMP @@ -720,10 +713,20 @@ LD ac_ct_OBJC OBJCFLAGS OBJC +ac_ct_CXX +CXXFLAGS +CXX ac_ct_PROPER_COMPILER_CXX PROPER_COMPILER_CXX POTENTIAL_CXX TOOLS_DIR_CXX +OBJEXT +EXEEXT +ac_ct_CC +CPPFLAGS +LDFLAGS +CFLAGS +CC ac_ct_PROPER_COMPILER_CC PROPER_COMPILER_CC POTENTIAL_CC @@ -834,17 +837,6 @@ SYS_ROOT PATH_SEP SRC_ROOT ZERO_ARCHDEF -ZERO_ARCHFLAG -ac_ct_CXX -CXXFLAGS -CXX -OBJEXT -EXEEXT -ac_ct_CC -CPPFLAGS -LDFLAGS -CFLAGS -CC DEFINE_CROSS_COMPILE_ARCH LP64 OPENJDK_TARGET_OS_API_DIR @@ -1041,6 +1033,7 @@ with_ccache_dir ac_precious_vars='build_alias host_alias target_alias +PKG_CONFIG CC CFLAGS LDFLAGS @@ -1049,7 +1042,6 @@ CPPFLAGS CXX CXXFLAGS CCC -PKG_CONFIG OBJC OBJCFLAGS CPP @@ -1465,7 +1457,7 @@ Try \`$0 --help' for more information" $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 - : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" + : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} ;; esac @@ -1809,6 +1801,7 @@ Optional Packages: --with-ccache-dir where to store ccache files [~/.ccache] Some influential environment variables: + PKG_CONFIG path to pkg-config utility CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L if you have libraries in a @@ -1818,7 +1811,6 @@ Some influential environment variables: you have headers in a nonstandard directory CXX C++ compiler command CXXFLAGS C++ compiler flags - PKG_CONFIG path to pkg-config utility OBJC Objective C compiler command OBJCFLAGS Objective C compiler flags CPP C preprocessor @@ -1902,7 +1894,7 @@ test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF OpenJDK configure jdk8 -generated by GNU Autoconf 2.68 +generated by GNU Autoconf 2.67 Copyright (C) 2010 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation @@ -1948,7 +1940,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_c_try_compile @@ -1986,7 +1978,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_cxx_try_compile @@ -2024,7 +2016,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_objc_try_compile @@ -2061,7 +2053,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_c_try_cpp @@ -2098,7 +2090,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_cxx_try_cpp @@ -2111,10 +2103,10 @@ fi ac_fn_cxx_check_header_mongrel () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - if eval \${$3+:} false; then : + if eval "test \"\${$3+set}\"" = set; then : { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval \${$3+:} false; then : +if eval "test \"\${$3+set}\"" = set; then : $as_echo_n "(cached) " >&6 fi eval ac_res=\$$3 @@ -2181,7 +2173,7 @@ $as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval \${$3+:} false; then : +if eval "test \"\${$3+set}\"" = set; then : $as_echo_n "(cached) " >&6 else eval "$3=\$ac_header_compiler" @@ -2190,7 +2182,7 @@ eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} } # ac_fn_cxx_check_header_mongrel @@ -2231,7 +2223,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_cxx_try_run @@ -2245,7 +2237,7 @@ ac_fn_cxx_check_header_compile () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval \${$3+:} false; then : +if eval "test \"\${$3+set}\"" = set; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2263,7 +2255,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} } # ac_fn_cxx_check_header_compile @@ -2440,7 +2432,7 @@ rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ rm -f conftest.val fi - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_cxx_compute_int @@ -2486,7 +2478,7 @@ fi # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} as_fn_set_status $ac_retval } # ac_fn_cxx_try_link @@ -2499,7 +2491,7 @@ ac_fn_cxx_check_func () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval \${$3+:} false; then : +if eval "test \"\${$3+set}\"" = set; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2554,7 +2546,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} } # ac_fn_cxx_check_func @@ -2567,7 +2559,7 @@ ac_fn_c_check_header_compile () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval \${$3+:} false; then : +if eval "test \"\${$3+set}\"" = set; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2585,7 +2577,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} } # ac_fn_c_check_header_compile cat >config.log <<_ACEOF @@ -2593,7 +2585,7 @@ This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by OpenJDK $as_me jdk8, which was -generated by GNU Autoconf 2.68. Invocation command line was +generated by GNU Autoconf 2.67. Invocation command line was $ $0 $@ @@ -2851,7 +2843,7 @@ $as_echo "$as_me: loading site script $ac_site_file" >&6;} || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file -See \`config.log' for more details" "$LINENO" 5; } +See \`config.log' for more details" "$LINENO" 5 ; } fi done @@ -3636,16 +3628,6 @@ fi -# PLATFORM_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE], -# [RUN-IF-FALSE]) -# ------------------------------------------------------------ -# Check that the c and c++ compilers support an argument - - -# Check that the compiler supports -mX flags -# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does - - # Support macro for PLATFORM_SETUP_OPENJDK_TARGET_BITS. # Add -mX to various FLAGS variables. @@ -3733,6 +3715,15 @@ fi + +# TOOLCHAIN_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE], +# [RUN-IF-FALSE]) +# ------------------------------------------------------------ +# Check that the c and c++ compilers support an argument + + + + # # Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. @@ -3783,7 +3774,7 @@ fi #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1366642537 +DATE_WHEN_GENERATED=1367502345 ############################################################################### # @@ -3821,7 +3812,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_BASENAME+:} false; then : +if test "${ac_cv_path_BASENAME+set}" = set; then : $as_echo_n "(cached) " >&6 else case $BASENAME in @@ -3880,7 +3871,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_BASH+:} false; then : +if test "${ac_cv_path_BASH+set}" = set; then : $as_echo_n "(cached) " >&6 else case $BASH in @@ -3939,7 +3930,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CAT+:} false; then : +if test "${ac_cv_path_CAT+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CAT in @@ -3998,7 +3989,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CHMOD+:} false; then : +if test "${ac_cv_path_CHMOD+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CHMOD in @@ -4057,7 +4048,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CMP+:} false; then : +if test "${ac_cv_path_CMP+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CMP in @@ -4116,7 +4107,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_COMM+:} false; then : +if test "${ac_cv_path_COMM+set}" = set; then : $as_echo_n "(cached) " >&6 else case $COMM in @@ -4175,7 +4166,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CP+:} false; then : +if test "${ac_cv_path_CP+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CP in @@ -4234,7 +4225,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CPIO+:} false; then : +if test "${ac_cv_path_CPIO+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CPIO in @@ -4293,7 +4284,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CUT+:} false; then : +if test "${ac_cv_path_CUT+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CUT in @@ -4352,7 +4343,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_DATE+:} false; then : +if test "${ac_cv_path_DATE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $DATE in @@ -4411,7 +4402,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_DIFF+:} false; then : +if test "${ac_cv_path_DIFF+set}" = set; then : $as_echo_n "(cached) " >&6 else case $DIFF in @@ -4470,7 +4461,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_DIRNAME+:} false; then : +if test "${ac_cv_path_DIRNAME+set}" = set; then : $as_echo_n "(cached) " >&6 else case $DIRNAME in @@ -4529,7 +4520,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_ECHO+:} false; then : +if test "${ac_cv_path_ECHO+set}" = set; then : $as_echo_n "(cached) " >&6 else case $ECHO in @@ -4588,7 +4579,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_EXPR+:} false; then : +if test "${ac_cv_path_EXPR+set}" = set; then : $as_echo_n "(cached) " >&6 else case $EXPR in @@ -4647,7 +4638,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_FILE+:} false; then : +if test "${ac_cv_path_FILE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $FILE in @@ -4706,7 +4697,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_FIND+:} false; then : +if test "${ac_cv_path_FIND+set}" = set; then : $as_echo_n "(cached) " >&6 else case $FIND in @@ -4765,7 +4756,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_HEAD+:} false; then : +if test "${ac_cv_path_HEAD+set}" = set; then : $as_echo_n "(cached) " >&6 else case $HEAD in @@ -4824,7 +4815,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_LN+:} false; then : +if test "${ac_cv_path_LN+set}" = set; then : $as_echo_n "(cached) " >&6 else case $LN in @@ -4883,7 +4874,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_LS+:} false; then : +if test "${ac_cv_path_LS+set}" = set; then : $as_echo_n "(cached) " >&6 else case $LS in @@ -4942,7 +4933,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_MKDIR+:} false; then : +if test "${ac_cv_path_MKDIR+set}" = set; then : $as_echo_n "(cached) " >&6 else case $MKDIR in @@ -5001,7 +4992,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_MKTEMP+:} false; then : +if test "${ac_cv_path_MKTEMP+set}" = set; then : $as_echo_n "(cached) " >&6 else case $MKTEMP in @@ -5060,7 +5051,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_MV+:} false; then : +if test "${ac_cv_path_MV+set}" = set; then : $as_echo_n "(cached) " >&6 else case $MV in @@ -5119,7 +5110,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_PRINTF+:} false; then : +if test "${ac_cv_path_PRINTF+set}" = set; then : $as_echo_n "(cached) " >&6 else case $PRINTF in @@ -5178,7 +5169,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_THEPWDCMD+:} false; then : +if test "${ac_cv_path_THEPWDCMD+set}" = set; then : $as_echo_n "(cached) " >&6 else case $THEPWDCMD in @@ -5237,7 +5228,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_RM+:} false; then : +if test "${ac_cv_path_RM+set}" = set; then : $as_echo_n "(cached) " >&6 else case $RM in @@ -5296,7 +5287,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_SH+:} false; then : +if test "${ac_cv_path_SH+set}" = set; then : $as_echo_n "(cached) " >&6 else case $SH in @@ -5355,7 +5346,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_SORT+:} false; then : +if test "${ac_cv_path_SORT+set}" = set; then : $as_echo_n "(cached) " >&6 else case $SORT in @@ -5414,7 +5405,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TAIL+:} false; then : +if test "${ac_cv_path_TAIL+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TAIL in @@ -5473,7 +5464,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TAR+:} false; then : +if test "${ac_cv_path_TAR+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TAR in @@ -5532,7 +5523,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TEE+:} false; then : +if test "${ac_cv_path_TEE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TEE in @@ -5591,7 +5582,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TOUCH+:} false; then : +if test "${ac_cv_path_TOUCH+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TOUCH in @@ -5650,7 +5641,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TR+:} false; then : +if test "${ac_cv_path_TR+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TR in @@ -5709,7 +5700,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_UNAME+:} false; then : +if test "${ac_cv_path_UNAME+set}" = set; then : $as_echo_n "(cached) " >&6 else case $UNAME in @@ -5768,7 +5759,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_UNIQ+:} false; then : +if test "${ac_cv_path_UNIQ+set}" = set; then : $as_echo_n "(cached) " >&6 else case $UNIQ in @@ -5827,7 +5818,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_WC+:} false; then : +if test "${ac_cv_path_WC+set}" = set; then : $as_echo_n "(cached) " >&6 else case $WC in @@ -5886,7 +5877,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_WHICH+:} false; then : +if test "${ac_cv_path_WHICH+set}" = set; then : $as_echo_n "(cached) " >&6 else case $WHICH in @@ -5945,7 +5936,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_XARGS+:} false; then : +if test "${ac_cv_path_XARGS+set}" = set; then : $as_echo_n "(cached) " >&6 else case $XARGS in @@ -6005,7 +5996,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_AWK+:} false; then : +if test "${ac_cv_prog_AWK+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$AWK"; then @@ -6055,7 +6046,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 $as_echo_n "checking for grep that handles long lines and -e... " >&6; } -if ${ac_cv_path_GREP+:} false; then : +if test "${ac_cv_path_GREP+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -z "$GREP"; then @@ -6130,7 +6121,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 $as_echo_n "checking for egrep... " >&6; } -if ${ac_cv_path_EGREP+:} false; then : +if test "${ac_cv_path_EGREP+set}" = set; then : $as_echo_n "(cached) " >&6 else if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 @@ -6209,7 +6200,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 $as_echo_n "checking for fgrep... " >&6; } -if ${ac_cv_path_FGREP+:} false; then : +if test "${ac_cv_path_FGREP+set}" = set; then : $as_echo_n "(cached) " >&6 else if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 @@ -6288,7 +6279,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } -if ${ac_cv_path_SED+:} false; then : +if test "${ac_cv_path_SED+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ @@ -6374,7 +6365,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_NAWK+:} false; then : +if test "${ac_cv_path_NAWK+set}" = set; then : $as_echo_n "(cached) " >&6 else case $NAWK in @@ -6434,7 +6425,7 @@ RM="$RM -f" set dummy cygpath; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CYGPATH+:} false; then : +if test "${ac_cv_path_CYGPATH+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CYGPATH in @@ -6474,7 +6465,7 @@ fi set dummy readlink; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_READLINK+:} false; then : +if test "${ac_cv_path_READLINK+set}" = set; then : $as_echo_n "(cached) " >&6 else case $READLINK in @@ -6514,7 +6505,7 @@ fi set dummy df; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_DF+:} false; then : +if test "${ac_cv_path_DF+set}" = set; then : $as_echo_n "(cached) " >&6 else case $DF in @@ -6554,7 +6545,7 @@ fi set dummy SetFile; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_SETFILE+:} false; then : +if test "${ac_cv_path_SETFILE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $SETFILE in @@ -6600,7 +6591,7 @@ $SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || { $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 $as_echo_n "checking build system type... " >&6; } -if ${ac_cv_build+:} false; then : +if test "${ac_cv_build+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_build_alias=$build_alias @@ -6616,7 +6607,7 @@ fi $as_echo "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; +*) as_fn_error $? "invalid value of canonical build" "$LINENO" 5 ;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' @@ -6634,7 +6625,7 @@ case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 $as_echo_n "checking host system type... " >&6; } -if ${ac_cv_host+:} false; then : +if test "${ac_cv_host+set}" = set; then : $as_echo_n "(cached) " >&6 else if test "x$host_alias" = x; then @@ -6649,7 +6640,7 @@ fi $as_echo "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; +*) as_fn_error $? "invalid value of canonical host" "$LINENO" 5 ;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' @@ -6667,7 +6658,7 @@ case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking target system type" >&5 $as_echo_n "checking target system type... " >&6; } -if ${ac_cv_target+:} false; then : +if test "${ac_cv_target+set}" = set; then : $as_echo_n "(cached) " >&6 else if test "x$target_alias" = x; then @@ -6682,7 +6673,7 @@ fi $as_echo "$ac_cv_target" >&6; } case $ac_cv_target in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical target" "$LINENO" 5;; +*) as_fn_error $? "invalid value of canonical target" "$LINENO" 5 ;; esac target=$ac_cv_target ac_save_IFS=$IFS; IFS='-' @@ -6704,1055 +6695,6 @@ test -n "$target_alias" && test "$program_prefix$program_suffix$program_transform_name" = \ NONENONEs,x,x, && program_prefix=${target_alias}- -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. -set dummy ${ac_tool_prefix}gcc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_CC+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="${ac_tool_prefix}gcc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_CC"; then - ac_ct_CC=$CC - # Extract the first word of "gcc", so it can be a program name with args. -set dummy gcc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_CC+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CC="gcc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 -$as_echo "$ac_ct_CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -else - CC="$ac_cv_prog_CC" -fi - -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. -set dummy ${ac_tool_prefix}cc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_CC+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="${ac_tool_prefix}cc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - fi -fi -if test -z "$CC"; then - # Extract the first word of "cc", so it can be a program name with args. -set dummy cc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_CC+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else - ac_prog_rejected=no -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then - ac_prog_rejected=yes - continue - fi - ac_cv_prog_CC="cc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -if test $ac_prog_rejected = yes; then - # We found a bogon in the path, so make sure we never use it. - set dummy $ac_cv_prog_CC - shift - if test $# != 0; then - # We chose a different compiler from the bogus one. - # However, it has the same basename, so the bogon will be chosen - # first if we set CC to just the basename; use the full file name. - shift - ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" - fi -fi -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -fi -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - for ac_prog in cl.exe - do - # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_CC+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="$ac_tool_prefix$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$CC" && break - done -fi -if test -z "$CC"; then - ac_ct_CC=$CC - for ac_prog in cl.exe -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_CC+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CC="$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 -$as_echo "$ac_ct_CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$ac_ct_CC" && break -done - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -fi - -fi - - -test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "no acceptable C compiler found in \$PATH -See \`config.log' for more details" "$LINENO" 5; } - -# Provide some information about the compiler. -$as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 -set X $ac_compile -ac_compiler=$2 -for ac_option in --version -v -V -qversion; do - { { ac_try="$ac_compiler $ac_option >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_compiler $ac_option >&5") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - sed '10a\ -... rest of stderr output deleted ... - 10q' conftest.err >conftest.er1 - cat conftest.er1 >&5 - fi - rm -f conftest.er1 conftest.err - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -done - -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" -# Try to create an executable without -o first, disregard a.out. -# It will help us diagnose broken compilers, and finding out an intuition -# of exeext. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 -$as_echo_n "checking whether the C compiler works... " >&6; } -ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` - -# The possible output files: -ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" - -ac_rmfiles= -for ac_file in $ac_files -do - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - * ) ac_rmfiles="$ac_rmfiles $ac_file";; - esac -done -rm -f $ac_rmfiles - -if { { ac_try="$ac_link_default" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link_default") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. -# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' -# in a Makefile. We should not override ac_cv_exeext if it was cached, -# so that the user can short-circuit this test for compilers unknown to -# Autoconf. -for ac_file in $ac_files '' -do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) - ;; - [ab].out ) - # We found the default executable, but exeext='' is most - # certainly right. - break;; - *.* ) - if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; - then :; else - ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - fi - # We set ac_cv_exeext here because the later test for it is not - # safe: cross compilers may not add the suffix if given an `-o' - # argument, so we may need to know it at that point already. - # Even if this section looks crufty: it has the advantage of - # actually working. - break;; - * ) - break;; - esac -done -test "$ac_cv_exeext" = no && ac_cv_exeext= - -else - ac_file='' -fi -if test -z "$ac_file"; then : - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -$as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error 77 "C compiler cannot create executables -See \`config.log' for more details" "$LINENO" 5; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; } -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 -$as_echo_n "checking for C compiler default output file name... " >&6; } -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 -$as_echo "$ac_file" >&6; } -ac_exeext=$ac_cv_exeext - -rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out -ac_clean_files=$ac_clean_files_save -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 -$as_echo_n "checking for suffix of executables... " >&6; } -if { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - # If both `conftest.exe' and `conftest' are `present' (well, observable) -# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will -# work properly (i.e., refer to `conftest.exe'), while it won't with -# `rm'. -for ac_file in conftest.exe conftest conftest.*; do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - break;; - * ) break;; - esac -done -else - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot compute suffix of executables: cannot compile and link -See \`config.log' for more details" "$LINENO" 5; } -fi -rm -f conftest conftest$ac_cv_exeext -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 -$as_echo "$ac_cv_exeext" >&6; } - -rm -f conftest.$ac_ext -EXEEXT=$ac_cv_exeext -ac_exeext=$EXEEXT -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -int -main () -{ -FILE *f = fopen ("conftest.out", "w"); - return ferror (f) || fclose (f) != 0; - - ; - return 0; -} -_ACEOF -ac_clean_files="$ac_clean_files conftest.out" -# Check that the compiler produces executables we can run. If not, either -# the compiler is broken, or we cross compile. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 -$as_echo_n "checking whether we are cross compiling... " >&6; } -if test "$cross_compiling" != yes; then - { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } - if { ac_try='./conftest$ac_cv_exeext' - { { case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; }; then - cross_compiling=no - else - if test "$cross_compiling" = maybe; then - cross_compiling=yes - else - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot run C compiled programs. -If you meant to cross compile, use \`--host'. -See \`config.log' for more details" "$LINENO" 5; } - fi - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 -$as_echo "$cross_compiling" >&6; } - -rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out -ac_clean_files=$ac_clean_files_save -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 -$as_echo_n "checking for suffix of object files... " >&6; } -if ${ac_cv_objext+:} false; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.o conftest.obj -if { { ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_compile") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - for ac_file in conftest.o conftest.obj conftest.*; do - test -f "$ac_file" || continue; - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; - *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` - break;; - esac -done -else - $as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error $? "cannot compute suffix of object files: cannot compile -See \`config.log' for more details" "$LINENO" 5; } -fi -rm -f conftest.$ac_cv_objext conftest.$ac_ext -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 -$as_echo "$ac_cv_objext" >&6; } -OBJEXT=$ac_cv_objext -ac_objext=$OBJEXT -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 -$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } -if ${ac_cv_c_compiler_gnu+:} false; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ -#ifndef __GNUC__ - choke me -#endif - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_compiler_gnu=yes -else - ac_compiler_gnu=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -ac_cv_c_compiler_gnu=$ac_compiler_gnu - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 -$as_echo "$ac_cv_c_compiler_gnu" >&6; } -if test $ac_compiler_gnu = yes; then - GCC=yes -else - GCC= -fi -ac_test_CFLAGS=${CFLAGS+set} -ac_save_CFLAGS=$CFLAGS -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 -$as_echo_n "checking whether $CC accepts -g... " >&6; } -if ${ac_cv_prog_cc_g+:} false; then : - $as_echo_n "(cached) " >&6 -else - ac_save_c_werror_flag=$ac_c_werror_flag - ac_c_werror_flag=yes - ac_cv_prog_cc_g=no - CFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_prog_cc_g=yes -else - CFLAGS="" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - -else - ac_c_werror_flag=$ac_save_c_werror_flag - CFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_prog_cc_g=yes -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_c_werror_flag=$ac_save_c_werror_flag -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 -$as_echo "$ac_cv_prog_cc_g" >&6; } -if test "$ac_test_CFLAGS" = set; then - CFLAGS=$ac_save_CFLAGS -elif test $ac_cv_prog_cc_g = yes; then - if test "$GCC" = yes; then - CFLAGS="-g -O2" - else - CFLAGS="-g" - fi -else - if test "$GCC" = yes; then - CFLAGS="-O2" - else - CFLAGS= - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 -$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } -if ${ac_cv_prog_cc_c89+:} false; then : - $as_echo_n "(cached) " >&6 -else - ac_cv_prog_cc_c89=no -ac_save_CC=$CC -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -#include -#include -#include -/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ -struct buf { int x; }; -FILE * (*rcsopen) (struct buf *, struct stat *, int); -static char *e (p, i) - char **p; - int i; -{ - return p[i]; -} -static char *f (char * (*g) (char **, int), char **p, ...) -{ - char *s; - va_list v; - va_start (v,p); - s = g (p, va_arg (v,int)); - va_end (v); - return s; -} - -/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has - function prototypes and stuff, but not '\xHH' hex character constants. - These don't provoke an error unfortunately, instead are silently treated - as 'x'. The following induces an error, until -std is added to get - proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an - array size at least. It's necessary to write '\x00'==0 to get something - that's true only with -std. */ -int osf4_cc_array ['\x00' == 0 ? 1 : -1]; - -/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters - inside strings and character constants. */ -#define FOO(x) 'x' -int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; - -int test (int i, double x); -struct s1 {int (*f) (int a);}; -struct s2 {int (*f) (double a);}; -int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); -int argc; -char **argv; -int -main () -{ -return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; - ; - return 0; -} -_ACEOF -for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ - -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" -do - CC="$ac_save_CC $ac_arg" - if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_prog_cc_c89=$ac_arg -fi -rm -f core conftest.err conftest.$ac_objext - test "x$ac_cv_prog_cc_c89" != "xno" && break -done -rm -f conftest.$ac_ext -CC=$ac_save_CC - -fi -# AC_CACHE_VAL -case "x$ac_cv_prog_cc_c89" in - x) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 -$as_echo "none needed" >&6; } ;; - xno) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 -$as_echo "unsupported" >&6; } ;; - *) - CC="$CC $ac_cv_prog_cc_c89" - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 -$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; -esac -if test "x$ac_cv_prog_cc_c89" != xno; then : - -fi - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - -ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu -if test -z "$CXX"; then - if test -n "$CCC"; then - CXX=$CCC - else - if test -n "$ac_tool_prefix"; then - for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC - do - # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_CXX+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CXX"; then - ac_cv_prog_CXX="$CXX" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CXX=$ac_cv_prog_CXX -if test -n "$CXX"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CXX" >&5 -$as_echo "$CXX" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$CXX" && break - done -fi -if test -z "$CXX"; then - ac_ct_CXX=$CXX - for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_CXX+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$ac_ct_CXX"; then - ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CXX="$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CXX=$ac_cv_prog_ac_ct_CXX -if test -n "$ac_ct_CXX"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CXX" >&5 -$as_echo "$ac_ct_CXX" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$ac_ct_CXX" && break -done - - if test "x$ac_ct_CXX" = x; then - CXX="g++" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CXX=$ac_ct_CXX - fi -fi - - fi -fi -# Provide some information about the compiler. -$as_echo "$as_me:${as_lineno-$LINENO}: checking for C++ compiler version" >&5 -set X $ac_compile -ac_compiler=$2 -for ac_option in --version -v -V -qversion; do - { { ac_try="$ac_compiler $ac_option >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_compiler $ac_option >&5") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - sed '10a\ -... rest of stderr output deleted ... - 10q' conftest.err >conftest.er1 - cat conftest.er1 >&5 - fi - rm -f conftest.er1 conftest.err - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -done - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C++ compiler" >&5 -$as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } -if ${ac_cv_cxx_compiler_gnu+:} false; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ -#ifndef __GNUC__ - choke me -#endif - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - ac_compiler_gnu=yes -else - ac_compiler_gnu=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -ac_cv_cxx_compiler_gnu=$ac_compiler_gnu - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cxx_compiler_gnu" >&5 -$as_echo "$ac_cv_cxx_compiler_gnu" >&6; } -if test $ac_compiler_gnu = yes; then - GXX=yes -else - GXX= -fi -ac_test_CXXFLAGS=${CXXFLAGS+set} -ac_save_CXXFLAGS=$CXXFLAGS -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 -$as_echo_n "checking whether $CXX accepts -g... " >&6; } -if ${ac_cv_prog_cxx_g+:} false; then : - $as_echo_n "(cached) " >&6 -else - ac_save_cxx_werror_flag=$ac_cxx_werror_flag - ac_cxx_werror_flag=yes - ac_cv_prog_cxx_g=no - CXXFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - ac_cv_prog_cxx_g=yes -else - CXXFLAGS="" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - -else - ac_cxx_werror_flag=$ac_save_cxx_werror_flag - CXXFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - ac_cv_prog_cxx_g=yes -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_cxx_werror_flag=$ac_save_cxx_werror_flag -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cxx_g" >&5 -$as_echo "$ac_cv_prog_cxx_g" >&6; } -if test "$ac_test_CXXFLAGS" = set; then - CXXFLAGS=$ac_save_CXXFLAGS -elif test $ac_cv_prog_cxx_g = yes; then - if test "$GXX" = yes; then - CXXFLAGS="-g -O2" - else - CXXFLAGS="-g" - fi -else - if test "$GXX" = yes; then - CXXFLAGS="-O2" - else - CXXFLAGS= - fi -fi -ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - # Figure out the build and target systems. # Note that in autoconf terminology, "build" is obvious, but "target" # is confusing; it assumes you are cross-compiling a cross-compiler (!) and "target" is thus the target of the @@ -8167,86 +7109,6 @@ $as_echo "$COMPILE_TYPE" >&6; } fi - # Some Zero and Shark settings. - # ZERO_ARCHFLAG tells the compiler which mode to build for - case "${OPENJDK_TARGET_CPU}" in - s390) - ZERO_ARCHFLAG="-m31" - ;; - *) - ZERO_ARCHFLAG="-m${OPENJDK_TARGET_CPU_BITS}" - esac - - { $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$ZERO_ARCHFLAG\"" >&5 -$as_echo_n "checking if compiler supports \"$ZERO_ARCHFLAG\"... " >&6; } - supports=yes - - saved_cflags="$CFLAGS" - CFLAGS="$CFLAGS $ZERO_ARCHFLAG" - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - int i; - -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - -else - supports=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - CFLAGS="$saved_cflags" - - saved_cxxflags="$CXXFLAGS" - CXXFLAGS="$CXXFLAG $ZERO_ARCHFLAG" - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - int i; - -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - -else - supports=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - CXXFLAGS="$saved_cxxflags" - - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5 -$as_echo "$supports" >&6; } - if test "x$supports" = "xyes" ; then - : - else - ZERO_ARCHFLAG="" - fi - - - # ZERO_ARCHDEF is used to enable architecture-specific code case "${OPENJDK_TARGET_CPU}" in ppc*) ZERO_ARCHDEF=PPC ;; @@ -9298,7 +8160,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_PKGHANDLER+:} false; then : +if test "${ac_cv_prog_PKGHANDLER+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$PKGHANDLER"; then @@ -9663,7 +8525,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CHECK_GMAKE+:} false; then : +if test "${ac_cv_path_CHECK_GMAKE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CHECK_GMAKE in @@ -10017,7 +8879,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CHECK_MAKE+:} false; then : +if test "${ac_cv_path_CHECK_MAKE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CHECK_MAKE in @@ -10376,7 +9238,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CHECK_TOOLSDIR_GMAKE+:} false; then : +if test "${ac_cv_path_CHECK_TOOLSDIR_GMAKE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CHECK_TOOLSDIR_GMAKE in @@ -10729,7 +9591,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CHECK_TOOLSDIR_MAKE+:} false; then : +if test "${ac_cv_path_CHECK_TOOLSDIR_MAKE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CHECK_TOOLSDIR_MAKE in @@ -11125,7 +9987,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_UNZIP+:} false; then : +if test "${ac_cv_path_UNZIP+set}" = set; then : $as_echo_n "(cached) " >&6 else case $UNZIP in @@ -11184,7 +10046,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_ZIP+:} false; then : +if test "${ac_cv_path_ZIP+set}" = set; then : $as_echo_n "(cached) " >&6 else case $ZIP in @@ -11243,7 +10105,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} set dummy ldd; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_LDD+:} false; then : +if test "${ac_cv_path_LDD+set}" = set; then : $as_echo_n "(cached) " >&6 else case $LDD in @@ -11289,7 +10151,7 @@ fi set dummy otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_OTOOL+:} false; then : +if test "${ac_cv_path_OTOOL+set}" = set; then : $as_echo_n "(cached) " >&6 else case $OTOOL in @@ -11334,7 +10196,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_READELF+:} false; then : +if test "${ac_cv_path_READELF+set}" = set; then : $as_echo_n "(cached) " >&6 else case $READELF in @@ -11377,7 +10239,7 @@ done set dummy hg; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_HG+:} false; then : +if test "${ac_cv_path_HG+set}" = set; then : $as_echo_n "(cached) " >&6 else case $HG in @@ -11417,7 +10279,7 @@ fi set dummy stat; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_STAT+:} false; then : +if test "${ac_cv_path_STAT+set}" = set; then : $as_echo_n "(cached) " >&6 else case $STAT in @@ -11457,7 +10319,7 @@ fi set dummy time; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TIME+:} false; then : +if test "${ac_cv_path_TIME+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TIME in @@ -11502,7 +10364,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_COMM+:} false; then : +if test "${ac_cv_path_COMM+set}" = set; then : $as_echo_n "(cached) " >&6 else case $COMM in @@ -11564,7 +10426,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_XATTR+:} false; then : +if test "${ac_cv_path_XATTR+set}" = set; then : $as_echo_n "(cached) " >&6 else case $XATTR in @@ -11628,7 +10490,7 @@ if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_PKG_CONFIG+:} false; then : +if test "${ac_cv_path_PKG_CONFIG+set}" = set; then : $as_echo_n "(cached) " >&6 else case $PKG_CONFIG in @@ -11671,7 +10533,7 @@ if test -z "$ac_cv_path_PKG_CONFIG"; then set dummy pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_ac_pt_PKG_CONFIG+:} false; then : +if test "${ac_cv_path_ac_pt_PKG_CONFIG+set}" = set; then : $as_echo_n "(cached) " >&6 else case $ac_pt_PKG_CONFIG in @@ -11844,7 +10706,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_BDEPS_UNZIP+:} false; then : +if test "${ac_cv_prog_BDEPS_UNZIP+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$BDEPS_UNZIP"; then @@ -11890,7 +10752,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_BDEPS_FTP+:} false; then : +if test "${ac_cv_prog_BDEPS_FTP+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$BDEPS_FTP"; then @@ -13163,7 +12025,7 @@ $as_echo "$BOOT_JDK_VERSION" >&6; } set dummy javac; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_JAVAC_CHECK+:} false; then : +if test "${ac_cv_path_JAVAC_CHECK+set}" = set; then : $as_echo_n "(cached) " >&6 else case $JAVAC_CHECK in @@ -13203,7 +12065,7 @@ fi set dummy java; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_JAVA_CHECK+:} false; then : +if test "${ac_cv_path_JAVA_CHECK+set}" = set; then : $as_echo_n "(cached) " >&6 else case $JAVA_CHECK in @@ -17277,7 +16139,7 @@ if test "x$OPENJDK_TARGET_OS" = "xwindows"; then set dummy link; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CYGWIN_LINK+:} false; then : +if test "${ac_cv_path_CYGWIN_LINK+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CYGWIN_LINK in @@ -18692,7 +17554,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_BUILD_CC+:} false; then : +if test "${ac_cv_path_BUILD_CC+set}" = set; then : $as_echo_n "(cached) " >&6 else case $BUILD_CC in @@ -19003,7 +17865,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_BUILD_CXX+:} false; then : +if test "${ac_cv_path_BUILD_CXX+set}" = set; then : $as_echo_n "(cached) " >&6 else case $BUILD_CXX in @@ -19312,7 +18174,7 @@ $as_echo "$as_me: Rewriting BUILD_CXX to \"$new_complete\"" >&6;} set dummy ld; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_BUILD_LD+:} false; then : +if test "${ac_cv_path_BUILD_LD+set}" = set; then : $as_echo_n "(cached) " >&6 else case $BUILD_LD in @@ -19828,7 +18690,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TOOLS_DIR_CC+:} false; then : +if test "${ac_cv_path_TOOLS_DIR_CC+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TOOLS_DIR_CC in @@ -19880,7 +18742,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_POTENTIAL_CC+:} false; then : +if test "${ac_cv_path_POTENTIAL_CC+set}" = set; then : $as_echo_n "(cached) " >&6 else case $POTENTIAL_CC in @@ -20293,7 +19155,7 @@ $as_echo "yes, trying to find proper $COMPILER_NAME compiler" >&6; } set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_PROPER_COMPILER_CC+:} false; then : +if test "${ac_cv_prog_PROPER_COMPILER_CC+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$PROPER_COMPILER_CC"; then @@ -20337,7 +19199,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_PROPER_COMPILER_CC+:} false; then : +if test "${ac_cv_prog_ac_ct_PROPER_COMPILER_CC+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_PROPER_COMPILER_CC"; then @@ -20787,7 +19649,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_CC+:} false; then : +if test "${ac_cv_prog_CC+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then @@ -20831,7 +19693,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_CC+:} false; then : +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then @@ -20884,7 +19746,7 @@ fi test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH -See \`config.log' for more details" "$LINENO" 5; } +See \`config.log' for more details" "$LINENO" 5 ; } # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 @@ -20911,9 +19773,259 @@ $as_echo "$ac_try_echo"; } >&5 test $ac_status = 0; } done +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" +# Try to create an executable without -o first, disregard a.out. +# It will help us diagnose broken compilers, and finding out an intuition +# of exeext. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 +$as_echo_n "checking whether the C compiler works... " >&6; } +ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` + +# The possible output files: +ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" + +ac_rmfiles= +for ac_file in $ac_files +do + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + * ) ac_rmfiles="$ac_rmfiles $ac_file";; + esac +done +rm -f $ac_rmfiles + +if { { ac_try="$ac_link_default" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link_default") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. +# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' +# in a Makefile. We should not override ac_cv_exeext if it was cached, +# so that the user can short-circuit this test for compilers unknown to +# Autoconf. +for ac_file in $ac_files '' +do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) + ;; + [ab].out ) + # We found the default executable, but exeext='' is most + # certainly right. + break;; + *.* ) + if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; + then :; else + ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + fi + # We set ac_cv_exeext here because the later test for it is not + # safe: cross compilers may not add the suffix if given an `-o' + # argument, so we may need to know it at that point already. + # Even if this section looks crufty: it has the advantage of + # actually working. + break;; + * ) + break;; + esac +done +test "$ac_cv_exeext" = no && ac_cv_exeext= + +else + ac_file='' +fi +if test -z "$ac_file"; then : + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error 77 "C compiler cannot create executables +See \`config.log' for more details" "$LINENO" 5 ; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 +$as_echo_n "checking for C compiler default output file name... " >&6; } +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 +$as_echo "$ac_file" >&6; } +ac_exeext=$ac_cv_exeext + +rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out +ac_clean_files=$ac_clean_files_save +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 +$as_echo_n "checking for suffix of executables... " >&6; } +if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # If both `conftest.exe' and `conftest' are `present' (well, observable) +# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will +# work properly (i.e., refer to `conftest.exe'), while it won't with +# `rm'. +for ac_file in conftest.exe conftest conftest.*; do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + break;; + * ) break;; + esac +done +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details" "$LINENO" 5 ; } +fi +rm -f conftest conftest$ac_cv_exeext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 +$as_echo "$ac_cv_exeext" >&6; } + +rm -f conftest.$ac_ext +EXEEXT=$ac_cv_exeext +ac_exeext=$EXEEXT +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +int +main () +{ +FILE *f = fopen ("conftest.out", "w"); + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +ac_clean_files="$ac_clean_files conftest.out" +# Check that the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 +$as_echo_n "checking whether we are cross compiling... " >&6; } +if test "$cross_compiling" != yes; then + { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } + if { ac_try='./conftest$ac_cv_exeext' + { { case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; }; then + cross_compiling=no + else + if test "$cross_compiling" = maybe; then + cross_compiling=yes + else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details" "$LINENO" 5 ; } + fi + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 +$as_echo "$cross_compiling" >&6; } + +rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out +ac_clean_files=$ac_clean_files_save +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 +$as_echo_n "checking for suffix of object files... " >&6; } +if test "${ac_cv_objext+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.o conftest.obj +if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + for ac_file in conftest.o conftest.obj conftest.*; do + test -f "$ac_file" || continue; + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; + *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` + break;; + esac +done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot compute suffix of object files: cannot compile +See \`config.log' for more details" "$LINENO" 5 ; } +fi +rm -f conftest.$ac_cv_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 +$as_echo "$ac_cv_objext" >&6; } +OBJEXT=$ac_cv_objext +ac_objext=$OBJEXT { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 $as_echo_n "checking whether we are using the GNU C compiler... " >&6; } -if ${ac_cv_c_compiler_gnu+:} false; then : +if test "${ac_cv_c_compiler_gnu+set}" = set; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -20950,7 +20062,7 @@ ac_test_CFLAGS=${CFLAGS+set} ac_save_CFLAGS=$CFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 $as_echo_n "checking whether $CC accepts -g... " >&6; } -if ${ac_cv_prog_cc_g+:} false; then : +if test "${ac_cv_prog_cc_g+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_save_c_werror_flag=$ac_c_werror_flag @@ -21028,7 +20140,7 @@ else fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 $as_echo_n "checking for $CC option to accept ISO C89... " >&6; } -if ${ac_cv_prog_cc_c89+:} false; then : +if test "${ac_cv_prog_cc_c89+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_cv_prog_cc_c89=no @@ -21151,7 +20263,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_TOOLS_DIR_CXX+:} false; then : +if test "${ac_cv_path_TOOLS_DIR_CXX+set}" = set; then : $as_echo_n "(cached) " >&6 else case $TOOLS_DIR_CXX in @@ -21203,7 +20315,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_POTENTIAL_CXX+:} false; then : +if test "${ac_cv_path_POTENTIAL_CXX+set}" = set; then : $as_echo_n "(cached) " >&6 else case $POTENTIAL_CXX in @@ -21616,7 +20728,7 @@ $as_echo "yes, trying to find proper $COMPILER_NAME compiler" >&6; } set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_PROPER_COMPILER_CXX+:} false; then : +if test "${ac_cv_prog_PROPER_COMPILER_CXX+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$PROPER_COMPILER_CXX"; then @@ -21660,7 +20772,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_PROPER_COMPILER_CXX+:} false; then : +if test "${ac_cv_prog_ac_ct_PROPER_COMPILER_CXX+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_PROPER_COMPILER_CXX"; then @@ -22114,7 +21226,7 @@ if test -z "$CXX"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_CXX+:} false; then : +if test "${ac_cv_prog_CXX+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$CXX"; then @@ -22158,7 +21270,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_CXX+:} false; then : +if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CXX"; then @@ -22236,7 +21348,7 @@ done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C++ compiler" >&5 $as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } -if ${ac_cv_cxx_compiler_gnu+:} false; then : +if test "${ac_cv_cxx_compiler_gnu+set}" = set; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -22273,7 +21385,7 @@ ac_test_CXXFLAGS=${CXXFLAGS+set} ac_save_CXXFLAGS=$CXXFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 $as_echo_n "checking whether $CXX accepts -g... " >&6; } -if ${ac_cv_prog_cxx_g+:} false; then : +if test "${ac_cv_prog_cxx_g+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_save_cxx_werror_flag=$ac_cxx_werror_flag @@ -22371,7 +21483,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_OBJC+:} false; then : +if test "${ac_cv_prog_OBJC+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJC"; then @@ -22415,7 +21527,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_OBJC+:} false; then : +if test "${ac_cv_prog_ac_ct_OBJC+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJC"; then @@ -22491,7 +21603,7 @@ done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU Objective C compiler" >&5 $as_echo_n "checking whether we are using the GNU Objective C compiler... " >&6; } -if ${ac_cv_objc_compiler_gnu+:} false; then : +if test "${ac_cv_objc_compiler_gnu+set}" = set; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -22528,7 +21640,7 @@ ac_test_OBJCFLAGS=${OBJCFLAGS+set} ac_save_OBJCFLAGS=$OBJCFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $OBJC accepts -g" >&5 $as_echo_n "checking whether $OBJC accepts -g... " >&6; } -if ${ac_cv_prog_objc_g+:} false; then : +if test "${ac_cv_prog_objc_g+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_save_objc_werror_flag=$ac_objc_werror_flag @@ -22904,7 +22016,7 @@ if test "x$OPENJDK_TARGET_OS" != xwindows; then set dummy ${ac_tool_prefix}ar; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_AR+:} false; then : +if test "${ac_cv_prog_AR+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$AR"; then @@ -22944,7 +22056,7 @@ if test -z "$ac_cv_prog_AR"; then set dummy ar; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_AR+:} false; then : +if test "${ac_cv_prog_ac_ct_AR+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_AR"; then @@ -23286,7 +22398,7 @@ if test "x$OPENJDK_TARGET_OS" = xwindows; then : set dummy link; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_WINLD+:} false; then : +if test "${ac_cv_prog_WINLD+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$WINLD"; then @@ -23625,7 +22737,7 @@ $as_echo "yes" >&6; } set dummy mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_MT+:} false; then : +if test "${ac_cv_prog_MT+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$MT"; then @@ -23946,7 +23058,7 @@ $as_echo "$as_me: Rewriting MT to \"$new_complete\"" >&6;} set dummy rc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_RC+:} false; then : +if test "${ac_cv_prog_RC+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$RC"; then @@ -24337,7 +23449,7 @@ fi set dummy lib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_WINAR+:} false; then : +if test "${ac_cv_prog_WINAR+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$WINAR"; then @@ -24643,7 +23755,7 @@ $as_echo "$as_me: Rewriting WINAR to \"$new_complete\"" >&6;} set dummy dumpbin; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_DUMPBIN+:} false; then : +if test "${ac_cv_prog_DUMPBIN+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$DUMPBIN"; then @@ -24962,7 +24074,7 @@ if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then - if ${ac_cv_prog_CPP+:} false; then : + if test "${ac_cv_prog_CPP+set}" = set; then : $as_echo_n "(cached) " >&6 else # Double quotes because CPP needs to be expanded @@ -25078,7 +24190,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check -See \`config.log' for more details" "$LINENO" 5; } +See \`config.log' for more details" "$LINENO" 5 ; } fi ac_ext=cpp @@ -25362,7 +24474,7 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C++ preprocessor" >&5 $as_echo_n "checking how to run the C++ preprocessor... " >&6; } if test -z "$CXXCPP"; then - if ${ac_cv_prog_CXXCPP+:} false; then : + if test "${ac_cv_prog_CXXCPP+set}" = set; then : $as_echo_n "(cached) " >&6 else # Double quotes because CXXCPP needs to be expanded @@ -25478,7 +24590,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C++ preprocessor \"$CXXCPP\" fails sanity check -See \`config.log' for more details" "$LINENO" 5; } +See \`config.log' for more details" "$LINENO" 5 ; } fi ac_ext=cpp @@ -25780,7 +24892,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris; then set dummy as; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_AS+:} false; then : +if test "${ac_cv_path_AS+set}" = set; then : $as_echo_n "(cached) " >&6 else case $AS in @@ -26092,7 +25204,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris; then set dummy nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_NM+:} false; then : +if test "${ac_cv_path_NM+set}" = set; then : $as_echo_n "(cached) " >&6 else case $NM in @@ -26398,7 +25510,7 @@ $as_echo "$as_me: Rewriting NM to \"$new_complete\"" >&6;} set dummy gnm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_GNM+:} false; then : +if test "${ac_cv_path_GNM+set}" = set; then : $as_echo_n "(cached) " >&6 else case $GNM in @@ -26704,7 +25816,7 @@ $as_echo "$as_me: Rewriting GNM to \"$new_complete\"" >&6;} set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_STRIP+:} false; then : +if test "${ac_cv_path_STRIP+set}" = set; then : $as_echo_n "(cached) " >&6 else case $STRIP in @@ -27010,7 +26122,7 @@ $as_echo "$as_me: Rewriting STRIP to \"$new_complete\"" >&6;} set dummy mcs; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_MCS+:} false; then : +if test "${ac_cv_path_MCS+set}" = set; then : $as_echo_n "(cached) " >&6 else case $MCS in @@ -27318,7 +26430,7 @@ elif test "x$OPENJDK_TARGET_OS" != xwindows; then set dummy ${ac_tool_prefix}nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_NM+:} false; then : +if test "${ac_cv_prog_NM+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$NM"; then @@ -27358,7 +26470,7 @@ if test -z "$ac_cv_prog_NM"; then set dummy nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_NM+:} false; then : +if test "${ac_cv_prog_ac_ct_NM+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_NM"; then @@ -27678,7 +26790,7 @@ $as_echo "$as_me: Rewriting NM to \"$new_complete\"" >&6;} set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_STRIP+:} false; then : +if test "${ac_cv_prog_STRIP+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then @@ -27718,7 +26830,7 @@ if test -z "$ac_cv_prog_STRIP"; then set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_STRIP+:} false; then : +if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then @@ -28043,7 +27155,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris || test "x$OPENJDK_TARGET_OS" = xlinux; set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_OBJCOPY+:} false; then : +if test "${ac_cv_prog_OBJCOPY+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJCOPY"; then @@ -28087,7 +27199,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_OBJCOPY+:} false; then : +if test "${ac_cv_prog_ac_ct_OBJCOPY+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJCOPY"; then @@ -28414,7 +27526,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_OBJDUMP+:} false; then : +if test "${ac_cv_prog_OBJDUMP+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJDUMP"; then @@ -28458,7 +27570,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : +if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJDUMP"; then @@ -28782,7 +27894,7 @@ if test "x$OPENJDK_TARGET_OS" = "xmacosx"; then set dummy lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_LIPO+:} false; then : +if test "${ac_cv_path_LIPO+set}" = set; then : $as_echo_n "(cached) " >&6 else case $LIPO in @@ -29094,9 +28206,10 @@ PATH="$OLD_PATH" # And we can test some aspects on the target using configure macros. + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 $as_echo_n "checking for ANSI C header files... " >&6; } -if ${ac_cv_header_stdc+:} false; then : +if test "${ac_cv_header_stdc+set}" = set; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -29231,79 +28344,6 @@ done # is made at runtime.) # - - - { $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"-m${OPENJDK_TARGET_CPU_BITS}\"" >&5 -$as_echo_n "checking if compiler supports \"-m${OPENJDK_TARGET_CPU_BITS}\"... " >&6; } - supports=yes - - saved_cflags="$CFLAGS" - CFLAGS="$CFLAGS -m${OPENJDK_TARGET_CPU_BITS}" - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - int i; - -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - -else - supports=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - CFLAGS="$saved_cflags" - - saved_cxxflags="$CXXFLAGS" - CXXFLAGS="$CXXFLAG -m${OPENJDK_TARGET_CPU_BITS}" - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - int i; - -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - -else - supports=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - CXXFLAGS="$saved_cxxflags" - - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5 -$as_echo "$supports" >&6; } - if test "x$supports" = "xyes" ; then - COMPILER_SUPPORTS_TARGET_BITS_FLAG=true - else - COMPILER_SUPPORTS_TARGET_BITS_FLAG=false - fi - - - - if test "x$OPENJDK_TARGET_OS" = xsolaris; then # Always specify -m flags on Solaris @@ -29346,7 +28386,7 @@ fi for ac_header in stdio.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "stdio.h" "ac_cv_header_stdio_h" "$ac_includes_default" -if test "x$ac_cv_header_stdio_h" = xyes; then : +if test "x$ac_cv_header_stdio_h" = x""yes; then : cat >>confdefs.h <<_ACEOF #define HAVE_STDIO_H 1 _ACEOF @@ -29375,7 +28415,7 @@ done # This bug is HP SR number 8606223364. { $as_echo "$as_me:${as_lineno-$LINENO}: checking size of int *" >&5 $as_echo_n "checking size of int *... " >&6; } -if ${ac_cv_sizeof_int_p+:} false; then : +if test "${ac_cv_sizeof_int_p+set}" = set; then : $as_echo_n "(cached) " >&6 else if ac_fn_cxx_compute_int "$LINENO" "(long int) (sizeof (int *))" "ac_cv_sizeof_int_p" "$ac_includes_default"; then : @@ -29385,7 +28425,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (int *) -See \`config.log' for more details" "$LINENO" 5; } +See \`config.log' for more details" "$LINENO" 5 ; } else ac_cv_sizeof_int_p=0 fi @@ -29432,7 +28472,7 @@ $as_echo "$OPENJDK_TARGET_CPU_BITS bits" >&6; } # { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether byte ordering is bigendian" >&5 $as_echo_n "checking whether byte ordering is bigendian... " >&6; } -if ${ac_cv_c_bigendian+:} false; then : +if test "${ac_cv_c_bigendian+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_cv_c_bigendian=unknown @@ -30228,6 +29268,161 @@ esac + + # Some Zero and Shark settings. + # ZERO_ARCHFLAG tells the compiler which mode to build for + case "${OPENJDK_TARGET_CPU}" in + s390) + ZERO_ARCHFLAG="-m31" + ;; + *) + ZERO_ARCHFLAG="-m${OPENJDK_TARGET_CPU_BITS}" + esac + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$ZERO_ARCHFLAG\"" >&5 +$as_echo_n "checking if compiler supports \"$ZERO_ARCHFLAG\"... " >&6; } + supports=yes + + saved_cflags="$CFLAGS" + CFLAGS="$CFLAGS $ZERO_ARCHFLAG" + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + CFLAGS="$saved_cflags" + + saved_cxxflags="$CXXFLAGS" + CXXFLAGS="$CXXFLAG $ZERO_ARCHFLAG" + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + CXXFLAGS="$saved_cxxflags" + + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5 +$as_echo "$supports" >&6; } + if test "x$supports" = "xyes" ; then + : + else + ZERO_ARCHFLAG="" + fi + + + + # Check that the compiler supports -mX flags + # Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"-m${OPENJDK_TARGET_CPU_BITS}\"" >&5 +$as_echo_n "checking if compiler supports \"-m${OPENJDK_TARGET_CPU_BITS}\"... " >&6; } + supports=yes + + saved_cflags="$CFLAGS" + CFLAGS="$CFLAGS -m${OPENJDK_TARGET_CPU_BITS}" + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + CFLAGS="$saved_cflags" + + saved_cxxflags="$CXXFLAGS" + CXXFLAGS="$CXXFLAG -m${OPENJDK_TARGET_CPU_BITS}" + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + int i; + +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + +else + supports=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + CXXFLAGS="$saved_cxxflags" + + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5 +$as_echo "$supports" >&6; } + if test "x$supports" = "xyes" ; then + COMPILER_SUPPORTS_TARGET_BITS_FLAG=true + else + COMPILER_SUPPORTS_TARGET_BITS_FLAG=false + fi + + + + # Setup debug symbols (need objcopy from the toolchain for that) # @@ -30443,8 +29638,8 @@ if test "x$with_x" = xno; then have_x=disabled else case $x_includes,$x_libraries in #( - *\'*) as_fn_error $? "cannot use X directory names containing '" "$LINENO" 5;; #( - *,NONE | NONE,*) if ${ac_cv_have_x+:} false; then : + *\'*) as_fn_error $? "cannot use X directory names containing '" "$LINENO" 5 ;; #( + *,NONE | NONE,*) if test "${ac_cv_have_x+set}" = set; then : $as_echo_n "(cached) " >&6 else # One or both of the vars are not set, and there is no cached value. @@ -30721,7 +29916,7 @@ if ac_fn_cxx_try_link "$LINENO"; then : else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet... " >&6; } -if ${ac_cv_lib_dnet_dnet_ntoa+:} false; then : +if test "${ac_cv_lib_dnet_dnet_ntoa+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30755,14 +29950,14 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_dnet_ntoa" >&6; } -if test "x$ac_cv_lib_dnet_dnet_ntoa" = xyes; then : +if test "x$ac_cv_lib_dnet_dnet_ntoa" = x""yes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet" fi if test $ac_cv_lib_dnet_dnet_ntoa = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet_stub" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet_stub... " >&6; } -if ${ac_cv_lib_dnet_stub_dnet_ntoa+:} false; then : +if test "${ac_cv_lib_dnet_stub_dnet_ntoa+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30796,7 +29991,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_stub_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_stub_dnet_ntoa" >&6; } -if test "x$ac_cv_lib_dnet_stub_dnet_ntoa" = xyes; then : +if test "x$ac_cv_lib_dnet_stub_dnet_ntoa" = x""yes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet_stub" fi @@ -30815,14 +30010,14 @@ rm -f core conftest.err conftest.$ac_objext \ # The functions gethostbyname, getservbyname, and inet_addr are # in -lbsd on LynxOS 3.0.1/i386, according to Lars Hecking. ac_fn_cxx_check_func "$LINENO" "gethostbyname" "ac_cv_func_gethostbyname" -if test "x$ac_cv_func_gethostbyname" = xyes; then : +if test "x$ac_cv_func_gethostbyname" = x""yes; then : fi if test $ac_cv_func_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lnsl" >&5 $as_echo_n "checking for gethostbyname in -lnsl... " >&6; } -if ${ac_cv_lib_nsl_gethostbyname+:} false; then : +if test "${ac_cv_lib_nsl_gethostbyname+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30856,14 +30051,14 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_nsl_gethostbyname" >&5 $as_echo "$ac_cv_lib_nsl_gethostbyname" >&6; } -if test "x$ac_cv_lib_nsl_gethostbyname" = xyes; then : +if test "x$ac_cv_lib_nsl_gethostbyname" = x""yes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl" fi if test $ac_cv_lib_nsl_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lbsd" >&5 $as_echo_n "checking for gethostbyname in -lbsd... " >&6; } -if ${ac_cv_lib_bsd_gethostbyname+:} false; then : +if test "${ac_cv_lib_bsd_gethostbyname+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30897,7 +30092,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_bsd_gethostbyname" >&5 $as_echo "$ac_cv_lib_bsd_gethostbyname" >&6; } -if test "x$ac_cv_lib_bsd_gethostbyname" = xyes; then : +if test "x$ac_cv_lib_bsd_gethostbyname" = x""yes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lbsd" fi @@ -30912,14 +30107,14 @@ fi # must be given before -lnsl if both are needed. We assume that # if connect needs -lnsl, so does gethostbyname. ac_fn_cxx_check_func "$LINENO" "connect" "ac_cv_func_connect" -if test "x$ac_cv_func_connect" = xyes; then : +if test "x$ac_cv_func_connect" = x""yes; then : fi if test $ac_cv_func_connect = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for connect in -lsocket" >&5 $as_echo_n "checking for connect in -lsocket... " >&6; } -if ${ac_cv_lib_socket_connect+:} false; then : +if test "${ac_cv_lib_socket_connect+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30953,7 +30148,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_socket_connect" >&5 $as_echo "$ac_cv_lib_socket_connect" >&6; } -if test "x$ac_cv_lib_socket_connect" = xyes; then : +if test "x$ac_cv_lib_socket_connect" = x""yes; then : X_EXTRA_LIBS="-lsocket $X_EXTRA_LIBS" fi @@ -30961,14 +30156,14 @@ fi # Guillermo Gomez says -lposix is necessary on A/UX. ac_fn_cxx_check_func "$LINENO" "remove" "ac_cv_func_remove" -if test "x$ac_cv_func_remove" = xyes; then : +if test "x$ac_cv_func_remove" = x""yes; then : fi if test $ac_cv_func_remove = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for remove in -lposix" >&5 $as_echo_n "checking for remove in -lposix... " >&6; } -if ${ac_cv_lib_posix_remove+:} false; then : +if test "${ac_cv_lib_posix_remove+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31002,7 +30197,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_posix_remove" >&5 $as_echo "$ac_cv_lib_posix_remove" >&6; } -if test "x$ac_cv_lib_posix_remove" = xyes; then : +if test "x$ac_cv_lib_posix_remove" = x""yes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lposix" fi @@ -31010,14 +30205,14 @@ fi # BSDI BSD/OS 2.1 needs -lipc for XOpenDisplay. ac_fn_cxx_check_func "$LINENO" "shmat" "ac_cv_func_shmat" -if test "x$ac_cv_func_shmat" = xyes; then : +if test "x$ac_cv_func_shmat" = x""yes; then : fi if test $ac_cv_func_shmat = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shmat in -lipc" >&5 $as_echo_n "checking for shmat in -lipc... " >&6; } -if ${ac_cv_lib_ipc_shmat+:} false; then : +if test "${ac_cv_lib_ipc_shmat+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31051,7 +30246,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ipc_shmat" >&5 $as_echo "$ac_cv_lib_ipc_shmat" >&6; } -if test "x$ac_cv_lib_ipc_shmat" = xyes; then : +if test "x$ac_cv_lib_ipc_shmat" = x""yes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lipc" fi @@ -31069,7 +30264,7 @@ fi # John Interrante, Karl Berry { $as_echo "$as_me:${as_lineno-$LINENO}: checking for IceConnectionNumber in -lICE" >&5 $as_echo_n "checking for IceConnectionNumber in -lICE... " >&6; } -if ${ac_cv_lib_ICE_IceConnectionNumber+:} false; then : +if test "${ac_cv_lib_ICE_IceConnectionNumber+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31103,7 +30298,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ICE_IceConnectionNumber" >&5 $as_echo "$ac_cv_lib_ICE_IceConnectionNumber" >&6; } -if test "x$ac_cv_lib_ICE_IceConnectionNumber" = xyes; then : +if test "x$ac_cv_lib_ICE_IceConnectionNumber" = x""yes; then : X_PRE_LIBS="$X_PRE_LIBS -lSM -lICE" fi @@ -32116,7 +31311,7 @@ $as_echo "$FREETYPE2_FOUND" >&6; } LDFLAGS="$FREETYPE2_LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for FT_Init_FreeType in -lfreetype" >&5 $as_echo_n "checking for FT_Init_FreeType in -lfreetype... " >&6; } -if ${ac_cv_lib_freetype_FT_Init_FreeType+:} false; then : +if test "${ac_cv_lib_freetype_FT_Init_FreeType+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32150,7 +31345,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_freetype_FT_Init_FreeType" >&5 $as_echo "$ac_cv_lib_freetype_FT_Init_FreeType" >&6; } -if test "x$ac_cv_lib_freetype_FT_Init_FreeType" = xyes; then : +if test "x$ac_cv_lib_freetype_FT_Init_FreeType" = x""yes; then : FREETYPE2_FOUND=true else as_fn_error $? "Could not find freetype2! $HELP_MSG " "$LINENO" 5 @@ -32438,7 +31633,7 @@ fi for ac_header in alsa/asoundlib.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "alsa/asoundlib.h" "ac_cv_header_alsa_asoundlib_h" "$ac_includes_default" -if test "x$ac_cv_header_alsa_asoundlib_h" = xyes; then : +if test "x$ac_cv_header_alsa_asoundlib_h" = x""yes; then : cat >>confdefs.h <<_ACEOF #define HAVE_ALSA_ASOUNDLIB_H 1 _ACEOF @@ -32497,7 +31692,7 @@ fi USE_EXTERNAL_LIBJPEG=true { $as_echo "$as_me:${as_lineno-$LINENO}: checking for main in -ljpeg" >&5 $as_echo_n "checking for main in -ljpeg... " >&6; } -if ${ac_cv_lib_jpeg_main+:} false; then : +if test "${ac_cv_lib_jpeg_main+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32525,7 +31720,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_jpeg_main" >&5 $as_echo "$ac_cv_lib_jpeg_main" >&6; } -if test "x$ac_cv_lib_jpeg_main" = xyes; then : +if test "x$ac_cv_lib_jpeg_main" = x""yes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBJPEG 1 _ACEOF @@ -32574,7 +31769,7 @@ if test "x${with_giflib}" = "xbundled"; then USE_EXTERNAL_LIBGIF=false elif test "x${with_giflib}" = "xsystem"; then ac_fn_cxx_check_header_mongrel "$LINENO" "gif_lib.h" "ac_cv_header_gif_lib_h" "$ac_includes_default" -if test "x$ac_cv_header_gif_lib_h" = xyes; then : +if test "x$ac_cv_header_gif_lib_h" = x""yes; then : else as_fn_error $? "--with-giflib=system specified, but gif_lib.h not found!" "$LINENO" 5 @@ -32583,7 +31778,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for DGifGetCode in -lgif" >&5 $as_echo_n "checking for DGifGetCode in -lgif... " >&6; } -if ${ac_cv_lib_gif_DGifGetCode+:} false; then : +if test "${ac_cv_lib_gif_DGifGetCode+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32617,7 +31812,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_gif_DGifGetCode" >&5 $as_echo "$ac_cv_lib_gif_DGifGetCode" >&6; } -if test "x$ac_cv_lib_gif_DGifGetCode" = xyes; then : +if test "x$ac_cv_lib_gif_DGifGetCode" = x""yes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBGIF 1 _ACEOF @@ -32649,7 +31844,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for compress in -lz" >&5 $as_echo_n "checking for compress in -lz... " >&6; } -if ${ac_cv_lib_z_compress+:} false; then : +if test "${ac_cv_lib_z_compress+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32683,7 +31878,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_z_compress" >&5 $as_echo "$ac_cv_lib_z_compress" >&6; } -if test "x$ac_cv_lib_z_compress" = xyes; then : +if test "x$ac_cv_lib_z_compress" = x""yes; then : ZLIB_FOUND=yes else ZLIB_FOUND=no @@ -32776,7 +31971,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cos in -lm" >&5 $as_echo_n "checking for cos in -lm... " >&6; } -if ${ac_cv_lib_m_cos+:} false; then : +if test "${ac_cv_lib_m_cos+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32810,7 +32005,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_m_cos" >&5 $as_echo "$ac_cv_lib_m_cos" >&6; } -if test "x$ac_cv_lib_m_cos" = xyes; then : +if test "x$ac_cv_lib_m_cos" = x""yes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBM 1 _ACEOF @@ -32834,7 +32029,7 @@ save_LIBS="$LIBS" LIBS="" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } -if ${ac_cv_lib_dl_dlopen+:} false; then : +if test "${ac_cv_lib_dl_dlopen+set}" = set; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32868,7 +32063,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } -if test "x$ac_cv_lib_dl_dlopen" = xyes; then : +if test "x$ac_cv_lib_dl_dlopen" = x""yes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBDL 1 _ACEOF @@ -33098,7 +32293,7 @@ and LIBFFI_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details. To get pkg-config, see . -See \`config.log' for more details" "$LINENO" 5; } +See \`config.log' for more details" "$LINENO" 5 ; } else LIBFFI_CFLAGS=$pkg_cv_LIBFFI_CFLAGS LIBFFI_LIBS=$pkg_cv_LIBFFI_LIBS @@ -33114,7 +32309,7 @@ if test "x$JVM_VARIANT_ZEROSHARK" = xtrue; then set dummy llvm-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_LLVM_CONFIG+:} false; then : +if test "${ac_cv_prog_LLVM_CONFIG+set}" = set; then : $as_echo_n "(cached) " >&6 else if test -n "$LLVM_CONFIG"; then @@ -33732,7 +32927,7 @@ fi set dummy ccache; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_CCACHE+:} false; then : +if test "${ac_cv_path_CCACHE+set}" = set; then : $as_echo_n "(cached) " >&6 else case $CCACHE in @@ -33993,21 +33188,10 @@ $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then - if test "x$cache_file" != "x/dev/null"; then + test "x$cache_file" != "x/dev/null" && { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 $as_echo "$as_me: updating cache $cache_file" >&6;} - if test ! -f "$cache_file" || test -h "$cache_file"; then - cat confcache >"$cache_file" - else - case $cache_file in #( - */* | ?:*) - mv -f confcache "$cache_file"$$ && - mv -f "$cache_file"$$ "$cache_file" ;; #( - *) - mv -f confcache "$cache_file" ;; - esac - fi - fi + cat confcache >$cache_file else { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 $as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} @@ -34039,7 +33223,7 @@ LTLIBOBJS=$ac_ltlibobjs -: "${CONFIG_STATUS=./config.status}" +: ${CONFIG_STATUS=./config.status} ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" @@ -34140,7 +33324,6 @@ fi IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. -as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR @@ -34448,7 +33631,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # values after options handling. ac_log=" This file was extended by OpenJDK $as_me jdk8, which was -generated by GNU Autoconf 2.68. Invocation command line was +generated by GNU Autoconf 2.67. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS @@ -34511,7 +33694,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ OpenJDK config.status jdk8 -configured by $0, generated by GNU Autoconf 2.68, +configured by $0, generated by GNU Autoconf 2.67, with options \\"\$ac_cs_config\\" Copyright (C) 2010 Free Software Foundation, Inc. @@ -34640,7 +33823,7 @@ do "$OUTPUT_ROOT/spec.sh") CONFIG_FILES="$CONFIG_FILES $OUTPUT_ROOT/spec.sh:$AUTOCONF_DIR/spec.sh.in" ;; "$OUTPUT_ROOT/Makefile") CONFIG_FILES="$CONFIG_FILES $OUTPUT_ROOT/Makefile:$AUTOCONF_DIR/Makefile.in" ;; - *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; + *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5 ;; esac done @@ -34662,10 +33845,9 @@ fi # after its creation but before its name has been assigned to `$tmp'. $debug || { - tmp= ac_tmp= + tmp= trap 'exit_status=$? - : "${ac_tmp:=$tmp}" - { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status + { test -z "$tmp" || test ! -d "$tmp" || rm -fr "$tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } @@ -34673,13 +33855,12 @@ $debug || { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && - test -d "$tmp" + test -n "$tmp" && test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 -ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. @@ -34701,7 +33882,7 @@ else ac_cs_awk_cr=$ac_cr fi -echo 'BEGIN {' >"$ac_tmp/subs1.awk" && +echo 'BEGIN {' >"$tmp/subs1.awk" && _ACEOF @@ -34729,7 +33910,7 @@ done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && +cat >>"\$tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h @@ -34777,7 +33958,7 @@ t delim rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK -cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && +cat >>"\$tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" @@ -34809,7 +33990,7 @@ if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat -fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ +fi < "$tmp/subs1.awk" > "$tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF @@ -34843,7 +34024,7 @@ fi # test -n "$CONFIG_FILES" # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then -cat >"$ac_tmp/defines.awk" <<\_ACAWK || +cat >"$tmp/defines.awk" <<\_ACAWK || BEGIN { _ACEOF @@ -34855,8 +34036,8 @@ _ACEOF # handling of long lines. ac_delim='%!_!# ' for ac_last_try in false false :; do - ac_tt=`sed -n "/$ac_delim/p" confdefs.h` - if test -z "$ac_tt"; then + ac_t=`sed -n "/$ac_delim/p" confdefs.h` + if test -z "$ac_t"; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 @@ -34957,7 +34138,7 @@ do esac case $ac_mode$ac_tag in :[FHL]*:*);; - :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; + :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5 ;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac @@ -34976,7 +34157,7 @@ do for ac_f do case $ac_f in - -) ac_f="$ac_tmp/stdin";; + -) ac_f="$tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. @@ -34985,7 +34166,7 @@ do [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || - as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; + as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5 ;; esac case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" @@ -35011,8 +34192,8 @@ $as_echo "$as_me: creating $ac_file" >&6;} esac case $ac_tag in - *:-:* | *:-) cat >"$ac_tmp/stdin" \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; + *:-:* | *:-) cat >"$tmp/stdin" \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac @@ -35137,22 +34318,21 @@ s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t $ac_datarootdir_hack " -eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ - >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 +eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$tmp/subs.awk" >$tmp/out \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && - { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && - { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ - "$ac_tmp/out"`; test -z "$ac_out"; } && + { ac_out=`sed -n '/\${datarootdir}/p' "$tmp/out"`; test -n "$ac_out"; } && + { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' "$tmp/out"`; test -z "$ac_out"; } && { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 $as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} - rm -f "$ac_tmp/stdin" + rm -f "$tmp/stdin" case $ac_file in - -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; - *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; + -) cat "$tmp/out" && rm -f "$tmp/out";; + *) rm -f "$ac_file" && mv "$tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; @@ -35163,20 +34343,20 @@ which seems to be undefined. Please make sure it is defined" >&2;} if test x"$ac_file" != x-; then { $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" - } >"$ac_tmp/config.h" \ + && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" + } >"$tmp/config.h" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 - if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then + if diff "$ac_file" "$tmp/config.h" >/dev/null 2>&1; then { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 $as_echo "$as_me: $ac_file is unchanged" >&6;} else rm -f "$ac_file" - mv "$ac_tmp/config.h" "$ac_file" \ + mv "$tmp/config.h" "$ac_file" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 fi else $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ + && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi ;; diff --git a/common/autoconf/platform.m4 b/common/autoconf/platform.m4 index 636b393078a..889b99ed727 100644 --- a/common/autoconf/platform.m4 +++ b/common/autoconf/platform.m4 @@ -333,18 +333,6 @@ AC_DEFUN([PLATFORM_SETUP_LEGACY_VARS], fi AC_SUBST(DEFINE_CROSS_COMPILE_ARCH) - # Some Zero and Shark settings. - # ZERO_ARCHFLAG tells the compiler which mode to build for - case "${OPENJDK_TARGET_CPU}" in - s390) - ZERO_ARCHFLAG="-m31" - ;; - *) - ZERO_ARCHFLAG="-m${OPENJDK_TARGET_CPU_BITS}" - esac - PLATFORM_COMPILER_CHECK_ARGUMENTS([$ZERO_ARCHFLAG], [], [ZERO_ARCHFLAG=""]) - AC_SUBST(ZERO_ARCHFLAG) - # ZERO_ARCHDEF is used to enable architecture-specific code case "${OPENJDK_TARGET_CPU}" in ppc*) ZERO_ARCHDEF=PPC ;; @@ -418,51 +406,6 @@ AC_SUBST(OS_VERSION_MINOR) AC_SUBST(OS_VERSION_MICRO) ]) -# PLATFORM_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE], -# [RUN-IF-FALSE]) -# ------------------------------------------------------------ -# Check that the c and c++ compilers support an argument -AC_DEFUN([PLATFORM_COMPILER_CHECK_ARGUMENTS], -[ - AC_MSG_CHECKING([if compiler supports "$1"]) - supports=yes - - saved_cflags="$CFLAGS" - CFLAGS="$CFLAGS $1" - AC_LANG_PUSH([C]) - AC_COMPILE_IFELSE([ - AC_LANG_SOURCE([[int i;]]) - ], [], [supports=no]) - AC_LANG_POP([C]) - CFLAGS="$saved_cflags" - - saved_cxxflags="$CXXFLAGS" - CXXFLAGS="$CXXFLAG $1" - AC_LANG_PUSH([C++]) - AC_COMPILE_IFELSE([ - AC_LANG_SOURCE([[int i;]]) - ], [], [supports=no]) - AC_LANG_POP([C++]) - CXXFLAGS="$saved_cxxflags" - - AC_MSG_RESULT([$supports]) - if test "x$supports" = "xyes" ; then - m4_ifval([$2], [$2], [:]) - else - m4_ifval([$3], [$3], [:]) - fi -]) - -# Check that the compiler supports -mX flags -# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does -AC_DEFUN([PLATFORM_CHECK_COMPILER_TARGET_BITS_FLAGS], -[ - PLATFORM_COMPILER_CHECK_ARGUMENTS([-m${OPENJDK_TARGET_CPU_BITS}], - [COMPILER_SUPPORTS_TARGET_BITS_FLAG=true], - [COMPILER_SUPPORTS_TARGET_BITS_FLAG=false]) - AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG) -]) - # Support macro for PLATFORM_SETUP_OPENJDK_TARGET_BITS. # Add -mX to various FLAGS variables. AC_DEFUN([PLATFORM_SET_COMPILER_TARGET_BITS_FLAGS], @@ -491,8 +434,6 @@ AC_DEFUN_ONCE([PLATFORM_SETUP_OPENJDK_TARGET_BITS], # is made at runtime.) # -PLATFORM_CHECK_COMPILER_TARGET_BITS_FLAGS - if test "x$OPENJDK_TARGET_OS" = xsolaris; then # Always specify -m flags on Solaris PLATFORM_SET_COMPILER_TARGET_BITS_FLAGS diff --git a/common/autoconf/toolchain.m4 b/common/autoconf/toolchain.m4 index 893fb16d674..a486abcb7cc 100644 --- a/common/autoconf/toolchain.m4 +++ b/common/autoconf/toolchain.m4 @@ -1030,3 +1030,61 @@ AC_SUBST(LDFLAGS_JDKLIB_SUFFIX) AC_SUBST(LDFLAGS_JDKEXE_SUFFIX) AC_SUBST(LDFLAGS_CXX_JDK) ]) + + +# TOOLCHAIN_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE], +# [RUN-IF-FALSE]) +# ------------------------------------------------------------ +# Check that the c and c++ compilers support an argument +AC_DEFUN([TOOLCHAIN_COMPILER_CHECK_ARGUMENTS], +[ + AC_MSG_CHECKING([if compiler supports "$1"]) + supports=yes + + saved_cflags="$CFLAGS" + CFLAGS="$CFLAGS $1" + AC_LANG_PUSH([C]) + AC_COMPILE_IFELSE([ + AC_LANG_SOURCE([[int i;]]) + ], [], [supports=no]) + AC_LANG_POP([C]) + CFLAGS="$saved_cflags" + + saved_cxxflags="$CXXFLAGS" + CXXFLAGS="$CXXFLAG $1" + AC_LANG_PUSH([C++]) + AC_COMPILE_IFELSE([ + AC_LANG_SOURCE([[int i;]]) + ], [], [supports=no]) + AC_LANG_POP([C++]) + CXXFLAGS="$saved_cxxflags" + + AC_MSG_RESULT([$supports]) + if test "x$supports" = "xyes" ; then + m4_ifval([$2], [$2], [:]) + else + m4_ifval([$3], [$3], [:]) + fi +]) + +AC_DEFUN_ONCE([TOOLCHAIN_SETUP_COMPILER_FLAGS_MISC], +[ + # Some Zero and Shark settings. + # ZERO_ARCHFLAG tells the compiler which mode to build for + case "${OPENJDK_TARGET_CPU}" in + s390) + ZERO_ARCHFLAG="-m31" + ;; + *) + ZERO_ARCHFLAG="-m${OPENJDK_TARGET_CPU_BITS}" + esac + TOOLCHAIN_COMPILER_CHECK_ARGUMENTS([$ZERO_ARCHFLAG], [], [ZERO_ARCHFLAG=""]) + AC_SUBST(ZERO_ARCHFLAG) + + # Check that the compiler supports -mX flags + # Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does + TOOLCHAIN_COMPILER_CHECK_ARGUMENTS([-m${OPENJDK_TARGET_CPU_BITS}], + [COMPILER_SUPPORTS_TARGET_BITS_FLAG=true], + [COMPILER_SUPPORTS_TARGET_BITS_FLAG=false]) + AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG) +]) From e1001e848f3bbadd1bb223780481d5b5c4e719a4 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Thu, 2 May 2013 15:56:39 +0200 Subject: [PATCH 48/50] 8011687: Support correct dependencies from header files on windows and solaris Reviewed-by: tbell --- common/autoconf/generated-configure.sh | 4 +++- common/autoconf/spec.gmk.in | 1 + common/autoconf/toolchain.m4 | 1 + common/makefiles/NativeCompilation.gmk | 20 +++++++++++++++++++- 4 files changed, 24 insertions(+), 2 deletions(-) diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index a7c9e7a8f77..832b6410016 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -681,6 +681,7 @@ LIBRARY_PREFIX STATIC_LIBRARY SHARED_LIBRARY OBJ_SUFFIX +COMPILER_NAME LIPO ac_ct_OBJDUMP OBJDUMP @@ -3774,7 +3775,7 @@ fi #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1367502345 +DATE_WHEN_GENERATED=1367502949 ############################################################################### # @@ -28805,6 +28806,7 @@ fi + # The (cross) compiler is now configured, we can now test capabilities # of the target platform. diff --git a/common/autoconf/spec.gmk.in b/common/autoconf/spec.gmk.in index 14a8ad34405..2172ee8ef68 100644 --- a/common/autoconf/spec.gmk.in +++ b/common/autoconf/spec.gmk.in @@ -300,6 +300,7 @@ MACOSX_VERSION_MIN=@MACOSX_VERSION_MIN@ # CC is gcc and others behaving reasonably similar. # CL is cl.exe only. COMPILER_TYPE:=@COMPILER_TYPE@ +COMPILER_NAME:=@COMPILER_NAME@ COMPILER_SUPPORTS_TARGET_BITS_FLAG=@COMPILER_SUPPORTS_TARGET_BITS_FLAG@ diff --git a/common/autoconf/toolchain.m4 b/common/autoconf/toolchain.m4 index a486abcb7cc..779f86117ab 100644 --- a/common/autoconf/toolchain.m4 +++ b/common/autoconf/toolchain.m4 @@ -573,6 +573,7 @@ else fi fi +AC_SUBST(COMPILER_NAME) AC_SUBST(OBJ_SUFFIX) AC_SUBST(SHARED_LIBRARY) AC_SUBST(STATIC_LIBRARY) diff --git a/common/makefiles/NativeCompilation.gmk b/common/makefiles/NativeCompilation.gmk index 838a62ce111..a7b41abc1d0 100644 --- a/common/makefiles/NativeCompilation.gmk +++ b/common/makefiles/NativeCompilation.gmk @@ -95,10 +95,28 @@ define add_native_source $$($1_$2_OBJ) : $2 ifeq ($(COMPILER_TYPE),CC) $$(call COMPILING_MSG,$2,$$($1_TARGET)) + # The Sun studio compiler doesn't output the full path to the object file in the + # generated deps files. Fixing it with sed. If compiling assembly, don't try this. + ifeq ($(COMPILER_NAME)$$(filter %.s,$2),ossc) + $$($1_$2_COMP) $$($1_$2_FLAGS) $$($1_$2_DEP_FLAG) $$($1_$2_DEP).tmp $(CC_OUT_OPTION)$$($1_$2_OBJ) $2 + $(SED) 's|^$$(@F):|$$@:|' $$($1_$2_DEP).tmp > $$($1_$2_DEP) + else $$($1_$2_COMP) $$($1_$2_FLAGS) $$($1_$2_DEP_FLAG) $$($1_$2_DEP) $(CC_OUT_OPTION)$$($1_$2_OBJ) $2 endif + endif + # The Visual Studio compiler lacks a feature for generating make dependencies, but by + # setting -showIncludes, all included files are printed. These are filtered out and + # parsed into make dependences. ifeq ($(COMPILER_TYPE),CL) - $$($1_$2_COMP) $$($1_$2_FLAGS) $$($1_$2_DEBUG_OUT_FLAGS) $(CC_OUT_OPTION)$$($1_$2_OBJ) $2 + $$($1_$2_COMP) $$($1_$2_FLAGS) -showIncludes $$($1_$2_DEBUG_OUT_FLAGS) $(CC_OUT_OPTION)$$($1_$2_OBJ) $2 | $(TEE) $$($1_$2_DEP).raw | $(GREP) -v "^Note: including file:" + ($(ECHO) $$@: \\ \ + && $(SED) -e '/^Note: including file:/!d' \ + -e 's|Note: including file: *||' \ + -e 's|\\|/|g' \ + -e 's|^\([a-zA-Z]\):|/cygdrive/\1|g' \ + -e '/$(subst /,\/,$(TOPDIR))/!d' \ + -e 's|$$$$| \\|g' \ + $$($1_$2_DEP).raw) > $$($1_$2_DEP) endif endif endef From 6ad3839543bc2186f69f26f7a0c7247900425690 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Thu, 2 May 2013 15:59:32 +0200 Subject: [PATCH 49/50] 8013552: Add build support for different man pages for OpenJDK and OracleJDK Reviewed-by: tbell, omajid --- jdk/makefiles/Images.gmk | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/jdk/makefiles/Images.gmk b/jdk/makefiles/Images.gmk index 70a816145b2..2dde16fdf66 100644 --- a/jdk/makefiles/Images.gmk +++ b/jdk/makefiles/Images.gmk @@ -352,16 +352,22 @@ ifneq ($(OPENJDK_TARGET_OS),windows) JDK_MAN_PAGES += jvisualvm.1 endif + ifndef OPENJDK + MAN_SRC_BASEDIR:=$(JDK_TOPDIR)/src/closed + else + MAN_SRC_BASEDIR:=$(JDK_TOPDIR)/src + endif + ifeq ($(OPENJDK_TARGET_OS), linux) - MAN_SRC_DIR:=$(JDK_TOPDIR)/src/linux/doc + MAN_SRC_DIR:=$(MAN_SRC_BASEDIR)/linux/doc MAN1_SUBDIR:=man endif ifeq ($(OPENJDK_TARGET_OS), solaris) - MAN_SRC_DIR:=$(JDK_TOPDIR)/src/solaris/doc + MAN_SRC_DIR:=$(MAN_SRC_BASEDIR)/solaris/doc MAN1_SUBDIR:=sun/man/man1 endif ifeq ($(OPENJDK_TARGET_OS), macosx) - MAN_SRC_DIR:=$(JDK_TOPDIR)/src/bsd/doc + MAN_SRC_DIR:=$(MAN_SRC_BASEDIR)/bsd/doc MAN1_SUBDIR:=man JDK_MAN_PAGES := $(filter-out jcmd.1, $(JDK_MAN_PAGES)) JDK_MAN_PAGES := $(filter-out jvisualvm.1, $(JDK_MAN_PAGES)) From 8a706d1baa7cc173a513898de0e917a408337e9e Mon Sep 17 00:00:00 2001 From: "J. Duke" Date: Wed, 5 Jul 2017 18:52:12 +0200 Subject: [PATCH 50/50] Added tag jdk8-b87 for changeset 5ebf6c63714d --- .hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags b/.hgtags index 6178c6775a6..ba39eb7d401 100644 --- a/.hgtags +++ b/.hgtags @@ -208,3 +208,4 @@ bcebd3fdefc91abb9d7fa0c5af6211b3f8720da6 jdk8-b83 d7ad0dfaa41151bd3a9ae46725b0aec3730a9cd0 jdk8-b84 1872c12529090e1c1dbf567f02ad7ae6231b8f0c jdk8-b85 da9a4c9312816451884aa6db6f18be51a07bff13 jdk8-b86 +5ebf6c63714de2c9dcf831074086d31daec819df jdk8-b87