1
0
mirror of https://github.com/wfjm/w11.git synced 2026-02-07 09:07:45 +00:00
Files
wfjm.w11/tools/src/librlink/RlinkCommandList.hpp
Walter F.J. Mueller 79c565f6f3 more compact dumps, add Dump(..,detail); trace output with cntl name
- RlinkCommand: add CommandInfo()
- RtclCmdBase: add GetArgsDump()
- RlinkCommandList: Dump(): add detail arg
- Rstats: add NameMaxLength(); Print(): add counter name
- Rw11Cntl: use Dump(detail) for PrimClist ect
- Rw11CntlBase,Rw11Rdma*: Dump(): add detail arg
- Rw11Cntl*: Dump(): add detail arg; use cntl name as message prefix
- RtclRw11Cntl: M_dump: use GetArgsDump and Dump detail
2017-04-02 19:06:38 +02:00

104 lines
3.8 KiB
C++

// $Id: RlinkCommandList.hpp 865 2017-04-02 16:45:06Z mueller $
//
// Copyright 2011-2017 by Walter F.J. Mueller <W.F.J.Mueller@gsi.de>
//
// This program is free software; you may redistribute and/or modify it under
// the terms of the GNU General Public License as published by the Free
// Software Foundation, either version 2, or at your option any later version.
//
// This program 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
// for complete details.
//
// Revision History:
// Date Rev Version Comment
// 2017-04-02 865 1.3.1 Dump(): add detail arg
// 2015-04-02 661 1.3 expect logic: add SetLastExpect methods
// 2014-11-23 606 1.2 new rlink v4 iface
// 2014-08-02 576 1.1 rename LastExpect->SetLastExpect
// 2013-05-06 495 1.0.1 add RlinkContext to Print() args; drop oper<<()
// 2011-03-05 366 1.0 Initial version
// 2011-01-09 354 0.1 First draft
// ---------------------------------------------------------------------------
/*!
\file
\version $Id: RlinkCommandList.hpp 865 2017-04-02 16:45:06Z mueller $
\brief Declaration of class RlinkCommandList.
*/
#ifndef included_Retro_RlinkCommandList
#define included_Retro_RlinkCommandList 1
#include <cstddef>
#include <cstdint>
#include <vector>
#include <iostream>
#include "RlinkCommandExpect.hpp"
#include "RlinkCommand.hpp"
#include "RlinkContext.hpp"
#include "RlinkAddrMap.hpp"
namespace Retro {
class RlinkCommandList {
public:
RlinkCommandList();
RlinkCommandList(const RlinkCommandList&);
~RlinkCommandList();
size_t AddCommand(RlinkCommand* cmd);
size_t AddCommand(const RlinkCommand& cmd);
size_t AddCommand(const RlinkCommandList& clist);
size_t AddRreg(uint16_t addr);
size_t AddRblk(uint16_t addr, size_t size);
size_t AddRblk(uint16_t addr, uint16_t* block, size_t size);
size_t AddWreg(uint16_t addr, uint16_t data);
size_t AddWblk(uint16_t addr, std::vector<uint16_t> block);
size_t AddWblk(uint16_t addr, const uint16_t* block, size_t size);
size_t AddLabo();
size_t AddAttn();
size_t AddInit(uint16_t addr, uint16_t data);
void SetLastExpectStatus(uint8_t stat, uint8_t statmsk=0xff);
void SetLastExpectData(uint16_t data, uint16_t datamsk=0xffff);
void SetLastExpectDone(uint16_t done);
void SetLastExpectBlock(const std::vector<uint16_t>& block);
void SetLastExpectBlock(const std::vector<uint16_t>& block,
const std::vector<uint16_t>& blockmsk);
void SetLastExpect(RlinkCommandExpect* exp);
void ClearLaboIndex();
void SetLaboIndex(int ind);
int LaboIndex() const;
bool LaboActive() const;
void Clear();
size_t Size() const;
void Print(std::ostream& os, const RlinkAddrMap* pamap=0,
size_t abase=16, size_t dbase=16,
size_t sbase=16) const;
void Dump(std::ostream& os, int ind=0, const char* text=0,
int detail=0) const;
RlinkCommandList& operator=(const RlinkCommandList& rhs);
RlinkCommand& operator[](size_t ind);
const RlinkCommand& operator[](size_t ind) const;
protected:
std::vector<RlinkCommand*> fList; //!< vector of commands
int fLaboIndex; //!< index of active labo (-1 if no)
};
} // end namespace Retro
#include "RlinkCommandList.ipp"
#endif