Message ID | 20180227125230.13000-6-michal.winiarski@intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On 2/27/2018 6:22 PM, Michał Winiarski wrote: > We have all the information we need at relay_open call time. > Since there's no reason to split the process into relay_open and > relay_late_setup_files, let's remove the extra code. > > Signed-off-by: Michał Winiarski <michal.winiarski@intel.com> > Cc: Chris Wilson <chris@chris-wilson.co.uk> > Cc: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com> > Cc: Sagar Arun Kamble <sagar.a.kamble@intel.com> > Cc: Michal Wajdeczko <michal.wajdeczko@intel.com> Looks good to me. Comment updates needed. With that: Reviewed-by: Sagar Arun Kamble <sagar.a.kamble@intel.com> > --- > drivers/gpu/drm/i915/intel_guc_log.c | 52 ++++-------------------------------- > 1 file changed, 5 insertions(+), 47 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_guc_log.c b/drivers/gpu/drm/i915/intel_guc_log.c > index 567620464f52..cbbdb400fa17 100644 > --- a/drivers/gpu/drm/i915/intel_guc_log.c > +++ b/drivers/gpu/drm/i915/intel_guc_log.c > @@ -126,7 +126,7 @@ static struct dentry *create_buf_file_callback(const char *filename, > * dentry of the file associated with the channel buffer and that file's > * name need not be same as the filename passed as an argument. > */ Need to update comment as we are using channel filename now. > - buf_file = debugfs_create_file("guc_log", mode, > + buf_file = debugfs_create_file(filename, mode, > parent, buf, &relay_file_operations); > return buf_file; > } > @@ -147,43 +147,6 @@ static struct rchan_callbacks relay_callbacks = { > .remove_buf_file = remove_buf_file_callback, > }; > > -static int guc_log_relay_file_create(struct intel_guc *guc) > -{ > - struct drm_i915_private *dev_priv = guc_to_i915(guc); > - struct dentry *log_dir; > - int ret; > - > - lockdep_assert_held(&guc->log.runtime.lock); > - > - /* For now create the log file in /sys/kernel/debug/dri/0 dir */ > - log_dir = dev_priv->drm.primary->debugfs_root; > - > - /* > - * If /sys/kernel/debug/dri/0 location do not exist, then debugfs is > - * not mounted and so can't create the relay file. > - * The relay API seems to fit well with debugfs only, for availing relay > - * there are 3 requirements which can be met for debugfs file only in a > - * straightforward/clean manner :- > - * i) Need the associated dentry pointer of the file, while opening the > - * relay channel. > - * ii) Should be able to use 'relay_file_operations' fops for the file. > - * iii) Set the 'i_private' field of file's inode to the pointer of > - * relay channel buffer. > - */ > - if (!log_dir) { > - DRM_ERROR("Debugfs dir not available yet for GuC log file\n"); > - return -ENODEV; > - } > - > - ret = relay_late_setup_files(guc->log.runtime.relay_chan, "guc_log", log_dir); > - if (ret < 0 && ret != -EEXIST) { > - DRM_ERROR("Couldn't associate relay chan with file %d\n", ret); > - return ret; > - } > - > - return 0; > -} > - > static void guc_move_to_next_buf(struct intel_guc *guc) > { > /* > @@ -267,7 +230,6 @@ static void guc_read_update_log_buffer(struct intel_guc *guc) > /* Get the pointer to shared GuC log buffer */ > log_buf_state = src_data = guc->log.runtime.buf_addr; > > - > /* Get the pointer to local buffer to store the logs */ > log_buf_snapshot_state = dst_data = guc_get_write_buffer(guc); > > @@ -436,8 +398,10 @@ int guc_log_relay_create(struct intel_guc *guc) > * the GuC firmware logs, the channel will be linked with a file > * later on when debugfs is registered. > */ and comment here as well. > - guc_log_relay_chan = relay_open(NULL, NULL, subbuf_size, > - n_subbufs, &relay_callbacks, dev_priv); > + guc_log_relay_chan = relay_open("guc_log", > + dev_priv->drm.primary->debugfs_root, > + subbuf_size, n_subbufs, > + &relay_callbacks, dev_priv); > if (!guc_log_relay_chan) { > DRM_ERROR("Couldn't create relay chan for GuC logging\n"); > > @@ -648,18 +612,12 @@ int intel_guc_log_register(struct intel_guc *guc) > if (ret) > goto err_relay; > > - ret = guc_log_relay_file_create(guc); > - if (ret) > - goto err_unmap; > - > guc_log_flush_irq_enable(guc); > > mutex_unlock(&guc->log.runtime.lock); > > return 0; > > -err_unmap: > - guc_log_unmap(guc); > err_relay: > guc_log_relay_destroy(guc); > err:
diff --git a/drivers/gpu/drm/i915/intel_guc_log.c b/drivers/gpu/drm/i915/intel_guc_log.c index 567620464f52..cbbdb400fa17 100644 --- a/drivers/gpu/drm/i915/intel_guc_log.c +++ b/drivers/gpu/drm/i915/intel_guc_log.c @@ -126,7 +126,7 @@ static struct dentry *create_buf_file_callback(const char *filename, * dentry of the file associated with the channel buffer and that file's * name need not be same as the filename passed as an argument. */ - buf_file = debugfs_create_file("guc_log", mode, + buf_file = debugfs_create_file(filename, mode, parent, buf, &relay_file_operations); return buf_file; } @@ -147,43 +147,6 @@ static struct rchan_callbacks relay_callbacks = { .remove_buf_file = remove_buf_file_callback, }; -static int guc_log_relay_file_create(struct intel_guc *guc) -{ - struct drm_i915_private *dev_priv = guc_to_i915(guc); - struct dentry *log_dir; - int ret; - - lockdep_assert_held(&guc->log.runtime.lock); - - /* For now create the log file in /sys/kernel/debug/dri/0 dir */ - log_dir = dev_priv->drm.primary->debugfs_root; - - /* - * If /sys/kernel/debug/dri/0 location do not exist, then debugfs is - * not mounted and so can't create the relay file. - * The relay API seems to fit well with debugfs only, for availing relay - * there are 3 requirements which can be met for debugfs file only in a - * straightforward/clean manner :- - * i) Need the associated dentry pointer of the file, while opening the - * relay channel. - * ii) Should be able to use 'relay_file_operations' fops for the file. - * iii) Set the 'i_private' field of file's inode to the pointer of - * relay channel buffer. - */ - if (!log_dir) { - DRM_ERROR("Debugfs dir not available yet for GuC log file\n"); - return -ENODEV; - } - - ret = relay_late_setup_files(guc->log.runtime.relay_chan, "guc_log", log_dir); - if (ret < 0 && ret != -EEXIST) { - DRM_ERROR("Couldn't associate relay chan with file %d\n", ret); - return ret; - } - - return 0; -} - static void guc_move_to_next_buf(struct intel_guc *guc) { /* @@ -267,7 +230,6 @@ static void guc_read_update_log_buffer(struct intel_guc *guc) /* Get the pointer to shared GuC log buffer */ log_buf_state = src_data = guc->log.runtime.buf_addr; - /* Get the pointer to local buffer to store the logs */ log_buf_snapshot_state = dst_data = guc_get_write_buffer(guc); @@ -436,8 +398,10 @@ int guc_log_relay_create(struct intel_guc *guc) * the GuC firmware logs, the channel will be linked with a file * later on when debugfs is registered. */ - guc_log_relay_chan = relay_open(NULL, NULL, subbuf_size, - n_subbufs, &relay_callbacks, dev_priv); + guc_log_relay_chan = relay_open("guc_log", + dev_priv->drm.primary->debugfs_root, + subbuf_size, n_subbufs, + &relay_callbacks, dev_priv); if (!guc_log_relay_chan) { DRM_ERROR("Couldn't create relay chan for GuC logging\n"); @@ -648,18 +612,12 @@ int intel_guc_log_register(struct intel_guc *guc) if (ret) goto err_relay; - ret = guc_log_relay_file_create(guc); - if (ret) - goto err_unmap; - guc_log_flush_irq_enable(guc); mutex_unlock(&guc->log.runtime.lock); return 0; -err_unmap: - guc_log_unmap(guc); err_relay: guc_log_relay_destroy(guc); err:
We have all the information we need at relay_open call time. Since there's no reason to split the process into relay_open and relay_late_setup_files, let's remove the extra code. Signed-off-by: Michał Winiarski <michal.winiarski@intel.com> Cc: Chris Wilson <chris@chris-wilson.co.uk> Cc: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com> Cc: Sagar Arun Kamble <sagar.a.kamble@intel.com> Cc: Michal Wajdeczko <michal.wajdeczko@intel.com> --- drivers/gpu/drm/i915/intel_guc_log.c | 52 ++++-------------------------------- 1 file changed, 5 insertions(+), 47 deletions(-)