~louis/ubuntu/trusty/clamav/lp799623_fix_logrotate

« back to all changes in this revision

Viewing changes to libclamav/c++/llvm/lib/CodeGen/ExactHazardRecognizer.h

  • Committer: Bazaar Package Importer
  • Author(s): Scott Kitterman
  • Date: 2010-03-12 11:30:04 UTC
  • mfrom: (0.41.1 upstream)
  • Revision ID: james.westby@ubuntu.com-20100312113004-b0fop4bkycszdd0z
Tags: 0.96~rc1+dfsg-0ubuntu1
* New upstream RC - FFE (LP: #537636):
  - Add OfficialDatabaseOnly option to clamav-base.postinst.in
  - Add LocalSocketGroup option to clamav-base.postinst.in
  - Add LocalSocketMode option to clamav-base.postinst.in
  - Add CrossFilesystems option to clamav-base.postinst.in
  - Add ClamukoScannerCount option to clamav-base.postinst.in
  - Add BytecodeSecurity opiton to clamav-base.postinst.in
  - Add DetectionStatsHostID option to clamav-freshclam.postinst.in
  - Add Bytecode option to clamav-freshclam.postinst.in
  - Add MilterSocketGroup option to clamav-milter.postinst.in
  - Add MilterSocketMode option to clamav-milter.postinst.in
  - Add ReportHostname option to clamav-milter.postinst.in
  - Bump libclamav SO version to 6.1.0 in libclamav6.install
  - Drop clamdmon from clamav.examples (no longer shipped by upstream)
  - Drop libclamav.a from libclamav-dev.install (not built by upstream)
  - Update SO version for lintian override for libclamav6
  - Add new Bytecode Testing Tool, usr/bin/clambc, to clamav.install
  - Add build-depends on python and python-setuptools for new test suite
  - Update debian/copyright for the embedded copy of llvm (using the system
    llvm is not currently feasible)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
//=- llvm/CodeGen/ExactHazardRecognizer.h - Scheduling Support -*- C++ -*-=//
 
2
//
 
3
//                     The LLVM Compiler Infrastructure
 
4
//
 
5
// This file is distributed under the University of Illinois Open Source
 
6
// License. See LICENSE.TXT for details.
 
7
//
 
8
//===----------------------------------------------------------------------===//
 
9
//
 
10
// This file implements the ExactHazardRecognizer class, which
 
11
// implements hazard-avoidance heuristics for scheduling, based on the
 
12
// scheduling itineraries specified for the target.
 
13
//
 
14
//===----------------------------------------------------------------------===//
 
15
 
 
16
#ifndef LLVM_CODEGEN_EXACTHAZARDRECOGNIZER_H
 
17
#define LLVM_CODEGEN_EXACTHAZARDRECOGNIZER_H
 
18
 
 
19
#include "llvm/CodeGen/ScheduleHazardRecognizer.h"
 
20
#include "llvm/CodeGen/ScheduleDAG.h"
 
21
#include "llvm/Target/TargetInstrItineraries.h"
 
22
 
 
23
namespace llvm {
 
24
  class ExactHazardRecognizer : public ScheduleHazardRecognizer {
 
25
    // Itinerary data for the target.
 
26
    const InstrItineraryData &ItinData;
 
27
 
 
28
    // Scoreboard to track function unit usage. Scoreboard[0] is a
 
29
    // mask of the FUs in use in the cycle currently being
 
30
    // schedule. Scoreboard[1] is a mask for the next cycle. The
 
31
    // Scoreboard is used as a circular buffer with the current cycle
 
32
    // indicated by ScoreboardHead.
 
33
    unsigned *Scoreboard;
 
34
 
 
35
    // The maximum number of cycles monitored by the Scoreboard. This
 
36
    // value is determined based on the target itineraries to ensure
 
37
    // that all hazards can be tracked.
 
38
    unsigned ScoreboardDepth;
 
39
 
 
40
    // Indices into the Scoreboard that represent the current cycle.
 
41
    unsigned ScoreboardHead;
 
42
 
 
43
    // Return the scoreboard index to use for 'offset' cycles in the
 
44
    // future. 'offset' of 0 returns ScoreboardHead.
 
45
    unsigned getFutureIndex(unsigned offset);
 
46
 
 
47
    // Print the scoreboard.
 
48
    void dumpScoreboard();
 
49
 
 
50
  public:
 
51
    ExactHazardRecognizer(const InstrItineraryData &ItinData);
 
52
    ~ExactHazardRecognizer();
 
53
    
 
54
    virtual HazardType getHazardType(SUnit *SU);
 
55
    virtual void Reset();
 
56
    virtual void EmitInstruction(SUnit *SU);
 
57
    virtual void AdvanceCycle();
 
58
  };
 
59
}
 
60
 
 
61
#endif