OpenCores
URL https://opencores.org/ocsvn/w11/w11/trunk

Subversion Repositories w11

[/] [w11/] [tags/] [w11a_V0.61/] [tools/] [src/] [librw11/] [Rw11VirtDiskFile.cpp] - Blame information for rev 40

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 21 wfjm
// $Id: Rw11VirtDiskFile.cpp 516 2013-05-05 21:24:52Z mueller $
2 20 wfjm
//
3
// Copyright 2013- by Walter F.J. Mueller <W.F.J.Mueller@gsi.de>
4
//
5
// This program is free software; you may redistribute and/or modify it under
6
// the terms of the GNU General Public License as published by the Free
7
// Software Foundation, either version 2, or at your option any later version.
8
//
9
// This program is distributed in the hope that it will be useful, but
10
// WITHOUT ANY WARRANTY, without even the implied warranty of MERCHANTABILITY
11
// or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12
// for complete details.
13
// 
14
// Revision History: 
15
// Date         Rev Version  Comment
16
// 2013-04-14   506   1.0    Initial version
17
// 2013-02-13   488   0.1    First draft
18
// ---------------------------------------------------------------------------
19
 
20
/*!
21
  \file
22 21 wfjm
  \version $Id: Rw11VirtDiskFile.cpp 516 2013-05-05 21:24:52Z mueller $
23 20 wfjm
  \brief   Implemenation of Rw11VirtDiskFile.
24
*/
25
 
26
#include <sys/types.h>
27
#include <sys/stat.h>
28
#include <fcntl.h>
29
#include <unistd.h>
30
 
31
#include "librtools/RosFill.hpp"
32
 
33
#include "Rw11VirtDiskFile.hpp"
34
 
35
using namespace std;
36
 
37
/*!
38
  \class Retro::Rw11VirtDiskFile
39
  \brief FIXME_docs
40
*/
41
 
42
// all method definitions in namespace Retro
43
namespace Retro {
44
 
45
//------------------------------------------+-----------------------------------
46
//! Default constructor
47
 
48
Rw11VirtDiskFile::Rw11VirtDiskFile(Rw11Unit* punit)
49
  : Rw11VirtDisk(punit),
50
    fFd(0)
51
{}
52
 
53
//------------------------------------------+-----------------------------------
54
//! Destructor
55
 
56
Rw11VirtDiskFile::~Rw11VirtDiskFile()
57
{
58
  if (fFd > 2) ::close(fFd);
59
}
60
 
61
//------------------------------------------+-----------------------------------
62
//! FIXME_docs
63
 
64
bool Rw11VirtDiskFile::Open(const std::string& url, RerrMsg& emsg)
65
{
66
  if (!fUrl.Set(url, "|wpro|", emsg)) return false;
67
 
68
  bool wpro = fUrl.FindOpt("wpro");
69
 
70
  int fd = ::open(fUrl.Path().c_str(), wpro ? O_RDONLY : O_RDWR);
71
  if (fd < 0) {
72
    emsg.InitErrno("Rw11VirtDiskFile::Open()",
73 21 wfjm
                   string("open() for '") + fUrl.Path() + "' failed: ", errno);
74 20 wfjm
    return false;
75
  }
76
 
77
  struct stat sbuf;
78
  if (::fstat(fd, &sbuf) < 0) {
79
    emsg.InitErrno("Rw11VirtDiskFile::Open()",
80 21 wfjm
                   string("stat() for '") + fUrl.Path() + "' failed: ", errno);
81 20 wfjm
    return false;
82
  }
83
 
84
  fFd = fd;
85
  fSize = sbuf.st_size;
86
  return true;
87
}
88
 
89
//------------------------------------------+-----------------------------------
90
//! FIXME_docs
91
 
92
bool Rw11VirtDiskFile::Read(size_t lba, size_t nblk, uint8_t* data,
93
                            RerrMsg& emsg)
94
{
95
  fStats.Inc(kStatNVDRead);
96
  fStats.Inc(kStatNVDReadBlk, double(nblk));
97
 
98
  size_t seekpos = fBlkSize * lba;
99
  size_t nbyt    = fBlkSize * nblk;
100
 
101
  if (seekpos >= fSize) {
102
    uint8_t* p = data;
103
    for (size_t i=0; i<nbyt; i++) *p++ = 0;
104
    return true;
105
  }
106
 
107
  if (!Seek(seekpos, emsg)) return false;
108
 
109
  ssize_t irc = ::read(fFd, data, nbyt);
110
  if (irc < 0) {
111
    emsg.InitErrno("Rw11VirtDiskFile::Read()", "read() failed: ", errno);
112
    return false;
113
  }
114
 
115
  if (irc < ssize_t(nbyt)) {
116
    uint8_t* p = data+irc;
117
    for (size_t i=irc; i<nbyt; i++) *p++ = 0;
118
  }
119
 
120
  return true;
121
}
122
 
123
//------------------------------------------+-----------------------------------
124
//! FIXME_docs
125
 
126
bool Rw11VirtDiskFile::Write(size_t lba, size_t nblk, const uint8_t* data,
127
                             RerrMsg& emsg)
128
{
129
  fStats.Inc(kStatNVDWrite);
130
  fStats.Inc(kStatNVDWriteBlk, double(nblk));
131
 
132
  size_t seekpos = fBlkSize * lba;
133
  size_t nbyt    = fBlkSize * nblk;
134
 
135
  if (!Seek(seekpos, emsg)) return false;
136
 
137
  ssize_t irc = ::write(fFd, data, nbyt);
138
  if (irc < ssize_t(nbyt)) {
139 21 wfjm
    emsg.InitErrno("Rw11VirtDiskFile::Write()", "write() failed: ", errno);
140 20 wfjm
    return false;
141
  }
142
 
143
  if (seekpos+nbyt > fSize) fSize = seekpos+nbyt;
144
 
145
  return true;
146
}
147
 
148
//------------------------------------------+-----------------------------------
149
//! FIXME_docs
150
 
151
bool Rw11VirtDiskFile::Seek(size_t seekpos, RerrMsg& emsg)
152
{
153
  if (::lseek(fFd, seekpos, SEEK_SET) < 0) {
154 21 wfjm
    emsg.InitErrno("Rw11VirtDiskFile::Seek()", "seek() failed: ", errno);
155 20 wfjm
    return false;
156
  }
157
 
158
  return true;
159
}
160
 
161
//------------------------------------------+-----------------------------------
162
//! FIXME_docs
163
 
164
void Rw11VirtDiskFile::Dump(std::ostream& os, int ind, const char* text) const
165
{
166
  RosFill bl(ind);
167
  os << bl << (text?text:"--") << "Rw11VirtDiskFile @ " << this << endl;
168
 
169
  os << bl << "  fFd:             " << fFd << endl;
170
  Rw11VirtDisk::Dump(os, ind, " ^");
171
  return;
172
}
173
 
174
} // end namespace Retro

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.