Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
5ed8b574
Commit
5ed8b574
authored
Feb 01, 2005
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Plain Diff
Merge pobox.com:/garz/repo/linux-2.6
into pobox.com:/garz/repo/libata-dev/dma-blacklist
parents
b389f382
2a11587d
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
88 additions
and
4 deletions
+88
-4
drivers/scsi/libata-core.c
drivers/scsi/libata-core.c
+88
-4
No files found.
drivers/scsi/libata-core.c
View file @
5ed8b574
...
...
@@ -1700,6 +1700,70 @@ void ata_bus_reset(struct ata_port *ap)
DPRINTK
(
"EXIT
\n
"
);
}
static
void
ata_pr_blacklisted
(
struct
ata_port
*
ap
,
struct
ata_device
*
dev
)
{
printk
(
KERN_WARNING
"ata%u: dev %u is on DMA blacklist, disabling DMA
\n
"
,
ap
->
id
,
dev
->
devno
);
}
static
const
char
*
ata_dma_blacklist
[]
=
{
"WDC AC11000H"
,
"WDC AC22100H"
,
"WDC AC32500H"
,
"WDC AC33100H"
,
"WDC AC31600H"
,
"WDC AC32100H"
,
"WDC AC23200L"
,
"Compaq CRD-8241B"
,
"CRD-8400B"
,
"CRD-8480B"
,
"CRD-8480C"
,
"CRD-8482B"
,
"CRD-84"
,
"SanDisk SDP3B"
,
"SanDisk SDP3B-64"
,
"SANYO CD-ROM CRD"
,
"HITACHI CDR-8"
,
"HITACHI CDR-8335"
,
"HITACHI CDR-8435"
,
"Toshiba CD-ROM XM-6202B"
,
"CD-532E-A"
,
"E-IDE CD-ROM CR-840"
,
"CD-ROM Drive/F5A"
,
"WPI CDD-820"
,
"SAMSUNG CD-ROM SC-148C"
,
"SAMSUNG CD-ROM SC"
,
"SanDisk SDP3B-64"
,
"SAMSUNG CD-ROM SN-124"
,
"ATAPI CD-ROM DRIVE 40X MAXIMUM"
,
"_NEC DV5800A"
,
};
static
int
ata_dma_blacklisted
(
struct
ata_port
*
ap
,
struct
ata_device
*
dev
)
{
unsigned
char
model_num
[
40
];
char
*
s
;
unsigned
int
len
;
int
i
;
ata_dev_id_string
(
dev
->
id
,
model_num
,
ATA_ID_PROD_OFS
,
sizeof
(
model_num
));
s
=
&
model_num
[
0
];
len
=
strnlen
(
s
,
sizeof
(
model_num
));
/* ATAPI specifies that empty space is blank-filled; remove blanks */
while
((
len
>
0
)
&&
(
s
[
len
-
1
]
==
' '
))
{
len
--
;
s
[
len
]
=
0
;
}
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
ata_dma_blacklist
);
i
++
)
if
(
!
strncmp
(
ata_dma_blacklist
[
i
],
s
,
len
))
return
1
;
return
0
;
}
static
unsigned
int
ata_get_mode_mask
(
struct
ata_port
*
ap
,
int
shift
)
{
struct
ata_device
*
master
,
*
slave
;
...
...
@@ -1712,17 +1776,37 @@ static unsigned int ata_get_mode_mask(struct ata_port *ap, int shift)
if
(
shift
==
ATA_SHIFT_UDMA
)
{
mask
=
ap
->
udma_mask
;
if
(
ata_dev_present
(
master
))
if
(
ata_dev_present
(
master
))
{
mask
&=
(
master
->
id
[
ATA_ID_UDMA_MODES
]
&
0xff
);
if
(
ata_dev_present
(
slave
))
if
(
ata_dma_blacklisted
(
ap
,
master
))
{
mask
=
0
;
ata_pr_blacklisted
(
ap
,
master
);
}
}
if
(
ata_dev_present
(
slave
))
{
mask
&=
(
slave
->
id
[
ATA_ID_UDMA_MODES
]
&
0xff
);
if
(
ata_dma_blacklisted
(
ap
,
slave
))
{
mask
=
0
;
ata_pr_blacklisted
(
ap
,
slave
);
}
}
}
else
if
(
shift
==
ATA_SHIFT_MWDMA
)
{
mask
=
ap
->
mwdma_mask
;
if
(
ata_dev_present
(
master
))
if
(
ata_dev_present
(
master
))
{
mask
&=
(
master
->
id
[
ATA_ID_MWDMA_MODES
]
&
0x07
);
if
(
ata_dev_present
(
slave
))
if
(
ata_dma_blacklisted
(
ap
,
master
))
{
mask
=
0
;
ata_pr_blacklisted
(
ap
,
master
);
}
}
if
(
ata_dev_present
(
slave
))
{
mask
&=
(
slave
->
id
[
ATA_ID_MWDMA_MODES
]
&
0x07
);
if
(
ata_dma_blacklisted
(
ap
,
slave
))
{
mask
=
0
;
ata_pr_blacklisted
(
ap
,
slave
);
}
}
}
else
if
(
shift
==
ATA_SHIFT_PIO
)
{
mask
=
ap
->
pio_mask
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment