Skip to content

Commit dfd9751

Browse files
floatiousdamien-lemoal
authored andcommitted
ata: libata: Change libata.force to use the generic ATA_QUIRK_MAX_SEC quirk
Modify the existing libata.force parameters "max_sec_128" and "max_sec_1024" to use the generic ATA_QUIRK_MAX_SEC quirk rather than individual quirks. This also allows us to remove the individual quirks ATA_QUIRK_MAX_SEC_128 and ATA_QUIRK_MAX_SEC_1024. Signed-off-by: Niklas Cassel <cassel@kernel.org> Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com> Reviewed-by: Damien Le Moal <dlemoal@kernel.org> Signed-off-by: Damien Le Moal <dlemoal@kernel.org>
1 parent 873abd7 commit dfd9751

3 files changed

Lines changed: 16 additions & 18 deletions

File tree

drivers/ata/libata-core.c

Lines changed: 16 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -84,6 +84,7 @@ static DEFINE_IDA(ata_ida);
8484
#ifdef CONFIG_ATA_FORCE
8585
struct ata_force_param {
8686
const char *name;
87+
u64 value;
8788
u8 cbl;
8889
u8 spd_limit;
8990
unsigned int xfer_mask;
@@ -3169,14 +3170,6 @@ int ata_dev_configure(struct ata_device *dev)
31693170
dev->quirks |= ATA_QUIRK_STUCK_ERR;
31703171
}
31713172

