DSPAnalyzer: Add basic class skeleton
Adds the non-functional skeleton for the to-be Analyzer interface with deglobalized components.
This commit is contained in:
parent
3f68aceaca
commit
8f4c6ad7b1
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <array>
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
|
|
||||||
namespace DSP
|
namespace DSP
|
||||||
|
@ -17,8 +18,9 @@ namespace DSP::Analyzer
|
||||||
// Useful things to detect:
|
// Useful things to detect:
|
||||||
// * Loop endpoints - so that we can avoid checking for loops every cycle.
|
// * Loop endpoints - so that we can avoid checking for loops every cycle.
|
||||||
|
|
||||||
enum
|
enum CodeFlags : u8
|
||||||
{
|
{
|
||||||
|
CODE_NONE = 0,
|
||||||
CODE_START_OF_INST = 1,
|
CODE_START_OF_INST = 1,
|
||||||
CODE_IDLE_SKIP = 2,
|
CODE_IDLE_SKIP = 2,
|
||||||
CODE_LOOP_START = 4,
|
CODE_LOOP_START = 4,
|
||||||
|
@ -27,6 +29,44 @@ enum
|
||||||
CODE_CHECK_INT = 32,
|
CODE_CHECK_INT = 32,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class Analyzer
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit Analyzer(const SDSP& dsp);
|
||||||
|
~Analyzer();
|
||||||
|
|
||||||
|
Analyzer(const Analyzer&) = default;
|
||||||
|
Analyzer& operator=(const Analyzer&) = delete;
|
||||||
|
|
||||||
|
Analyzer(Analyzer&&) = default;
|
||||||
|
Analyzer& operator=(Analyzer&&) = delete;
|
||||||
|
|
||||||
|
// This one should be called every time IRAM changes - which is basically
|
||||||
|
// every time that a new ucode gets uploaded, and never else. At that point,
|
||||||
|
// we can do as much static analysis as we want - but we should always throw
|
||||||
|
// all old analysis away. Luckily the entire address space is only 64K code
|
||||||
|
// words and the actual code space 8K instructions in total, so we can do
|
||||||
|
// some pretty expensive analysis if necessary.
|
||||||
|
void Analyze();
|
||||||
|
|
||||||
|
// Retrieves the flags set during analysis for code in memory.
|
||||||
|
[[nodiscard]] u8 GetCodeFlags(u16 address) const { return m_code_flags[address]; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
// Flushes all analyzed state.
|
||||||
|
void Reset();
|
||||||
|
|
||||||
|
// Analyzes a region of DSP memory.
|
||||||
|
// Note: start is inclusive, end is exclusive.
|
||||||
|
void AnalyzeRange(u16 start_addr, u16 end_addr);
|
||||||
|
|
||||||
|
// Holds data about all instructions in RAM.
|
||||||
|
std::array<u8, 65536> m_code_flags{};
|
||||||
|
|
||||||
|
// DSP context for analysis to be run under.
|
||||||
|
const SDSP& m_dsp;
|
||||||
|
};
|
||||||
|
|
||||||
// This one should be called every time IRAM changes - which is basically
|
// This one should be called every time IRAM changes - which is basically
|
||||||
// every time that a new ucode gets uploaded, and never else. At that point,
|
// every time that a new ucode gets uploaded, and never else. At that point,
|
||||||
// we can do as much static analysis as we want - but we should always throw
|
// we can do as much static analysis as we want - but we should always throw
|
||||||
|
|
Loading…
Reference in New Issue