xref: /csrg-svn/sys/tahoe/stand/vdformat/smd.c (revision 29536)
1*29536Ssam #ifndef lint
2*29536Ssam static char sccsid[] = "@(#)smd.c	1.1 (Berkeley/CCI) 07/05/86";
3*29536Ssam #endif
4*29536Ssam 
5*29536Ssam #include	"vdfmt.h"
6*29536Ssam 
7*29536Ssam 
8*29536Ssam 
9*29536Ssam /*
10*29536Ssam **	The sector format of the SMD controller looks like this:
11*29536Ssam **  28 bytes sector gap		(header error)
12*29536Ssam **   1 byte sync (0x19)		(header error)
13*29536Ssam **   2 bytes cylinder address	(header error)
14*29536Ssam **   1 byte track address	(header error)
15*29536Ssam **   1 byte sector address	(header error)
16*29536Ssam **   2 bytes header crc		(header error)
17*29536Ssam **  18 bytes header gap		(data error)
18*29536Ssam ** 512 bytes data		(data error)
19*29536Ssam **   4 byte ecc			(data error)
20*29536Ssam **  ?? trailing pad		(data error)
21*29536Ssam */
22*29536Ssam 
23*29536Ssam fmt_err smd_decode_position(bad_entry)
24*29536Ssam bs_entry bad_entry;
25*29536Ssam {
26*29536Ssam 	fmt_err	error;
27*29536Ssam 	int	sector_length = CURRENT->vc_traksize / CURRENT->vc_nsec;
28*29536Ssam 	int	offset = (bad_entry.bs_offset-2) % sector_length;
29*29536Ssam 	int	bytes = ((bad_entry.bs_length / 8)) + 4;
30*29536Ssam 
31*29536Ssam 	error.err_adr.cylinder = bad_entry.bs_cyl;
32*29536Ssam 	error.err_adr.track = bad_entry.bs_trk;
33*29536Ssam 	error.err_adr.sector = (bad_entry.bs_offset-2) / sector_length;
34*29536Ssam 	if(error.err_adr.sector >= CURRENT->vc_nsec) {
35*29536Ssam 		error.err_adr.sector = CURRENT->vc_nsec - 1;
36*29536Ssam 		error.err_stat = DATA_ERROR;
37*29536Ssam 	}
38*29536Ssam 	else if((offset < 35) || ((offset+bytes) > sector_length))
39*29536Ssam 		error.err_stat = HEADER_ERROR;
40*29536Ssam 	else
41*29536Ssam 		error.err_stat = DATA_ERROR;
42*29536Ssam 	return	error;
43*29536Ssam }
44*29536Ssam 
45*29536Ssam 
46*29536Ssam /*
47*29536Ssam **
48*29536Ssam */
49*29536Ssam 
50*29536Ssam bs_entry smd_code_position(error)
51*29536Ssam fmt_err	error;
52*29536Ssam {
53*29536Ssam 	int		sector_length = CURRENT->vc_traksize / CURRENT->vc_nsec;
54*29536Ssam 	bs_entry	temp;
55*29536Ssam 
56*29536Ssam 	temp.bs_length = 1;
57*29536Ssam 	temp.bs_cyl = error.err_adr.cylinder;
58*29536Ssam 	temp.bs_trk = error.err_adr.track;
59*29536Ssam 	temp.bs_offset = error.err_adr.sector * sector_length;
60*29536Ssam 	if(error.err_stat & HEADER_ERROR) {
61*29536Ssam 		temp.bs_offset += 1;
62*29536Ssam 	}
63*29536Ssam 	else {
64*29536Ssam 		temp.bs_offset += 50;
65*29536Ssam 	}
66*29536Ssam 	temp.bs_alt.cylinder = 0;
67*29536Ssam 	temp.bs_alt.track = 0;
68*29536Ssam 	temp.bs_alt.sector = 0;
69*29536Ssam 	temp.bs_how = scanning;
70*29536Ssam 	return	temp;
71*29536Ssam }
72*29536Ssam 
73*29536Ssam 
74*29536Ssam 
75*29536Ssam /*
76*29536Ssam **
77*29536Ssam */
78*29536Ssam 
79*29536Ssam smd_cyl_skew()
80*29536Ssam {
81*29536Ssam 	return 0;
82*29536Ssam }
83*29536Ssam 
84*29536Ssam 
85*29536Ssam /*
86*29536Ssam **
87*29536Ssam */
88*29536Ssam 
89*29536Ssam smd_trk_skew()
90*29536Ssam {
91*29536Ssam 	return 0;
92*29536Ssam }
93*29536Ssam 
94