3172-
if (dev->quirks & ATA_QUIRK_MAX_SEC_128)
3173-
dev->max_sectors = min_t(unsigned int, ATA_MAX_SECTORS_128,
3174-
dev->max_sectors);
3175-
3176-
if (dev->quirks & ATA_QUIRK_MAX_SEC_1024)
3177-
dev->max_sectors = min_t(unsigned int, ATA_MAX_SECTORS_1024,
3178-
dev->max_sectors);
3179-
31803173
if (dev->quirks & ATA_QUIRK_MAX_SEC)
31813174
dev->max_sectors = min_t(unsigned int, dev->max_sectors,
31823175
ata_dev_get_quirk_value(dev,
@@ -4012,7 +4005,6 @@ static const char * const ata_quirk_names[] = {
40124005
[__ATA_QUIRK_DIAGNOSTIC] = "diagnostic",
40134006
[__ATA_QUIRK_NODMA] = "nodma",
40144007
[__ATA_QUIRK_NONCQ] = "noncq",
4015-
[__ATA_QUIRK_MAX_SEC_128] = "maxsec128",
40164008
[__ATA_QUIRK_BROKEN_HPA] = "brokenhpa",
40174009
[__ATA_QUIRK_DISABLE] = "disable",
40184010
[__ATA_QUIRK_HPA_SIZE] = "hpasize",
@@ -4033,7 +4025,6 @@ static const char * const ata_quirk_names[] = {
40334025
[__ATA_QUIRK_ZERO_AFTER_TRIM] = "zeroaftertrim",
40344026
[__ATA_QUIRK_NO_DMA_LOG] = "nodmalog",
40354027
[__ATA_QUIRK_NOTRIM] = "notrim",
4036-
[__ATA_QUIRK_MAX_SEC_1024] = "maxsec1024",
40374028
[__ATA_QUIRK_MAX_SEC] = "maxsec",
40384029
[__ATA_QUIRK_MAX_TRIM_128M] = "maxtrim128m",
40394030
[__ATA_QUIRK_NO_NCQ_ON_ATI] = "noncqonati",
@@ -4417,6 +4408,14 @@ static u64 ata_dev_get_max_sec_quirk_value(struct ata_device *dev)
44174408
const struct ata_dev_quirk_value *ad = __ata_dev_max_sec_quirks;
44184409
u64 val = 0;
44194410

4411+
#ifdef CONFIG_ATA_FORCE
4412+
const struct ata_force_ent *fe = ata_force_get_fe_for_dev(dev);
4413+
if (fe && (fe->param.quirk_on & ATA_QUIRK_MAX_SEC) && fe->param.value)
4414+
val = fe->param.value;
4415+
#endif
4416+
if (val)
4417+
goto out;
4418+
44204419
ata_id_c_string(dev->id, model_num, ATA_ID_PROD, sizeof(model_num));
44214420
ata_id_c_string(dev->id, model_rev, ATA_ID_FW_REV, sizeof(model_rev));
44224421

@@ -4429,6 +4428,7 @@ static u64 ata_dev_get_max_sec_quirk_value(struct ata_device *dev)
44294428
ad++;
44304429
}
44314430

4431+
out:
44324432
ata_dev_warn(dev, "%s quirk is using value: %llu\n",
44334433
ata_quirk_names[__ATA_QUIRK_MAX_SEC], val);
44344434

@@ -6482,6 +6482,10 @@ EXPORT_SYMBOL_GPL(ata_platform_remove_one);
64826482
#define force_quirk_on(name, flag) \
64836483
{ #name, .quirk_on = (flag) }
64846484

6485+
#define force_quirk_val(name, flag, val) \
6486+
{ #name, .quirk_on = (flag), \
6487+
.value = (val) }
6488+
64856489
#define force_quirk_onoff(name, flag) \
64866490
{ "no" #name, .quirk_on = (flag) }, \
64876491
{ #name, .quirk_off = (flag) }
@@ -6556,8 +6560,8 @@ static const struct ata_force_param force_tbl[] __initconst = {
65566560
force_quirk_onoff(iddevlog, ATA_QUIRK_NO_ID_DEV_LOG),
65576561
force_quirk_onoff(logdir, ATA_QUIRK_NO_LOG_DIR),
65586562

6559-
force_quirk_on(max_sec_128, ATA_QUIRK_MAX_SEC_128),
6560-
force_quirk_on(max_sec_1024, ATA_QUIRK_MAX_SEC_1024),
6563+
force_quirk_val(max_sec_128, ATA_QUIRK_MAX_SEC, 128),
6564+
force_quirk_val(max_sec_1024, ATA_QUIRK_MAX_SEC, 1024),
65616565
force_quirk_on(max_sec_lba48, ATA_QUIRK_MAX_SEC_LBA48),
65626566

65636567
force_quirk_onoff(lpm, ATA_QUIRK_NOLPM),

include/linux/ata.h

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -26,9 +26,7 @@ enum {
2626
ATA_MAX_DEVICES = 2, /* per bus/port */
2727
ATA_MAX_PRD = 256, /* we could make these 256/256 */
2828
ATA_SECT_SIZE = 512,
29-
ATA_MAX_SECTORS_128 = 128,
3029
ATA_MAX_SECTORS = 256,
31-
ATA_MAX_SECTORS_1024 = 1024,
3230
ATA_MAX_SECTORS_LBA48 = 65535,/* avoid count to be 0000h */
3331
ATA_MAX_SECTORS_TAPE = 65535,
3432
ATA_MAX_TRIM_RNUM = 64, /* 512-byte payload / (6-byte LBA + 2-byte range per entry) */

include/linux/libata.h

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -52,7 +52,6 @@ enum ata_quirks {
5252
__ATA_QUIRK_DIAGNOSTIC, /* Failed boot diag */
5353
__ATA_QUIRK_NODMA, /* DMA problems */
5454
__ATA_QUIRK_NONCQ, /* Don't use NCQ */
55-
__ATA_QUIRK_MAX_SEC_128, /* Limit max sects to 128 */
5655
__ATA_QUIRK_BROKEN_HPA, /* Broken HPA */
5756
__ATA_QUIRK_DISABLE, /* Disable it */
5857
__ATA_QUIRK_HPA_SIZE, /* Native size off by one */
@@ -74,7 +73,6 @@ enum ata_quirks {
7473
__ATA_QUIRK_ZERO_AFTER_TRIM, /* Guarantees zero after trim */
7574
__ATA_QUIRK_NO_DMA_LOG, /* Do not use DMA for log read */
7675
__ATA_QUIRK_NOTRIM, /* Do not use TRIM */
77-
__ATA_QUIRK_MAX_SEC_1024, /* Limit max sects to 1024 */
7876
__ATA_QUIRK_MAX_SEC, /* Limit max sectors */
7977
__ATA_QUIRK_MAX_TRIM_128M, /* Limit max trim size to 128M */
8078
__ATA_QUIRK_NO_NCQ_ON_ATI, /* Disable NCQ on ATI chipset */
@@ -94,7 +92,6 @@ enum {
9492
ATA_QUIRK_DIAGNOSTIC = (1U << __ATA_QUIRK_DIAGNOSTIC),
9593
ATA_QUIRK_NODMA = (1U << __ATA_QUIRK_NODMA),
9694
ATA_QUIRK_NONCQ = (1U << __ATA_QUIRK_NONCQ),
97-
ATA_QUIRK_MAX_SEC_128 = (1U << __ATA_QUIRK_MAX_SEC_128),
9895
ATA_QUIRK_BROKEN_HPA = (1U << __ATA_QUIRK_BROKEN_HPA),
9996
ATA_QUIRK_DISABLE = (1U << __ATA_QUIRK_DISABLE),
10097
ATA_QUIRK_HPA_SIZE = (1U << __ATA_QUIRK_HPA_SIZE),
@@ -115,7 +112,6 @@ enum {
115112
ATA_QUIRK_ZERO_AFTER_TRIM = (1U << __ATA_QUIRK_ZERO_AFTER_TRIM),
116113
ATA_QUIRK_NO_DMA_LOG = (1U << __ATA_QUIRK_NO_DMA_LOG),
117114
ATA_QUIRK_NOTRIM = (1U << __ATA_QUIRK_NOTRIM),
118-
ATA_QUIRK_MAX_SEC_1024 = (1U << __ATA_QUIRK_MAX_SEC_1024),
119115
ATA_QUIRK_MAX_SEC = (1U << __ATA_QUIRK_MAX_SEC),
120116
ATA_QUIRK_MAX_TRIM_128M = (1U << __ATA_QUIRK_MAX_TRIM_128M),
121117
ATA_QUIRK_NO_NCQ_ON_ATI = (1U << __ATA_QUIRK_NO_NCQ_ON_ATI),

0 commit comments

Comments
 (0)