File: qscan_cmd.cpp

package info (click to toggle)
qpxtool 0.8.1-2.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,796 kB
  • sloc: cpp: 35,365; sh: 823; makefile: 336; sql: 87
file content (130 lines) | stat: -rw-r--r-- 2,835 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
/*
 * qscan plugin for ASUS drives:
 *	1612
 *	1814
 *	2014S1
 *	2014L1
 *
 * This file is part of the QPxTool project.
 * Copyright (C) 2008-2009 Gennady "ShultZ" Kozlov <qpxtool@mail.ru>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 * See the file "COPYING" for the exact licensing terms.
 */

#include <stdio.h>
#include <stdlib.h>

#include <qpx_transport.h>
#include <qpx_mmc.h>
#include <common_functions.h>

#include <qscan_plugin.h>

int scan_asus::probe_drive()
{
	dev->cmd[0] = 0x5A;
	dev->cmd[2] = 0x38;
	dev->cmd[3] = 0x41;
	dev->cmd[4] = 0x53;
	dev->cmd[5] = 0x10;
	dev->cmd[9] = 0x04;
	if ((dev->err=dev->cmd.transport(READ, dev->rd_buf, 20))){
		sperror ("asus_probe",dev->err); return DEV_FAIL;
	}
	if (strncmp((char*)dev->rd_buf,"ASUS",4)) return DEV_FAIL;
	return DEV_PROBED;
}

// ************* Scan init commands *********
int scan_asus::cmd_errc_init()
{
	/* initialize scan mode */
	dev->cmd[0] = 0x5A;
	dev->cmd[2] = 0x38;
	dev->cmd[3] = 0x41;
	dev->cmd[4] = 0x53;
	dev->cmd[5] = 0x10;
	dev->cmd[9] = 0x01;
	if ((dev->err=dev->cmd.transport(NONE, NULL, 0))){
		sperror ("asus_errc_init",dev->err); return 1;
	}
	seek(dev,0);
	return 0;
}

int scan_asus::cmd_errc_getdata()
{
	/* initialize scan mode */
	dev->cmd[0] = 0x5A;
	dev->cmd[2] = 0x38;
	dev->cmd[3] = 0x41;
	dev->cmd[4] = 0x53;
	dev->cmd[5] = 0x10;
	dev->cmd[9] = 0x00;
	if ((dev->err=dev->cmd.transport(READ,dev->rd_buf,8))){
		sperror ("asus_errc_getdata",dev->err); return 1;
	}
	return 0;
}



// **********************
int scan_asus::cmd_cd_errc_block(cd_errc *data)
{
//	seek(dev,lba);
	data->e11 = 0;
	data->e21 = 0;
	data->e31 = 0;
	data->e12 = 0;
	data->e32 = 0;
	data->uncr = 0;
	
	if (!cmd_errc_getdata()) {
		data->bler = (dev->rd_buf[1] << 8) | dev->rd_buf[0];
		data->e22 = (dev->rd_buf[3] << 8) | dev->rd_buf[2];
	} else {
		data->bler = 0;
		data->e22 = 0;
	}
	lba=((int)dev->rd_buf[5] * 4500 + (int)dev->rd_buf[6] * 75 + (int)dev->rd_buf[7]);
//	lba+=75;
	return 0;
}

int scan_asus::cmd_dvd_errc_block(dvd_errc *data)
{
	seek(dev,lba);
	data->poe = 0;
	data->pof = 0;
	if (!cmd_errc_getdata()) {
		data->pie = (dev->rd_buf[1] << 8) | dev->rd_buf[0];
		data->pif = (dev->rd_buf[3] << 8) | dev->rd_buf[2];
	} else {
		data->pie = 0;
		data->pif = 0;
	}
//	lba = swap4(dev->rd_buf+4);
	lba+=16;
	return 0;
}

// ************* END SCAN COMMAND *********
int scan_asus::cmd_errc_end()
{
	dev->cmd[0] = 0x5A;
	dev->cmd[2] = 0x38;
	dev->cmd[3] = 0x41;
	dev->cmd[4] = 0x53;
	dev->cmd[5] = 0x10;
	dev->cmd[9] = 0x02;
	if ((dev->err=dev->cmd.transport(NONE, NULL, 0))){
		sperror ("asus_errc_end",dev->err); return 1;
	}
	return 0;
}