return &fne->fae;
 }
 
+static struct fanotify_event *fanotify_alloc_error_event(
+                                               struct fsnotify_group *group,
+                                               __kernel_fsid_t *fsid,
+                                               const void *data, int data_type)
+{
+       struct fs_error_report *report =
+                       fsnotify_data_error_report(data, data_type);
+       struct fanotify_error_event *fee;
+
+       if (WARN_ON_ONCE(!report))
+               return NULL;
+
+       fee = mempool_alloc(&group->fanotify_data.error_events_pool, GFP_NOFS);
+       if (!fee)
+               return NULL;
+
+       fee->fae.type = FANOTIFY_EVENT_TYPE_FS_ERROR;
+
+       return &fee->fae;
+}
+
 static struct fanotify_event *fanotify_alloc_event(struct fsnotify_group *group,
                                                   u32 mask, const void *data,
                                                   int data_type, struct inode *dir,
 
        if (fanotify_is_perm_event(mask)) {
                event = fanotify_alloc_perm_event(path, gfp);
+       } else if (fanotify_is_error_event(mask)) {
+               event = fanotify_alloc_error_event(group, fsid, data,
+                                                  data_type);
        } else if (name_event && (file_name || child)) {
                event = fanotify_alloc_name_event(id, fsid, file_name, child,
                                                  &hash, gfp);
        kfree(FANOTIFY_NE(event));
 }
 
+static void fanotify_free_error_event(struct fsnotify_group *group,
+                                     struct fanotify_event *event)
+{
+       struct fanotify_error_event *fee = FANOTIFY_EE(event);
+
+       mempool_free(fee, &group->fanotify_data.error_events_pool);
+}
+
 static void fanotify_free_event(struct fsnotify_group *group,
                                struct fsnotify_event *fsn_event)
 {
        case FANOTIFY_EVENT_TYPE_OVERFLOW:
                kfree(event);
                break;
+       case FANOTIFY_EVENT_TYPE_FS_ERROR:
+               fanotify_free_error_event(group, event);
+               break;
        default:
                WARN_ON_ONCE(1);
        }
 
        return container_of(fse, struct fanotify_event, fse);
 }
 
+static inline bool fanotify_is_error_event(u32 mask)
+{
+       return mask & FAN_FS_ERROR;
+}
+
 static inline bool fanotify_event_has_path(struct fanotify_event *event)
 {
        return event->type == FANOTIFY_EVENT_TYPE_PATH ||
 static inline bool fanotify_is_hashed_event(u32 mask)
 {
        return !(fanotify_is_perm_event(mask) ||
+                fanotify_is_error_event(mask) ||
                 fsnotify_is_overflow_event(mask));
 }