Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
10ad05df
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
10ad05df
编写于
3月 22, 2006
作者:
J
Jeff Garzik
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[libata sata_nv] cleanups: convert #defines to enums; remove in-file history
上级
142877b0
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
49 addition
and
75 deletion
+49
-75
drivers/scsi/sata_nv.c
drivers/scsi/sata_nv.c
+49
-75
未找到文件。
drivers/scsi/sata_nv.c
浏览文件 @
10ad05df
...
...
@@ -29,34 +29,6 @@
* NV-specific details such as register offsets, SATA phy location,
* hotplug info, etc.
*
* 0.10
* - Fixed spurious interrupts issue seen with the Maxtor 6H500F0 500GB
* drive. Also made the check_hotplug() callbacks return whether there
* was a hotplug interrupt or not. This was not the source of the
* spurious interrupts, but is the right thing to do anyway.
*
* 0.09
* - Fixed bug introduced by 0.08's MCP51 and MCP55 support.
*
* 0.08
* - Added support for MCP51 and MCP55.
*
* 0.07
* - Added support for RAID class code.
*
* 0.06
* - Added generic SATA support by using a pci_device_id that filters on
* the IDE storage class code.
*
* 0.03
* - Fixed a bug where the hotplug handlers for non-CK804/MCP04 were using
* mmio_base, which is only set for the CK804/MCP04 case.
*
* 0.02
* - Added support for CK804 SATA controller.
*
* 0.01
* - Initial revision.
*/
#include <linux/config.h>
...
...
@@ -74,53 +46,55 @@
#define DRV_NAME "sata_nv"
#define DRV_VERSION "0.8"
#define NV_PORTS 2
#define NV_PIO_MASK 0x1f
#define NV_MWDMA_MASK 0x07
#define NV_UDMA_MASK 0x7f
#define NV_PORT0_SCR_REG_OFFSET 0x00
#define NV_PORT1_SCR_REG_OFFSET 0x40
#define NV_INT_STATUS 0x10
#define NV_INT_STATUS_CK804 0x440
#define NV_INT_STATUS_PDEV_INT 0x01
#define NV_INT_STATUS_PDEV_PM 0x02
#define NV_INT_STATUS_PDEV_ADDED 0x04
#define NV_INT_STATUS_PDEV_REMOVED 0x08
#define NV_INT_STATUS_SDEV_INT 0x10
#define NV_INT_STATUS_SDEV_PM 0x20
#define NV_INT_STATUS_SDEV_ADDED 0x40
#define NV_INT_STATUS_SDEV_REMOVED 0x80
#define NV_INT_STATUS_PDEV_HOTPLUG (NV_INT_STATUS_PDEV_ADDED | \
NV_INT_STATUS_PDEV_REMOVED)
#define NV_INT_STATUS_SDEV_HOTPLUG (NV_INT_STATUS_SDEV_ADDED | \
NV_INT_STATUS_SDEV_REMOVED)
#define NV_INT_STATUS_HOTPLUG (NV_INT_STATUS_PDEV_HOTPLUG | \
NV_INT_STATUS_SDEV_HOTPLUG)
#define NV_INT_ENABLE 0x11
#define NV_INT_ENABLE_CK804 0x441
#define NV_INT_ENABLE_PDEV_MASK 0x01
#define NV_INT_ENABLE_PDEV_PM 0x02
#define NV_INT_ENABLE_PDEV_ADDED 0x04
#define NV_INT_ENABLE_PDEV_REMOVED 0x08
#define NV_INT_ENABLE_SDEV_MASK 0x10
#define NV_INT_ENABLE_SDEV_PM 0x20
#define NV_INT_ENABLE_SDEV_ADDED 0x40
#define NV_INT_ENABLE_SDEV_REMOVED 0x80
#define NV_INT_ENABLE_PDEV_HOTPLUG (NV_INT_ENABLE_PDEV_ADDED | \
NV_INT_ENABLE_PDEV_REMOVED)
#define NV_INT_ENABLE_SDEV_HOTPLUG (NV_INT_ENABLE_SDEV_ADDED | \
NV_INT_ENABLE_SDEV_REMOVED)
#define NV_INT_ENABLE_HOTPLUG (NV_INT_ENABLE_PDEV_HOTPLUG | \
NV_INT_ENABLE_SDEV_HOTPLUG)
#define NV_INT_CONFIG 0x12
#define NV_INT_CONFIG_METHD 0x01 // 0 = INT, 1 = SMI
// For PCI config register 20
#define NV_MCP_SATA_CFG_20 0x50
#define NV_MCP_SATA_CFG_20_SATA_SPACE_EN 0x04
enum
{
NV_PORTS
=
2
,
NV_PIO_MASK
=
0x1f
,
NV_MWDMA_MASK
=
0x07
,
NV_UDMA_MASK
=
0x7f
,
NV_PORT0_SCR_REG_OFFSET
=
0x00
,
NV_PORT1_SCR_REG_OFFSET
=
0x40
,
NV_INT_STATUS
=
0x10
,
NV_INT_STATUS_CK804
=
0x440
,
NV_INT_STATUS_PDEV_INT
=
0x01
,
NV_INT_STATUS_PDEV_PM
=
0x02
,
NV_INT_STATUS_PDEV_ADDED
=
0x04
,
NV_INT_STATUS_PDEV_REMOVED
=
0x08
,
NV_INT_STATUS_SDEV_INT
=
0x10
,
NV_INT_STATUS_SDEV_PM
=
0x20
,
NV_INT_STATUS_SDEV_ADDED
=
0x40
,
NV_INT_STATUS_SDEV_REMOVED
=
0x80
,
NV_INT_STATUS_PDEV_HOTPLUG
=
(
NV_INT_STATUS_PDEV_ADDED
|
NV_INT_STATUS_PDEV_REMOVED
),
NV_INT_STATUS_SDEV_HOTPLUG
=
(
NV_INT_STATUS_SDEV_ADDED
|
NV_INT_STATUS_SDEV_REMOVED
),
NV_INT_STATUS_HOTPLUG
=
(
NV_INT_STATUS_PDEV_HOTPLUG
|
NV_INT_STATUS_SDEV_HOTPLUG
),
NV_INT_ENABLE
=
0x11
,
NV_INT_ENABLE_CK804
=
0x441
,
NV_INT_ENABLE_PDEV_MASK
=
0x01
,
NV_INT_ENABLE_PDEV_PM
=
0x02
,
NV_INT_ENABLE_PDEV_ADDED
=
0x04
,
NV_INT_ENABLE_PDEV_REMOVED
=
0x08
,
NV_INT_ENABLE_SDEV_MASK
=
0x10
,
NV_INT_ENABLE_SDEV_PM
=
0x20
,
NV_INT_ENABLE_SDEV_ADDED
=
0x40
,
NV_INT_ENABLE_SDEV_REMOVED
=
0x80
,
NV_INT_ENABLE_PDEV_HOTPLUG
=
(
NV_INT_ENABLE_PDEV_ADDED
|
NV_INT_ENABLE_PDEV_REMOVED
),
NV_INT_ENABLE_SDEV_HOTPLUG
=
(
NV_INT_ENABLE_SDEV_ADDED
|
NV_INT_ENABLE_SDEV_REMOVED
),
NV_INT_ENABLE_HOTPLUG
=
(
NV_INT_ENABLE_PDEV_HOTPLUG
|
NV_INT_ENABLE_SDEV_HOTPLUG
),
NV_INT_CONFIG
=
0x12
,
NV_INT_CONFIG_METHD
=
0x01
,
// 0 = INT, 1 = SMI
// For PCI config register 20
NV_MCP_SATA_CFG_20
=
0x50
,
NV_MCP_SATA_CFG_20_SATA_SPACE_EN
=
0x04
,
};
static
int
nv_init_one
(
struct
pci_dev
*
pdev
,
const
struct
pci_device_id
*
ent
);
static
irqreturn_t
nv_interrupt
(
int
irq
,
void
*
dev_instance
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录