libopenraw  0.3.7
peffile.cpp
1 /*
2  * libopenraw - peffile.cpp
3  *
4  * Copyright (C) 2006-2022 Hubert Figuière
5  *
6  * This library is free software: you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public License
8  * as published by the Free Software Foundation, either version 3 of
9  * the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library. If not, see
18  * <http://www.gnu.org/licenses/>.
19  */
20 
21 
22 #include <libopenraw/cameraids.h>
23 
24 #include "rawdata.hpp"
25 #include "ifd.hpp"
26 #include "ifdfilecontainer.hpp"
27 #include "ifddir.hpp"
28 #include "peffile.hpp"
29 #include "rawfile_private.hpp"
30 
31 using namespace Debug;
32 
33 namespace OpenRaw {
34 namespace Internals {
35 
36 #define OR_MAKE_PENTAX_TYPEID(camid) \
37  OR_MAKE_FILE_TYPEID(OR_TYPEID_VENDOR_PENTAX,camid)
38 #define OR_MAKE_RICOH_TYPEID(camid) \
39  OR_MAKE_FILE_TYPEID(OR_TYPEID_VENDOR_RICOH,camid)
40 
41 static const ModelIdMap modelid_map = {
42  { 0x12994, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_D_PEF) },
43  { 0x12aa2, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DS_PEF) },
44  { 0x12b1a, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL_PEF) },
45  // *ist DS2
46  { 0x12b7e, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL2_PEF) },
47  { 0x12b9c, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_PEF) },
48  { 0x12b9d, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K110D_PEF) },
49  { 0x12ba2, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_SUPER_PEF) },
50  { 0x12c1e, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K10D_PEF) },
51  { 0x12cd2, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K20D_PEF) },
52  { 0x12cfa, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K200D_PEF) },
53  { 0x12d72, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K2000_PEF) },
54  { 0x12d73, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KM_PEF) },
55  { 0x12db8, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K7_PEF) },
56  { 0x12dfe, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KX_PEF) },
57  { 0x12e08, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_645D_PEF) },
58  { 0x12e6c, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KR_PEF) },
59  { 0x12e76, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_PEF) },
60  // Q
61  // K-01
62  // K-30
63  // Q10
64  { 0x12f70, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_II_PEF) },
65  { 0x12f71, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_IIS_PEF) },
66  // Q7
67  // K-50
68  { 0x12fc0, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_PEF) },
69  // K-500
70  { 0x13010, OR_MAKE_RICOH_TYPEID(OR_TYPEID_PENTAX_645Z_PEF) },
71  { 0x1301a, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS1_PEF) },
72  { 0x13024, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS2_PEF) },
73  // Q-S1
74  { 0x13092, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_PEF) },
75  { 0x1309c, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_II_PEF) },
76  // GR III
77  { 0x13222, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K70_PEF) },
78  { 0x1322c, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KP_PEF) },
79  { 0x13240, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_MKII_PEF) },
80  { 0x13254, OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_MKIII_PEF) },
81 };
82 
83 /* taken from dcraw, by default */
84 static const BuiltinColourMatrix s_matrices[] = {
85  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_D_PEF),
86  0,
87  0,
88  { 9651, -2059, -1189, -8881, 16512, 2487, -1460, 1345, 10687 } },
89  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL_PEF),
90  0,
91  0,
92  { 10829, -2838, -1115, -8339, 15817, 2696, -837, 680, 11939 } },
93  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL2_PEF),
94  0,
95  0,
96  { 10504, -2439, -1189, -8603, 16208, 2531, -1022, 863, 12242 } },
97  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DS_PEF),
98  0,
99  0,
100  { 10371, -2333, -1206, -8688, 16231, 2602, -1230, 1116, 11282 } },
101  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K10D_PEF),
102  0,
103  0,
104  { 9566, -2863, -803, -7170, 15172, 2112, -818, 803, 9705 } },
105  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_PEF),
106  0,
107  0,
108  { 8566, -2746, -1201, -3612, 12204, 1550, -893, 1680, 6264 } },
109  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_MKII_PEF),
110  0,
111  0,
112  { 8596, -2981, -639, -4202, 12046, 2431, -685, 1424, 6122 } },
113  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_PEF),
114  0,
115  0,
116  { 11095, -3157, -1324, -8377, 15834, 2720, -1108, 947, 11688 } },
117  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_SUPER_PEF),
118  0,
119  0,
120  { 11095, -3157, -1324, -8377, 15834, 2720, -1108, 947, 11688 } },
121  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K110D_PEF),
122  0,
123  0,
124  { 11095, -3157, -1324, -8377, 15834, 2720, -1108, 947, 11688 } },
125  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K20D_PEF),
126  0,
127  0,
128  { 9427, -2714, -868, -7493, 16092, 1373, -2199, 3264, 7180 } },
129  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K200D_PEF),
130  0,
131  0,
132  { 9186, -2678, -907, -8693, 16517, 2260, -1129, 1094, 8524 } },
133  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K2000_PEF),
134  0,
135  0,
136  { 9730, -2989, -970, -8527, 16258, 2381, -1060, 970, 8362 } },
137  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KR_PEF),
138  0,
139  0,
140  { 9895, -3077, -850, -5304, 13035, 2521, -883, 1768, 6936 } },
141  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_PEF),
142  0,
143  0,
144  { 8542, -2581, -1144, -3995, 12301, 1881, -863, 1514, 5755 } },
145  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_II_PEF),
146  0,
147  0,
148  { 9251, -3817, -1069, -4627, 12667, 2175, -798, 1660, 5633 } },
149  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_MKIII_PEF),
150  0,
151  0,
152  { 8571, -2590, -1148, -3995, 12301, 1881, -1052, 1844, 7013 } },
153  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_PEF),
154  0,
155  0,
156  { 8713, -2833, -743, -4342, 11900, 2772, -722, 1543, 6247 } },
157  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_II_PEF),
158  0,
159  0,
160  { 8435, -2549, -1130, -3995, 12301, 1881, -989, 1734, 6591 } },
161  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_IIS_PEF),
162  0,
163  0,
164  { 8170, -2725, -639, -4440, 12017, 2744, -771, 1465, 6599 } },
165  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K7_PEF),
166  0,
167  0,
168  { 9142, -2947, -678, -8648, 16967, 1663, -2224, 2898, 8615 } },
169  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K70_PEF),
170  0,
171  0,
172  { 8766, -3149, -747, -3976, 11943, 2292, -517, 1259, 5552 } },
173  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KM_PEF),
174  0,
175  0,
176  { 9730, -2989, -970, -8527, 16258, 2381, -1060, 970, 8362 } },
177  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KX_PEF),
178  0,
179  0,
180  { 8843, -2837, -625, -5025, 12644, 2668, -411, 1234, 7410 } },
181  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS1_PEF),
182  0,
183  0,
184  { 7989, -2511, -1137, -3882, 12350, 1689, -862, 1524, 6444 } },
185  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS2_PEF),
186  0,
187  0,
188  { 8662, -3280, -798, -3928, 11771, 2444, -586, 1232, 6054 } },
189  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KP_PEF),
190  0,
191  0,
192  { 8617, -3228, -1034, -4674, 12821, 2044, -803, 1577, 5728 } },
193  { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_645D_PEF),
194  0,
195  0x3e00,
196  { 10646, -3593, -1158, -3329, 11699, 1831, -667, 2874, 6287 } },
197  { OR_MAKE_RICOH_TYPEID(OR_TYPEID_PENTAX_645Z_PEF),
198  0,
199  0x3fff,
200  { 9519, -3591, -664, -4074, 11725, 2671, -624, 1501, 6653 } },
201 
202  { 0, 0, 0, { 0, 0, 0, 0, 0, 0, 0, 0, 0 } }
203 };
204 
205 const struct IfdFile::camera_ids_t PEFFile::s_def[] = {
206  { "PENTAX *ist D ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_D_PEF) },
207  { "PENTAX *ist DL ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL_PEF) },
208  { "PENTAX *ist DL2 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL2_PEF) },
209  { "PENTAX *ist DS ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DS_PEF) },
210  { "PENTAX K10D ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K10D_PEF) },
211  { "PENTAX K100D ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_PEF) },
212  { "PENTAX K100D Super ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_SUPER_PEF) },
213  { "PENTAX K110D ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K110D_PEF) },
214  { "PENTAX K20D ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K20D_PEF) },
215  { "PENTAX K200D ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K200D_PEF) },
216  { "PENTAX K2000 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K2000_PEF) },
217  { "PENTAX K-1 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_PEF) },
218  { "PENTAX K-1 Mark II ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_MKII_PEF) },
219  { "PENTAX K-r ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KR_PEF) },
220  { "PENTAX K-3 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_PEF) },
221  { "PENTAX K-3 II ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_II_PEF) },
222  { "PENTAX K-3 Mark III ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K3_MKIII_PEF) },
223  { "PENTAX K-5 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_PEF) },
224  { "PENTAX K-5 II ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_II_PEF) },
225  { "PENTAX K-5 II s ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_IIS_PEF) },
226  { "PENTAX K-7 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K7_PEF) },
227  { "PENTAX K-70 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K70_PEF) },
228  { "PENTAX K-S1 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS1_PEF) },
229  { "PENTAX K-S2 ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS2_PEF) },
230  { "PENTAX K-m ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KM_PEF) },
231  { "PENTAX K-x ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KX_PEF) },
232  { "PENTAX KP ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KP_PEF) },
233  { "PENTAX 645D ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_645D_PEF) },
234  { "PENTAX 645Z ", OR_MAKE_RICOH_TYPEID(OR_TYPEID_PENTAX_645Z_PEF) },
235  { 0, 0 }
236 };
237 
238 
239 RawFile *PEFFile::factory(const IO::Stream::Ptr &s)
240 {
241  return new PEFFile(s);
242 }
243 
244 PEFFile::PEFFile(const IO::Stream::Ptr &s)
245  : IfdFile(s, OR_RAWFILE_TYPE_PEF)
246 {
247  _setIdMap(s_def);
248  _setMatrices(s_matrices);
249 }
250 
251 PEFFile::~PEFFile()
252 {
253 }
254 
255 ::or_error PEFFile::_enumThumbnailSizes(std::vector<uint32_t> &list)
256 {
257  auto err = this->IfdFile::_enumThumbnailSizes(list);
258  auto makerNote = makerNoteIfd();
259  if (makerNote) {
260  auto e = makerNote->getEntry(MNOTE_PENTAX_PREVIEW_IMAGE_SIZE);
261  if (e) {
262  auto w = makerNote->getEntryValue<uint16_t>(*e, 0);
263  auto h = makerNote->getEntryValue<uint16_t>(*e, 1);
264  auto dim = std::max(w, h);
265  list.push_back(dim);
266 
267  auto offset = makerNote->getIntegerValue(MNOTE_PENTAX_PREVIEW_IMAGE_START).value_or(0);
268  if (offset > 0) {
269  offset += makerNote->getMnoteOffset();
270  }
271  auto length = makerNote->getIntegerValue(MNOTE_PENTAX_PREVIEW_IMAGE_LENGTH).value_or(0);
272  if (offset != 0 && length != 0) {
273  _addThumbnail(dim, ThumbDesc(w, h, OR_DATA_TYPE_JPEG, offset, length));
274  err = OR_ERROR_NONE;
275  }
276  }
277 
278  }
279 
280  return err;
281 }
282 
284  const ModelIdMap*& model_map)
285 {
286  auto mn = makerNoteIfd();
287  if (mn) {
288  // There is a camera model ID in the MakerNote tag 0x0010.
289  ifd = mn;
290  index = IFD::MNOTE_PENTAX_MODEL_ID;
291  model_map = &modelid_map;
292  return true;
293  }
294  return false;
295 }
296 
297 ::or_error PEFFile::_getRawData(RawData & data, uint32_t options)
298 {
299  ::or_error err;
300  const IfdDir::Ref & _cfaIfd = cfaIfd();
301  err = _getRawDataFromDir(data, _cfaIfd);
302  if (err == OR_ERROR_NONE) {
303  auto mnote = makerNoteIfd();
304  auto offset = mnote->getEntry(MNOTE_PENTAX_IMAGEAREAOFFSET);
305  if (offset) {
306  auto x = mnote->getEntryValue<uint16_t>(*offset, 0);
307  auto y = mnote->getEntryValue<uint16_t>(*offset, 1);
308  auto image_size = mnote->getEntry(MNOTE_PENTAX_RAWIMAGESIZE);
309  if (image_size) {
310  auto w = mnote->getEntryValue<uint16_t>(*image_size, 0);
311  auto h = mnote->getEntryValue<uint16_t>(*image_size, 1);
312  data.setActiveArea(x, y, w, h);
313  }
314  }
315 
316  auto white_level = mnote->getIntegerValue(MNOTE_PENTAX_WHITELEVEL);
317  if (white_level) {
318  data.setWhiteLevel(white_level.value());
319  }
320 
321  uint16_t compression = data.compression();
322  switch(compression) {
324  if((options & OR_OPTIONS_DONT_DECOMPRESS) == 0) {
325  // TODO decompress
326  }
327  break;
329  break;
330  case IFD::COMPRESS_NONE:
331  {
332  // Pentax a big endian. This should be done in _getRawDataFromDir() according
333  // to the container endian.
334  auto p = data.data();
335  uint16_t* pixels = (uint16_t*)p;
336  for (size_t i = 0; i < data.size() / 2; i++) {
337  *pixels = be16toh(*pixels);
338  pixels++;
339  }
340  }
341  break;
342 
343  default:
344  break;
345  }
346  }
347  return err;
348 }
349 
350 }
351 }
352 /*
353  Local Variables:
354  mode:c++
355  c-file-style:"stroustrup"
356  c-file-offsets:((innamespace . 0))
357  indent-tabs-mode:nil
358  fill-column:80
359  End:
360 */
361 
size_t size() const
Get the size of the data.
Definition: bitmapdata.cpp:120
std::shared_ptr< Stream > Ptr
Definition: stream.hpp:47
std::shared_ptr< IfdDir > Ref
Shared ptr of an IfdDir.
Definition: ifddir.hpp:56
virtual ::or_error _enumThumbnailSizes(std::vector< uint32_t > &list) override
List the thumbnails in the IFD.
Definition: ifdfile.cpp:173
::or_error _getRawDataFromDir(RawData &data, const IfdDir::Ref &dir)
Load the compressed raw data from a standard location in an IFD.
Definition: ifdfile.cpp:533
Represent camera raw data.
Definition: rawdata.hpp:38
RAW file.
Definition: rawfile.hpp:66
Internals::MakerNoteDir::Ref makerNoteIfd()
Get the MakerNote IFD.
Definition: rawfile.cpp:724
Internals::IfdDir::Ref cfaIfd()
Get the IFD containing the CFA.
Definition: rawfile.cpp:696
or_error
Error codes returned by libopenraw.
Definition: consts.h:42
@ OR_DATA_TYPE_JPEG
Definition: consts.h:84
@ OR_OPTIONS_DONT_DECOMPRESS
Definition: consts.h:114
@ OR_RAWFILE_TYPE_PEF
Definition: consts.h:68
@ OR_ERROR_NONE
Definition: consts.h:43
std::map< uint32_t, ::or_rawfile_typeid > ModelIdMap
Definition: rawfile.hpp:54
Global namespace for libopenraw.
Definition: arwfile.cpp:29
virtual ::or_error _getRawData(RawData &data, uint32_t options) override
Get the RAW data.
Definition: peffile.cpp:297
virtual bool vendorCameraIdLocation(Internals::IfdDir::Ref &ifd, uint16_t &index, const Internals::ModelIdMap *&model_map) override
Get the vendor camera ID location.
Definition: peffile.cpp:283
virtual ::or_error _enumThumbnailSizes(std::vector< uint32_t > &list) override
List the thumbnails in the IFD.
Definition: peffile.cpp:255