]> Git Repo - linux.git/blobdiff - drivers/gpu/drm/amd/amdgpu/amdgpu_ras.c
Merge tag 'for-5.2/block-post-20190516' of git://git.kernel.dk/linux-block
[linux.git] / drivers / gpu / drm / amd / amdgpu / amdgpu_ras.c
index 469cb6477b8e294f273d1c647f7031127cf1dcf3..22bd21efe6b1edf26f2b7f68a82e864e307208ac 100644 (file)
@@ -530,6 +530,33 @@ int amdgpu_ras_feature_enable(struct amdgpu_device *adev,
        return 0;
 }
 
+/* Only used in device probe stage and called only once. */
+int amdgpu_ras_feature_enable_on_boot(struct amdgpu_device *adev,
+               struct ras_common_if *head, bool enable)
+{
+       struct amdgpu_ras *con = amdgpu_ras_get_context(adev);
+       int ret;
+
+       if (!con)
+               return -EINVAL;
+
+       if (con->flags & AMDGPU_RAS_FLAG_INIT_BY_VBIOS) {
+               /* If ras is enabled by vbios, we set up ras object first in
+                * both case. For enable, that is all what we need do. For
+                * disable, we need perform a ras TA disable cmd after that.
+                */
+               ret = __amdgpu_ras_feature_enable(adev, head, 1);
+               if (ret)
+                       return ret;
+
+               if (!enable)
+                       ret = amdgpu_ras_feature_enable(adev, head, 0);
+       } else
+               ret = amdgpu_ras_feature_enable(adev, head, enable);
+
+       return ret;
+}
+
 static int amdgpu_ras_disable_all_features(struct amdgpu_device *adev,
                bool bypass)
 {
@@ -558,11 +585,13 @@ static int amdgpu_ras_enable_all_features(struct amdgpu_device *adev,
        struct amdgpu_ras *con = amdgpu_ras_get_context(adev);
        int ras_block_count = AMDGPU_RAS_BLOCK_COUNT;
        int i;
+       const enum amdgpu_ras_error_type default_ras_type =
+               AMDGPU_RAS_ERROR__NONE;
 
        for (i = 0; i < ras_block_count; i++) {
                struct ras_common_if head = {
                        .block = i,
-                       .type = AMDGPU_RAS_ERROR__MULTI_UNCORRECTABLE,
+                       .type = default_ras_type,
                        .sub_block_index = 0,
                };
                strcpy(head.name, ras_block_str(i));
@@ -1368,9 +1397,6 @@ int amdgpu_ras_init(struct amdgpu_device *adev)
 
        amdgpu_ras_mask &= AMDGPU_RAS_BLOCK_MASK;
 
-       if (con->flags & AMDGPU_RAS_FLAG_INIT_BY_VBIOS)
-               amdgpu_ras_enable_all_features(adev, 1);
-
        if (amdgpu_ras_fs_init(adev))
                goto fs_out;
 
@@ -1398,18 +1424,25 @@ void amdgpu_ras_post_init(struct amdgpu_device *adev)
        if (!con)
                return;
 
-       /* We enable ras on all hw_supported block, but as boot parameter might
-        * disable some of them and one or more IP has not implemented yet.
-        * So we disable them on behalf.
-        */
        if (con->flags & AMDGPU_RAS_FLAG_INIT_BY_VBIOS) {
+               /* Set up all other IPs which are not implemented. There is a
+                * tricky thing that IP's actual ras error type should be
+                * MULTI_UNCORRECTABLE, but as driver does not handle it, so
+                * ERROR_NONE make sense anyway.
+                */
+               amdgpu_ras_enable_all_features(adev, 1);
+
+               /* We enable ras on all hw_supported block, but as boot
+                * parameter might disable some of them and one or more IP has
+                * not implemented yet. So we disable them on behalf.
+                */
                list_for_each_entry_safe(obj, tmp, &con->head, node) {
                        if (!amdgpu_ras_is_supported(adev, obj->head.block)) {
                                amdgpu_ras_feature_enable(adev, &obj->head, 0);
                                /* there should be no any reference. */
                                WARN_ON(alive_obj(obj));
                        }
-               };
+               }
        }
 }
 
This page took 0.033112 seconds and 4 git commands to generate.