File: scsi_mode_sense.c

package info (click to toggle)
diskscan 0.21-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,656 kB
  • sloc: ansic: 11,136; python: 338; xml: 138; sh: 41; makefile: 34
file content (95 lines) | stat: -rw-r--r-- 2,951 bytes parent folder | download | duplicates (4)
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
/* Copyright 2014 Baruch Even
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */

#include "scsicmd.h"
#include "main.h"
#include "sense_dump.h"
#include "parse_mode_sense.h"
#include <stdio.h>
#include <memory.h>
#include <errno.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <scsi/sg.h>
#include <inttypes.h>

void do_command(int fd)
{
	unsigned char cdb[32];
	unsigned char buf[4096];
	unsigned cdb_len = cdb_mode_sense_10(cdb, true, false, PAGE_CONTROL_CURRENT, 0x3F, 0xFF, sizeof(buf));

	memset(buf, 0, sizeof(buf));
	printf("List all supported pages\n");
	bool ret = submit_cmd(fd, cdb, cdb_len, buf, sizeof(buf), SG_DXFER_FROM_DEV);
	if (!ret) {
		fprintf(stderr, "Failed to submit command\n");
		return;
	}

	unsigned char *sense = NULL;
	unsigned sense_len = 0;
	unsigned buf_len = 0;
	ret = read_response_buf(fd, &sense, &sense_len, &buf_len);

	if (sense) {
		printf("error while reading response buffer, nothing to show\n");
		return;
	}

	printf("Read %u bytes\n", buf_len);
	response_dump(buf, buf_len);

	if (buf_len < MODE_SENSE_10_MIN_LEN) {
		printf("Returned data is too short, expected a minimum of %u bytes and got only %u\n", MODE_SENSE_10_MIN_LEN, buf_len);
		return;
	}

	printf("Mode data len: %u\n", mode_sense_10_data_len(buf));
	printf("Medium Type: %u\n", mode_sense_10_medium_type(buf));
	printf("Device specific param: %u\n", mode_sense_10_device_specific_param(buf));
	printf("Long LBA: %s\n", mode_sense_10_long_lba(buf) ? "yes" : "no");
	printf("Block Descriptor length: %u\n", mode_sense_10_block_descriptor_length(buf));

	if (buf_len < MODE_SENSE_10_MIN_LEN + mode_sense_10_block_descriptor_length(buf))
	{
		printf("Not enough data for the block descriptor length\n");
		return;
	}

	if (mode_sense_10_long_lba(buf)) {
		printf("Don't know how to parse the block descriptor for a long lba yet\n");
	} else {
		uint8_t *bdb = mode_sense_10_block_descriptor_data(buf);

		putchar('\n');
		printf("Density code: %u\n", block_descriptor_density_code(bdb));
		printf("Num blocks: %u\n", block_descriptor_num_blocks(bdb));
		printf("Block length: %u\n", block_descriptor_block_length(bdb));
	}

	if (buf_len < MODE_SENSE_10_MIN_LEN + mode_sense_10_block_descriptor_length(buf) + mode_sense_10_data_len(buf))
	{
		printf("Not enough data for the mode data length\n");
		return;
	}

	putchar('\n');
	//uint8_t *mode_data = mode_sense_10_mode_data(buf);

}