scons: Add warning for overloaded virtual functions
A derived function with a different signature than a base class function will result in the base class function of the same name being hidden. The parameter list and return type for the member function in the derived class must match those of the member function in the base class, otherwise the function in the derived class will hide the function in the base class and no polymorphic behaviour will occur. This patch addresses these warnings by ensuring a unique function name to avoid (unintentionally) hiding any functions.
This commit is contained in:
parent
d670fa60a1
commit
0acd2a96e5
13 changed files with 53 additions and 3 deletions
|
@ -528,7 +528,8 @@ if main['GCC']:
|
||||||
main.Append(CCFLAGS=['-pipe'])
|
main.Append(CCFLAGS=['-pipe'])
|
||||||
main.Append(CCFLAGS=['-fno-strict-aliasing'])
|
main.Append(CCFLAGS=['-fno-strict-aliasing'])
|
||||||
main.Append(CCFLAGS=['-Wall', '-Wno-sign-compare', '-Wundef'])
|
main.Append(CCFLAGS=['-Wall', '-Wno-sign-compare', '-Wundef'])
|
||||||
main.Append(CXXFLAGS=['-Wmissing-field-initializers'])
|
main.Append(CXXFLAGS=['-Wmissing-field-initializers',
|
||||||
|
'-Woverloaded-virtual'])
|
||||||
main.Append(CXXFLAGS=['-std=c++0x'])
|
main.Append(CXXFLAGS=['-std=c++0x'])
|
||||||
|
|
||||||
# Check for versions with bugs
|
# Check for versions with bugs
|
||||||
|
@ -578,7 +579,8 @@ elif main['CLANG']:
|
||||||
# Ruby makes frequent use of extraneous parantheses in the printing
|
# Ruby makes frequent use of extraneous parantheses in the printing
|
||||||
# of if-statements
|
# of if-statements
|
||||||
main.Append(CCFLAGS=['-Wno-parentheses'])
|
main.Append(CCFLAGS=['-Wno-parentheses'])
|
||||||
main.Append(CXXFLAGS=['-Wmissing-field-initializers'])
|
main.Append(CXXFLAGS=['-Wmissing-field-initializers',
|
||||||
|
'-Woverloaded-virtual'])
|
||||||
main.Append(CXXFLAGS=['-std=c++0x'])
|
main.Append(CXXFLAGS=['-std=c++0x'])
|
||||||
# On Mac OS X/Darwin we need to also use libc++ (part of XCode) as
|
# On Mac OS X/Darwin we need to also use libc++ (part of XCode) as
|
||||||
# opposed to libstdc++ to make the transition from TR1 to
|
# opposed to libstdc++ to make the transition from TR1 to
|
||||||
|
|
|
@ -83,6 +83,9 @@ output header {{
|
||||||
|
|
||||||
AlphaISA::PCState branchTarget(const AlphaISA::PCState &branchPC) const;
|
AlphaISA::PCState branchTarget(const AlphaISA::PCState &branchPC) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string
|
std::string
|
||||||
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
@ -108,6 +111,9 @@ output header {{
|
||||||
|
|
||||||
AlphaISA::PCState branchTarget(ThreadContext *tc) const;
|
AlphaISA::PCState branchTarget(ThreadContext *tc) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string
|
std::string
|
||||||
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
|
|
@ -49,6 +49,8 @@ class AlphaLiveProcess : public LiveProcess
|
||||||
|
|
||||||
public:
|
public:
|
||||||
AlphaISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
AlphaISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using LiveProcess::getSyscallArg;
|
||||||
void setSyscallArg(ThreadContext *tc, int i, AlphaISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, AlphaISA::IntReg val);
|
||||||
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
||||||
};
|
};
|
||||||
|
|
|
@ -74,6 +74,9 @@ class %(class_name)s : public %(base_class)s
|
||||||
ConditionCode _condCode);
|
ConditionCode _condCode);
|
||||||
%(BasicExecDeclare)s
|
%(BasicExecDeclare)s
|
||||||
ArmISA::PCState branchTarget(const ArmISA::PCState &branchPC) const;
|
ArmISA::PCState branchTarget(const ArmISA::PCState &branchPC) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
};
|
};
|
||||||
}};
|
}};
|
||||||
|
|
||||||
|
|
|
@ -45,6 +45,8 @@ class ArmLinuxProcess : public ArmLiveProcess
|
||||||
void initState();
|
void initState();
|
||||||
|
|
||||||
ArmISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
ArmISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using ArmLiveProcess::getSyscallArg;
|
||||||
void setSyscallArg(ThreadContext *tc, int i, ArmISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, ArmISA::IntReg val);
|
||||||
|
|
||||||
/// The target system's hostname.
|
/// The target system's hostname.
|
||||||
|
|
|
@ -53,7 +53,7 @@ class ArmLiveProcess : public LiveProcess
|
||||||
public:
|
public:
|
||||||
void argsInit(int intSize, int pageSize);
|
void argsInit(int intSize, int pageSize);
|
||||||
|
|
||||||
uint64_t getSyscallArg(ThreadContext *tc, int &i, int width);
|
ArmISA::IntReg getSyscallArg(ThreadContext *tc, int &i, int width);
|
||||||
ArmISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
ArmISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
void setSyscallArg(ThreadContext *tc, int i, ArmISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, ArmISA::IntReg val);
|
||||||
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
||||||
|
|
|
@ -91,6 +91,9 @@ output header {{
|
||||||
|
|
||||||
MipsISA::PCState branchTarget(const MipsISA::PCState &branchPC) const;
|
MipsISA::PCState branchTarget(const MipsISA::PCState &branchPC) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string
|
std::string
|
||||||
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
@ -118,6 +121,9 @@ output header {{
|
||||||
|
|
||||||
MipsISA::PCState branchTarget(ThreadContext *tc) const;
|
MipsISA::PCState branchTarget(ThreadContext *tc) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string
|
std::string
|
||||||
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
|
|
@ -53,6 +53,8 @@ class MipsLiveProcess : public LiveProcess
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MipsISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
MipsISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using LiveProcess::getSyscallArg;
|
||||||
void setSyscallArg(ThreadContext *tc, int i, MipsISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, MipsISA::IntReg val);
|
||||||
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
||||||
};
|
};
|
||||||
|
|
|
@ -88,6 +88,9 @@ class BranchPCRel : public PCDependentDisassembly
|
||||||
|
|
||||||
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -114,6 +117,9 @@ class BranchNonPCRel : public PCDependentDisassembly
|
||||||
|
|
||||||
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -189,6 +195,9 @@ class BranchPCRelCond : public BranchCond
|
||||||
|
|
||||||
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -215,6 +224,9 @@ class BranchNonPCRelCond : public BranchCond
|
||||||
|
|
||||||
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
PowerISA::PCState branchTarget(const PowerISA::PCState &pc) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -233,6 +245,9 @@ class BranchRegCond : public BranchCond
|
||||||
|
|
||||||
PowerISA::PCState branchTarget(ThreadContext *tc) const;
|
PowerISA::PCState branchTarget(ThreadContext *tc) const;
|
||||||
|
|
||||||
|
/// Explicitly import the otherwise hidden branchTarget
|
||||||
|
using StaticInst::branchTarget;
|
||||||
|
|
||||||
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
std::string generateDisassembly(Addr pc, const SymbolTable *symtab) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -46,6 +46,8 @@ class PowerLinuxProcess : public PowerLiveProcess
|
||||||
void initState();
|
void initState();
|
||||||
|
|
||||||
PowerISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
PowerISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using LiveProcess::getSyscallArg;
|
||||||
void setSyscallArg(ThreadContext *tc, int i, PowerISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, PowerISA::IntReg val);
|
||||||
|
|
||||||
/// Array of syscall descriptors, indexed by call number.
|
/// Array of syscall descriptors, indexed by call number.
|
||||||
|
|
|
@ -52,6 +52,8 @@ class PowerLiveProcess : public LiveProcess
|
||||||
public:
|
public:
|
||||||
void argsInit(int intSize, int pageSize);
|
void argsInit(int intSize, int pageSize);
|
||||||
PowerISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
PowerISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using LiveProcess::getSyscallArg;
|
||||||
void setSyscallArg(ThreadContext *tc, int i, PowerISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, PowerISA::IntReg val);
|
||||||
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value);
|
||||||
};
|
};
|
||||||
|
|
|
@ -94,6 +94,9 @@ class Sparc32LiveProcess : public SparcLiveProcess
|
||||||
void flushWindows(ThreadContext *tc);
|
void flushWindows(ThreadContext *tc);
|
||||||
|
|
||||||
SparcISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
SparcISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using LiveProcess::getSyscallArg;
|
||||||
|
|
||||||
void setSyscallArg(ThreadContext *tc, int i, SparcISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, SparcISA::IntReg val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -122,6 +125,9 @@ class Sparc64LiveProcess : public SparcLiveProcess
|
||||||
void flushWindows(ThreadContext *tc);
|
void flushWindows(ThreadContext *tc);
|
||||||
|
|
||||||
SparcISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
SparcISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using LiveProcess::getSyscallArg;
|
||||||
|
|
||||||
void setSyscallArg(ThreadContext *tc, int i, SparcISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, SparcISA::IntReg val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -103,6 +103,8 @@ namespace X86ISA
|
||||||
void initState();
|
void initState();
|
||||||
|
|
||||||
X86ISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
X86ISA::IntReg getSyscallArg(ThreadContext *tc, int &i);
|
||||||
|
/// Explicitly import the otherwise hidden getSyscallArg
|
||||||
|
using LiveProcess::getSyscallArg;
|
||||||
void setSyscallArg(ThreadContext *tc, int i, X86ISA::IntReg val);
|
void setSyscallArg(ThreadContext *tc, int i, X86ISA::IntReg val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue