Commit b0e2062d authored by yipechai's avatar yipechai Committed by Alex Deucher

drm/amdgpu: Modify mca block to fit for the unified ras block data and ops

1.Modify mca block to fit for the unified ras block data and ops.
2.Define special .ras_block_match function for mca block to identify itself.
3.Change amdgpu_mca_ras_funcs to amdgpu_mca_ras_block(amdgpu_mca_ras had been used), and the corresponding variable name remove _funcs suffix.
4.Remove the const flag of cma ras variable so that cma ras block can be able to be inserted into amdgpu device ras block link list.
5.Invoke amdgpu_ras_register_ras_block function to register cma ras block into amdgpu device ras block link list.
6.Remove the redundant code about cma in amdgpu_ras.c after using the unified ras block.
Signed-off-by: default avataryipechai <YiPeng.Chai@amd.com>
Reviewed-by: default avatarHawking Zhang <Hawking.Zhang@amd.com>
Reviewed-by: default avatarJohn Clements <john.clements@amd.com>
Reviewed-by: default avatarTao Zhou <tao.zhou1@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent bdc4292b
...@@ -469,23 +469,20 @@ int amdgpu_gmc_ras_late_init(struct amdgpu_device *adev) ...@@ -469,23 +469,20 @@ int amdgpu_gmc_ras_late_init(struct amdgpu_device *adev)
return r; return r;
} }
if (adev->mca.mp0.ras_funcs && if (adev->mca.mp0.ras && adev->mca.mp0.ras->ras_block.ras_late_init) {
adev->mca.mp0.ras_funcs->ras_late_init) { r = adev->mca.mp0.ras->ras_block.ras_late_init(adev, NULL);
r = adev->mca.mp0.ras_funcs->ras_late_init(adev);
if (r) if (r)
return r; return r;
} }
if (adev->mca.mp1.ras_funcs && if (adev->mca.mp1.ras && adev->mca.mp1.ras->ras_block.ras_late_init) {
adev->mca.mp1.ras_funcs->ras_late_init) { r = adev->mca.mp1.ras->ras_block.ras_late_init(adev, NULL);
r = adev->mca.mp1.ras_funcs->ras_late_init(adev);
if (r) if (r)
return r; return r;
} }
if (adev->mca.mpio.ras_funcs && if (adev->mca.mpio.ras && adev->mca.mpio.ras->ras_block.ras_late_init) {
adev->mca.mpio.ras_funcs->ras_late_init) { r = adev->mca.mpio.ras->ras_block.ras_late_init(adev, NULL);
r = adev->mca.mpio.ras_funcs->ras_late_init(adev);
if (r) if (r)
return r; return r;
} }
......
...@@ -74,20 +74,23 @@ void amdgpu_mca_query_ras_error_count(struct amdgpu_device *adev, ...@@ -74,20 +74,23 @@ void amdgpu_mca_query_ras_error_count(struct amdgpu_device *adev,
int amdgpu_mca_ras_late_init(struct amdgpu_device *adev, int amdgpu_mca_ras_late_init(struct amdgpu_device *adev,
struct amdgpu_mca_ras *mca_dev) struct amdgpu_mca_ras *mca_dev)
{ {
char sysfs_name[32] = {0};
int r; int r;
struct ras_ih_if ih_info = { struct ras_ih_if ih_info = {
.cb = NULL, .cb = NULL,
}; };
struct ras_fs_if fs_info = { struct ras_fs_if fs_info= {
.sysfs_name = mca_dev->ras_funcs->sysfs_name, .sysfs_name = sysfs_name,
}; };
snprintf(sysfs_name, sizeof(sysfs_name), "%s_err_count", mca_dev->ras->ras_block.name);
if (!mca_dev->ras_if) { if (!mca_dev->ras_if) {
mca_dev->ras_if = kmalloc(sizeof(struct ras_common_if), GFP_KERNEL); mca_dev->ras_if = kmalloc(sizeof(struct ras_common_if), GFP_KERNEL);
if (!mca_dev->ras_if) if (!mca_dev->ras_if)
return -ENOMEM; return -ENOMEM;
mca_dev->ras_if->block = mca_dev->ras_funcs->ras_block; mca_dev->ras_if->block = mca_dev->ras->ras_block.block;
mca_dev->ras_if->sub_block_index = mca_dev->ras_funcs->ras_sub_block; mca_dev->ras_if->sub_block_index = mca_dev->ras->ras_block.sub_block_index;
mca_dev->ras_if->type = AMDGPU_RAS_ERROR__MULTI_UNCORRECTABLE; mca_dev->ras_if->type = AMDGPU_RAS_ERROR__MULTI_UNCORRECTABLE;
} }
ih_info.head = fs_info.head = *mca_dev->ras_if; ih_info.head = fs_info.head = *mca_dev->ras_if;
......
...@@ -21,21 +21,13 @@ ...@@ -21,21 +21,13 @@
#ifndef __AMDGPU_MCA_H__ #ifndef __AMDGPU_MCA_H__
#define __AMDGPU_MCA_H__ #define __AMDGPU_MCA_H__
struct amdgpu_mca_ras_funcs { struct amdgpu_mca_ras_block {
int (*ras_late_init)(struct amdgpu_device *adev); struct amdgpu_ras_block_object ras_block;
void (*ras_fini)(struct amdgpu_device *adev);
void (*query_ras_error_count)(struct amdgpu_device *adev,
void *ras_error_status);
void (*query_ras_error_address)(struct amdgpu_device *adev,
void *ras_error_status);
uint32_t ras_block;
uint32_t ras_sub_block;
const char* sysfs_name;
}; };
struct amdgpu_mca_ras { struct amdgpu_mca_ras {
struct ras_common_if *ras_if; struct ras_common_if *ras_if;
const struct amdgpu_mca_ras_funcs *ras_funcs; struct amdgpu_mca_ras_block *ras;
}; };
struct amdgpu_mca_funcs { struct amdgpu_mca_funcs {
......
...@@ -37,7 +37,7 @@ static void mca_v3_0_mp0_query_ras_error_count(struct amdgpu_device *adev, ...@@ -37,7 +37,7 @@ static void mca_v3_0_mp0_query_ras_error_count(struct amdgpu_device *adev,
ras_error_status); ras_error_status);
} }
static int mca_v3_0_mp0_ras_late_init(struct amdgpu_device *adev) static int mca_v3_0_mp0_ras_late_init(struct amdgpu_device *adev, void *ras_info)
{ {
return amdgpu_mca_ras_late_init(adev, &adev->mca.mp0); return amdgpu_mca_ras_late_init(adev, &adev->mca.mp0);
} }
...@@ -47,14 +47,34 @@ static void mca_v3_0_mp0_ras_fini(struct amdgpu_device *adev) ...@@ -47,14 +47,34 @@ static void mca_v3_0_mp0_ras_fini(struct amdgpu_device *adev)
amdgpu_mca_ras_fini(adev, &adev->mca.mp0); amdgpu_mca_ras_fini(adev, &adev->mca.mp0);
} }
const struct amdgpu_mca_ras_funcs mca_v3_0_mp0_ras_funcs = { static int mca_v3_0_ras_block_match(struct amdgpu_ras_block_object* block_obj, enum amdgpu_ras_block block, uint32_t sub_block_index)
.ras_late_init = mca_v3_0_mp0_ras_late_init, {
.ras_fini = mca_v3_0_mp0_ras_fini, if(!block_obj)
return -EINVAL;
if( (block_obj->block == block) &&
(block_obj->sub_block_index == sub_block_index)) {
return 0;
}
return -EINVAL;
}
const struct amdgpu_ras_block_hw_ops mca_v3_0_mp0_hw_ops = {
.query_ras_error_count = mca_v3_0_mp0_query_ras_error_count, .query_ras_error_count = mca_v3_0_mp0_query_ras_error_count,
.query_ras_error_address = NULL, .query_ras_error_address = NULL,
.ras_block = AMDGPU_RAS_BLOCK__MCA, };
.ras_sub_block = AMDGPU_RAS_MCA_BLOCK__MP0,
.sysfs_name = "mp0_err_count", struct amdgpu_mca_ras_block mca_v3_0_mp0_ras = {
.ras_block = {
.block = AMDGPU_RAS_BLOCK__MCA,
.sub_block_index = AMDGPU_RAS_MCA_BLOCK__MP0,
.name = "mp0",
.hw_ops = &mca_v3_0_mp0_hw_ops,
.ras_block_match = mca_v3_0_ras_block_match,
.ras_late_init = mca_v3_0_mp0_ras_late_init,
.ras_fini = mca_v3_0_mp0_ras_fini,
},
}; };
static void mca_v3_0_mp1_query_ras_error_count(struct amdgpu_device *adev, static void mca_v3_0_mp1_query_ras_error_count(struct amdgpu_device *adev,
...@@ -65,7 +85,7 @@ static void mca_v3_0_mp1_query_ras_error_count(struct amdgpu_device *adev, ...@@ -65,7 +85,7 @@ static void mca_v3_0_mp1_query_ras_error_count(struct amdgpu_device *adev,
ras_error_status); ras_error_status);
} }
static int mca_v3_0_mp1_ras_late_init(struct amdgpu_device *adev) static int mca_v3_0_mp1_ras_late_init(struct amdgpu_device *adev, void *ras_info)
{ {
return amdgpu_mca_ras_late_init(adev, &adev->mca.mp1); return amdgpu_mca_ras_late_init(adev, &adev->mca.mp1);
} }
...@@ -75,14 +95,21 @@ static void mca_v3_0_mp1_ras_fini(struct amdgpu_device *adev) ...@@ -75,14 +95,21 @@ static void mca_v3_0_mp1_ras_fini(struct amdgpu_device *adev)
amdgpu_mca_ras_fini(adev, &adev->mca.mp1); amdgpu_mca_ras_fini(adev, &adev->mca.mp1);
} }
const struct amdgpu_mca_ras_funcs mca_v3_0_mp1_ras_funcs = { const struct amdgpu_ras_block_hw_ops mca_v3_0_mp1_hw_ops = {
.ras_late_init = mca_v3_0_mp1_ras_late_init,
.ras_fini = mca_v3_0_mp1_ras_fini,
.query_ras_error_count = mca_v3_0_mp1_query_ras_error_count, .query_ras_error_count = mca_v3_0_mp1_query_ras_error_count,
.query_ras_error_address = NULL, .query_ras_error_address = NULL,
.ras_block = AMDGPU_RAS_BLOCK__MCA, };
.ras_sub_block = AMDGPU_RAS_MCA_BLOCK__MP1,
.sysfs_name = "mp1_err_count", struct amdgpu_mca_ras_block mca_v3_0_mp1_ras = {
.ras_block = {
.block = AMDGPU_RAS_BLOCK__MCA,
.sub_block_index = AMDGPU_RAS_MCA_BLOCK__MP1,
.name = "mp1",
.hw_ops = &mca_v3_0_mp1_hw_ops,
.ras_block_match = mca_v3_0_ras_block_match,
.ras_late_init = mca_v3_0_mp1_ras_late_init,
.ras_fini = mca_v3_0_mp1_ras_fini,
},
}; };
static void mca_v3_0_mpio_query_ras_error_count(struct amdgpu_device *adev, static void mca_v3_0_mpio_query_ras_error_count(struct amdgpu_device *adev,
...@@ -93,7 +120,7 @@ static void mca_v3_0_mpio_query_ras_error_count(struct amdgpu_device *adev, ...@@ -93,7 +120,7 @@ static void mca_v3_0_mpio_query_ras_error_count(struct amdgpu_device *adev,
ras_error_status); ras_error_status);
} }
static int mca_v3_0_mpio_ras_late_init(struct amdgpu_device *adev) static int mca_v3_0_mpio_ras_late_init(struct amdgpu_device *adev, void *ras_info)
{ {
return amdgpu_mca_ras_late_init(adev, &adev->mca.mpio); return amdgpu_mca_ras_late_init(adev, &adev->mca.mpio);
} }
...@@ -103,14 +130,21 @@ static void mca_v3_0_mpio_ras_fini(struct amdgpu_device *adev) ...@@ -103,14 +130,21 @@ static void mca_v3_0_mpio_ras_fini(struct amdgpu_device *adev)
amdgpu_mca_ras_fini(adev, &adev->mca.mpio); amdgpu_mca_ras_fini(adev, &adev->mca.mpio);
} }
const struct amdgpu_mca_ras_funcs mca_v3_0_mpio_ras_funcs = { const struct amdgpu_ras_block_hw_ops mca_v3_0_mpio_hw_ops = {
.ras_late_init = mca_v3_0_mpio_ras_late_init,
.ras_fini = mca_v3_0_mpio_ras_fini,
.query_ras_error_count = mca_v3_0_mpio_query_ras_error_count, .query_ras_error_count = mca_v3_0_mpio_query_ras_error_count,
.query_ras_error_address = NULL, .query_ras_error_address = NULL,
.ras_block = AMDGPU_RAS_BLOCK__MCA, };
.ras_sub_block = AMDGPU_RAS_MCA_BLOCK__MPIO,
.sysfs_name = "mpio_err_count", struct amdgpu_mca_ras_block mca_v3_0_mpio_ras = {
.ras_block = {
.block = AMDGPU_RAS_BLOCK__MCA,
.sub_block_index = AMDGPU_RAS_MCA_BLOCK__MPIO,
.name = "mpio",
.hw_ops = &mca_v3_0_mpio_hw_ops,
.ras_block_match = mca_v3_0_ras_block_match,
.ras_late_init = mca_v3_0_mpio_ras_late_init,
.ras_fini = mca_v3_0_mpio_ras_fini,
},
}; };
...@@ -118,9 +152,12 @@ static void mca_v3_0_init(struct amdgpu_device *adev) ...@@ -118,9 +152,12 @@ static void mca_v3_0_init(struct amdgpu_device *adev)
{ {
struct amdgpu_mca *mca = &adev->mca; struct amdgpu_mca *mca = &adev->mca;
mca->mp0.ras_funcs = &mca_v3_0_mp0_ras_funcs; mca->mp0.ras = &mca_v3_0_mp0_ras;
mca->mp1.ras_funcs = &mca_v3_0_mp1_ras_funcs; mca->mp1.ras = &mca_v3_0_mp1_ras;
mca->mpio.ras_funcs = &mca_v3_0_mpio_ras_funcs; mca->mpio.ras = &mca_v3_0_mpio_ras;
amdgpu_ras_register_ras_block(adev, &mca->mp0.ras->ras_block);
amdgpu_ras_register_ras_block(adev, &mca->mp1.ras->ras_block);
amdgpu_ras_register_ras_block(adev, &mca->mpio.ras->ras_block);
} }
const struct amdgpu_mca_funcs mca_v3_0_funcs = { const struct amdgpu_mca_funcs mca_v3_0_funcs = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment