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
Kirill Smelkov
linux
Commits
2f5a3145
Commit
2f5a3145
authored
Jan 13, 2017
by
James Bottomley
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'mkp-scsi/4.10/scsi-fixes' into fixes
parents
a47fff10
cd60be49
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
33 additions
and
85 deletions
+33
-85
drivers/scsi/lpfc/lpfc_sli.c
drivers/scsi/lpfc/lpfc_sli.c
+7
-0
drivers/scsi/qla2xxx/qla_attr.c
drivers/scsi/qla2xxx/qla_attr.c
+13
-5
drivers/scsi/qla2xxx/qla_def.h
drivers/scsi/qla2xxx/qla_def.h
+1
-2
drivers/scsi/qla2xxx/qla_isr.c
drivers/scsi/qla2xxx/qla_isr.c
+11
-77
drivers/scsi/qla2xxx/qla_os.c
drivers/scsi/qla2xxx/qla_os.c
+1
-1
No files found.
drivers/scsi/lpfc/lpfc_sli.c
View file @
2f5a3145
...
@@ -5954,18 +5954,25 @@ lpfc_sli4_alloc_resource_identifiers(struct lpfc_hba *phba)
...
@@ -5954,18 +5954,25 @@ lpfc_sli4_alloc_resource_identifiers(struct lpfc_hba *phba)
free_vfi_bmask:
free_vfi_bmask:
kfree
(
phba
->
sli4_hba
.
vfi_bmask
);
kfree
(
phba
->
sli4_hba
.
vfi_bmask
);
phba
->
sli4_hba
.
vfi_bmask
=
NULL
;
free_xri_ids:
free_xri_ids:
kfree
(
phba
->
sli4_hba
.
xri_ids
);
kfree
(
phba
->
sli4_hba
.
xri_ids
);
phba
->
sli4_hba
.
xri_ids
=
NULL
;
free_xri_bmask:
free_xri_bmask:
kfree
(
phba
->
sli4_hba
.
xri_bmask
);
kfree
(
phba
->
sli4_hba
.
xri_bmask
);
phba
->
sli4_hba
.
xri_bmask
=
NULL
;
free_vpi_ids:
free_vpi_ids:
kfree
(
phba
->
vpi_ids
);
kfree
(
phba
->
vpi_ids
);
phba
->
vpi_ids
=
NULL
;
free_vpi_bmask:
free_vpi_bmask:
kfree
(
phba
->
vpi_bmask
);
kfree
(
phba
->
vpi_bmask
);
phba
->
vpi_bmask
=
NULL
;
free_rpi_ids:
free_rpi_ids:
kfree
(
phba
->
sli4_hba
.
rpi_ids
);
kfree
(
phba
->
sli4_hba
.
rpi_ids
);
phba
->
sli4_hba
.
rpi_ids
=
NULL
;
free_rpi_bmask:
free_rpi_bmask:
kfree
(
phba
->
sli4_hba
.
rpi_bmask
);
kfree
(
phba
->
sli4_hba
.
rpi_bmask
);
phba
->
sli4_hba
.
rpi_bmask
=
NULL
;
err_exit:
err_exit:
return
rc
;
return
rc
;
}
}
...
...
drivers/scsi/qla2xxx/qla_attr.c
View file @
2f5a3145
...
@@ -243,12 +243,15 @@ qla2x00_sysfs_read_optrom(struct file *filp, struct kobject *kobj,
...
@@ -243,12 +243,15 @@ qla2x00_sysfs_read_optrom(struct file *filp, struct kobject *kobj,
struct
qla_hw_data
*
ha
=
vha
->
hw
;
struct
qla_hw_data
*
ha
=
vha
->
hw
;
ssize_t
rval
=
0
;
ssize_t
rval
=
0
;
mutex_lock
(
&
ha
->
optrom_mutex
);
if
(
ha
->
optrom_state
!=
QLA_SREADING
)
if
(
ha
->
optrom_state
!=
QLA_SREADING
)
return
0
;
goto
out
;
mutex_lock
(
&
ha
->
optrom_mutex
);
rval
=
memory_read_from_buffer
(
buf
,
count
,
&
off
,
ha
->
optrom_buffer
,
rval
=
memory_read_from_buffer
(
buf
,
count
,
&
off
,
ha
->
optrom_buffer
,
ha
->
optrom_region_size
);
ha
->
optrom_region_size
);
out:
mutex_unlock
(
&
ha
->
optrom_mutex
);
mutex_unlock
(
&
ha
->
optrom_mutex
);
return
rval
;
return
rval
;
...
@@ -263,14 +266,19 @@ qla2x00_sysfs_write_optrom(struct file *filp, struct kobject *kobj,
...
@@ -263,14 +266,19 @@ qla2x00_sysfs_write_optrom(struct file *filp, struct kobject *kobj,
struct
device
,
kobj
)));
struct
device
,
kobj
)));
struct
qla_hw_data
*
ha
=
vha
->
hw
;
struct
qla_hw_data
*
ha
=
vha
->
hw
;
if
(
ha
->
optrom_state
!=
QLA_SWRITING
)
mutex_lock
(
&
ha
->
optrom_mutex
);
if
(
ha
->
optrom_state
!=
QLA_SWRITING
)
{
mutex_unlock
(
&
ha
->
optrom_mutex
);
return
-
EINVAL
;
return
-
EINVAL
;
if
(
off
>
ha
->
optrom_region_size
)
}
if
(
off
>
ha
->
optrom_region_size
)
{
mutex_unlock
(
&
ha
->
optrom_mutex
);
return
-
ERANGE
;
return
-
ERANGE
;
}
if
(
off
+
count
>
ha
->
optrom_region_size
)
if
(
off
+
count
>
ha
->
optrom_region_size
)
count
=
ha
->
optrom_region_size
-
off
;
count
=
ha
->
optrom_region_size
-
off
;
mutex_lock
(
&
ha
->
optrom_mutex
);
memcpy
(
&
ha
->
optrom_buffer
[
off
],
buf
,
count
);
memcpy
(
&
ha
->
optrom_buffer
[
off
],
buf
,
count
);
mutex_unlock
(
&
ha
->
optrom_mutex
);
mutex_unlock
(
&
ha
->
optrom_mutex
);
...
...
drivers/scsi/qla2xxx/qla_def.h
View file @
2f5a3145
...
@@ -2732,7 +2732,7 @@ struct isp_operations {
...
@@ -2732,7 +2732,7 @@ struct isp_operations {
#define QLA_MSIX_FW_MODE(m) (((m) & (BIT_7|BIT_8|BIT_9)) >> 7)
#define QLA_MSIX_FW_MODE(m) (((m) & (BIT_7|BIT_8|BIT_9)) >> 7)
#define QLA_MSIX_FW_MODE_1(m) (QLA_MSIX_FW_MODE(m) == 1)
#define QLA_MSIX_FW_MODE_1(m) (QLA_MSIX_FW_MODE(m) == 1)
#define QLA_
MSIX_DEFAULT 0x00
#define QLA_
BASE_VECTORS 2
/* default + RSP */
#define QLA_MSIX_RSP_Q 0x01
#define QLA_MSIX_RSP_Q 0x01
#define QLA_ATIO_VECTOR 0x02
#define QLA_ATIO_VECTOR 0x02
#define QLA_MSIX_QPAIR_MULTIQ_RSP_Q 0x03
#define QLA_MSIX_QPAIR_MULTIQ_RSP_Q 0x03
...
@@ -2754,7 +2754,6 @@ struct qla_msix_entry {
...
@@ -2754,7 +2754,6 @@ struct qla_msix_entry {
uint16_t
entry
;
uint16_t
entry
;
char
name
[
30
];
char
name
[
30
];
void
*
handle
;
void
*
handle
;
struct
irq_affinity_notify
irq_notify
;
int
cpuid
;
int
cpuid
;
};
};
...
...
drivers/scsi/qla2xxx/qla_isr.c
View file @
2f5a3145
...
@@ -19,10 +19,6 @@ static void qla2x00_status_entry(scsi_qla_host_t *, struct rsp_que *, void *);
...
@@ -19,10 +19,6 @@ static void qla2x00_status_entry(scsi_qla_host_t *, struct rsp_que *, void *);
static
void
qla2x00_status_cont_entry
(
struct
rsp_que
*
,
sts_cont_entry_t
*
);
static
void
qla2x00_status_cont_entry
(
struct
rsp_que
*
,
sts_cont_entry_t
*
);
static
void
qla2x00_error_entry
(
scsi_qla_host_t
*
,
struct
rsp_que
*
,
static
void
qla2x00_error_entry
(
scsi_qla_host_t
*
,
struct
rsp_que
*
,
sts_entry_t
*
);
sts_entry_t
*
);
static
void
qla_irq_affinity_notify
(
struct
irq_affinity_notify
*
,
const
cpumask_t
*
);
static
void
qla_irq_affinity_release
(
struct
kref
*
);
/**
/**
* qla2100_intr_handler() - Process interrupts for the ISP2100 and ISP2200.
* qla2100_intr_handler() - Process interrupts for the ISP2100 and ISP2200.
...
@@ -2572,14 +2568,6 @@ void qla24xx_process_response_queue(struct scsi_qla_host *vha,
...
@@ -2572,14 +2568,6 @@ void qla24xx_process_response_queue(struct scsi_qla_host *vha,
if
(
!
vha
->
flags
.
online
)
if
(
!
vha
->
flags
.
online
)
return
;
return
;
if
(
rsp
->
msix
&&
rsp
->
msix
->
cpuid
!=
smp_processor_id
())
{
/* if kernel does not notify qla of IRQ's CPU change,
* then set it here.
*/
rsp
->
msix
->
cpuid
=
smp_processor_id
();
ha
->
tgt
.
rspq_vector_cpuid
=
rsp
->
msix
->
cpuid
;
}
while
(
rsp
->
ring_ptr
->
signature
!=
RESPONSE_PROCESSED
)
{
while
(
rsp
->
ring_ptr
->
signature
!=
RESPONSE_PROCESSED
)
{
pkt
=
(
struct
sts_entry_24xx
*
)
rsp
->
ring_ptr
;
pkt
=
(
struct
sts_entry_24xx
*
)
rsp
->
ring_ptr
;
...
@@ -3018,13 +3006,20 @@ static struct qla_init_msix_entry qla82xx_msix_entries[] = {
...
@@ -3018,13 +3006,20 @@ static struct qla_init_msix_entry qla82xx_msix_entries[] = {
static
int
static
int
qla24xx_enable_msix
(
struct
qla_hw_data
*
ha
,
struct
rsp_que
*
rsp
)
qla24xx_enable_msix
(
struct
qla_hw_data
*
ha
,
struct
rsp_que
*
rsp
)
{
{
#define MIN_MSIX_COUNT 2
int
i
,
ret
;
int
i
,
ret
;
struct
qla_msix_entry
*
qentry
;
struct
qla_msix_entry
*
qentry
;
scsi_qla_host_t
*
vha
=
pci_get_drvdata
(
ha
->
pdev
);
scsi_qla_host_t
*
vha
=
pci_get_drvdata
(
ha
->
pdev
);
struct
irq_affinity
desc
=
{
.
pre_vectors
=
QLA_BASE_VECTORS
,
};
if
(
QLA_TGT_MODE_ENABLED
()
&&
IS_ATIO_MSIX_CAPABLE
(
ha
))
desc
.
pre_vectors
++
;
ret
=
pci_alloc_irq_vectors_affinity
(
ha
->
pdev
,
QLA_BASE_VECTORS
,
ha
->
msix_count
,
PCI_IRQ_MSIX
|
PCI_IRQ_AFFINITY
,
&
desc
);
ret
=
pci_alloc_irq_vectors
(
ha
->
pdev
,
MIN_MSIX_COUNT
,
ha
->
msix_count
,
PCI_IRQ_MSIX
|
PCI_IRQ_AFFINITY
);
if
(
ret
<
0
)
{
if
(
ret
<
0
)
{
ql_log
(
ql_log_fatal
,
vha
,
0x00c7
,
ql_log
(
ql_log_fatal
,
vha
,
0x00c7
,
"MSI-X: Failed to enable support, "
"MSI-X: Failed to enable support, "
...
@@ -3069,13 +3064,10 @@ qla24xx_enable_msix(struct qla_hw_data *ha, struct rsp_que *rsp)
...
@@ -3069,13 +3064,10 @@ qla24xx_enable_msix(struct qla_hw_data *ha, struct rsp_que *rsp)
qentry
->
have_irq
=
0
;
qentry
->
have_irq
=
0
;
qentry
->
in_use
=
0
;
qentry
->
in_use
=
0
;
qentry
->
handle
=
NULL
;
qentry
->
handle
=
NULL
;
qentry
->
irq_notify
.
notify
=
qla_irq_affinity_notify
;
qentry
->
irq_notify
.
release
=
qla_irq_affinity_release
;
qentry
->
cpuid
=
-
1
;
}
}
/* Enable MSI-X vectors for the base queue */
/* Enable MSI-X vectors for the base queue */
for
(
i
=
0
;
i
<
(
QLA_MSIX_RSP_Q
+
1
)
;
i
++
)
{
for
(
i
=
0
;
i
<
QLA_BASE_VECTORS
;
i
++
)
{
qentry
=
&
ha
->
msix_entries
[
i
];
qentry
=
&
ha
->
msix_entries
[
i
];
qentry
->
handle
=
rsp
;
qentry
->
handle
=
rsp
;
rsp
->
msix
=
qentry
;
rsp
->
msix
=
qentry
;
...
@@ -3093,18 +3085,6 @@ qla24xx_enable_msix(struct qla_hw_data *ha, struct rsp_que *rsp)
...
@@ -3093,18 +3085,6 @@ qla24xx_enable_msix(struct qla_hw_data *ha, struct rsp_que *rsp)
goto
msix_register_fail
;
goto
msix_register_fail
;
qentry
->
have_irq
=
1
;
qentry
->
have_irq
=
1
;
qentry
->
in_use
=
1
;
qentry
->
in_use
=
1
;
/* Register for CPU affinity notification. */
irq_set_affinity_notifier
(
qentry
->
vector
,
&
qentry
->
irq_notify
);
/* Schedule work (ie. trigger a notification) to read cpu
* mask for this specific irq.
* kref_get is required because
* irq_affinity_notify() will do
* kref_put().
*/
kref_get
(
&
qentry
->
irq_notify
.
kref
);
schedule_work
(
&
qentry
->
irq_notify
.
work
);
}
}
/*
/*
...
@@ -3301,49 +3281,3 @@ int qla25xx_request_irq(struct qla_hw_data *ha, struct qla_qpair *qpair,
...
@@ -3301,49 +3281,3 @@ int qla25xx_request_irq(struct qla_hw_data *ha, struct qla_qpair *qpair,
msix
->
handle
=
qpair
;
msix
->
handle
=
qpair
;
return
ret
;
return
ret
;
}
}
/* irq_set_affinity/irqbalance will trigger notification of cpu mask update */
static
void
qla_irq_affinity_notify
(
struct
irq_affinity_notify
*
notify
,
const
cpumask_t
*
mask
)
{
struct
qla_msix_entry
*
e
=
container_of
(
notify
,
struct
qla_msix_entry
,
irq_notify
);
struct
qla_hw_data
*
ha
;
struct
scsi_qla_host
*
base_vha
;
struct
rsp_que
*
rsp
=
e
->
handle
;
/* user is recommended to set mask to just 1 cpu */
e
->
cpuid
=
cpumask_first
(
mask
);
ha
=
rsp
->
hw
;
base_vha
=
pci_get_drvdata
(
ha
->
pdev
);
ql_dbg
(
ql_dbg_init
,
base_vha
,
0xffff
,
"%s: host %ld : vector %d cpu %d
\n
"
,
__func__
,
base_vha
->
host_no
,
e
->
vector
,
e
->
cpuid
);
if
(
e
->
have_irq
)
{
if
((
IS_QLA83XX
(
ha
)
||
IS_QLA27XX
(
ha
))
&&
(
e
->
entry
==
QLA83XX_RSPQ_MSIX_ENTRY_NUMBER
))
{
ha
->
tgt
.
rspq_vector_cpuid
=
e
->
cpuid
;
ql_dbg
(
ql_dbg_init
,
base_vha
,
0xffff
,
"%s: host%ld: rspq vector %d cpu %d runtime change
\n
"
,
__func__
,
base_vha
->
host_no
,
e
->
vector
,
e
->
cpuid
);
}
}
}
static
void
qla_irq_affinity_release
(
struct
kref
*
ref
)
{
struct
irq_affinity_notify
*
notify
=
container_of
(
ref
,
struct
irq_affinity_notify
,
kref
);
struct
qla_msix_entry
*
e
=
container_of
(
notify
,
struct
qla_msix_entry
,
irq_notify
);
struct
rsp_que
*
rsp
=
e
->
handle
;
struct
scsi_qla_host
*
base_vha
=
pci_get_drvdata
(
rsp
->
hw
->
pdev
);
ql_dbg
(
ql_dbg_init
,
base_vha
,
0xffff
,
"%s: host%ld: vector %d cpu %d
\n
"
,
__func__
,
base_vha
->
host_no
,
e
->
vector
,
e
->
cpuid
);
}
drivers/scsi/qla2xxx/qla_os.c
View file @
2f5a3145
...
@@ -466,7 +466,7 @@ static void qla2x00_free_queues(struct qla_hw_data *ha)
...
@@ -466,7 +466,7 @@ static void qla2x00_free_queues(struct qla_hw_data *ha)
continue
;
continue
;
rsp
=
ha
->
rsp_q_map
[
cnt
];
rsp
=
ha
->
rsp_q_map
[
cnt
];
clear_bit
(
cnt
,
ha
->
r
eq
_qid_map
);
clear_bit
(
cnt
,
ha
->
r
sp
_qid_map
);
ha
->
rsp_q_map
[
cnt
]
=
NULL
;
ha
->
rsp_q_map
[
cnt
]
=
NULL
;
spin_unlock_irqrestore
(
&
ha
->
hardware_lock
,
flags
);
spin_unlock_irqrestore
(
&
ha
->
hardware_lock
,
flags
);
qla2x00_free_rsp_que
(
ha
,
rsp
);
qla2x00_free_rsp_que
(
ha
,
rsp
);
...
...
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