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:
Andreas Hansson 2013-02-19 05:56:06 -05:00
parent d670fa60a1
commit 0acd2a96e5
13 changed files with 53 additions and 3 deletions

View file

@ -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

View file

@ -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;
}; };

View file

@ -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);
}; };

View file

@ -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;
}; };
}}; }};

View file

@ -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.

View file

@ -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);

View file

@ -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;
}; };

View file

@ -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);
}; };

View file

@ -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;
}; };

View file

@ -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.

View file

@ -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);
}; };

View file

@ -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);
}; };

View file

@ -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);
}; };