Skip to content

Commit

Permalink
Avoid allocating memory every time we might log a label (#4893)
Browse files Browse the repository at this point in the history
We allocate a String every time we want to get a label for logging. The string is also allocated when logging is disabled. Either way, the allocation is unnecessary. This commit replaces the String with a dyn Debug reference which does not need any allocation.
  • Loading branch information
nical authored Dec 18, 2023
1 parent 625165e commit a1b183f
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 19 deletions.
6 changes: 3 additions & 3 deletions wgpu-core/src/binding_model.rs
Original file line number Diff line number Diff line change
Expand Up @@ -467,7 +467,7 @@ pub struct BindGroupLayout<A: HalApi> {
impl<A: HalApi> Drop for BindGroupLayout<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw BindGroupLayout {}", self.info.label());
resource_log!("Destroy raw BindGroupLayout {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_bind_group_layout(raw);
Expand Down Expand Up @@ -605,7 +605,7 @@ pub struct PipelineLayout<A: HalApi> {
impl<A: HalApi> Drop for PipelineLayout<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw PipelineLayout {}", self.info.label());
resource_log!("Destroy raw PipelineLayout {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_pipeline_layout(raw);
Expand Down Expand Up @@ -826,7 +826,7 @@ pub struct BindGroup<A: HalApi> {
impl<A: HalApi> Drop for BindGroup<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw BindGroup {}", self.info.label());
resource_log!("Destroy raw BindGroup {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_bind_group(raw);
Expand Down
2 changes: 1 addition & 1 deletion wgpu-core/src/command/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ impl<A: HalApi> Drop for CommandBuffer<A> {
if self.data.lock().is_none() {
return;
}
resource_log!("resource::CommandBuffer::drop {}", self.info.label());
resource_log!("resource::CommandBuffer::drop {:?}", self.info.label());
let mut baked = self.extract_baked_commands();
unsafe {
baked.encoder.reset_all(baked.list.into_iter());
Expand Down
2 changes: 1 addition & 1 deletion wgpu-core/src/device/resource.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,7 @@ impl<A: HalApi> std::fmt::Debug for Device<A> {

impl<A: HalApi> Drop for Device<A> {
fn drop(&mut self) {
resource_log!("Destroy raw Device {}", self.info.label());
resource_log!("Destroy raw Device {:?}", self.info.label());
let raw = self.raw.take().unwrap();
let pending_writes = self.pending_writes.lock().take().unwrap();
pending_writes.dispose(&raw);
Expand Down
6 changes: 3 additions & 3 deletions wgpu-core/src/pipeline.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ pub struct ShaderModule<A: HalApi> {
impl<A: HalApi> Drop for ShaderModule<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw ShaderModule {}", self.info.label());
resource_log!("Destroy raw ShaderModule {:?}", self.info.label());
#[cfg(feature = "trace")]
if let Some(ref mut trace) = *self.device.trace.lock() {
trace.add(trace::Action::DestroyShaderModule(self.info.id()));
Expand Down Expand Up @@ -250,7 +250,7 @@ pub struct ComputePipeline<A: HalApi> {
impl<A: HalApi> Drop for ComputePipeline<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw ComputePipeline {}", self.info.label());
resource_log!("Destroy raw ComputePipeline {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_compute_pipeline(raw);
Expand Down Expand Up @@ -491,7 +491,7 @@ pub struct RenderPipeline<A: HalApi> {
impl<A: HalApi> Drop for RenderPipeline<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw RenderPipeline {}", self.info.label());
resource_log!("Destroy raw RenderPipeline {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_render_pipeline(raw);
Expand Down
26 changes: 15 additions & 11 deletions wgpu-core/src/resource.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,15 +94,19 @@ impl<Id: TypedId> ResourceInfo<Id> {
}
}

pub(crate) fn label(&self) -> String
pub(crate) fn label(&self) -> &dyn Debug
where
Id: Debug,
{
if let Some(id) = self.id.as_ref() {
format!("[{}] {:?}", self.label, id)
} else {
format!("[{}]", self.label)
if !self.label.is_empty() {
return &self.label;
}

if let Some(id) = &self.id {
return id;
}

&""
}

pub(crate) fn id(&self) -> Id {
Expand Down Expand Up @@ -409,7 +413,7 @@ pub struct Buffer<A: HalApi> {
impl<A: HalApi> Drop for Buffer<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw Buffer {}", self.info.label());
resource_log!("Destroy raw Buffer {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_buffer(raw);
Expand Down Expand Up @@ -638,7 +642,7 @@ pub struct StagingBuffer<A: HalApi> {
impl<A: HalApi> Drop for StagingBuffer<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.lock().take() {
resource_log!("Destroy raw StagingBuffer {}", self.info.label());
resource_log!("Destroy raw StagingBuffer {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_buffer(raw);
Expand Down Expand Up @@ -720,7 +724,7 @@ pub struct Texture<A: HalApi> {

impl<A: HalApi> Drop for Texture<A> {
fn drop(&mut self) {
resource_log!("Destroy raw Texture {}", self.info.label());
resource_log!("Destroy raw Texture {:?}", self.info.label());
use hal::Device;
let mut clear_mode = self.clear_mode.write();
let clear_mode = &mut *clear_mode;
Expand Down Expand Up @@ -1052,7 +1056,7 @@ pub struct TextureView<A: HalApi> {
impl<A: HalApi> Drop for TextureView<A> {
fn drop(&mut self) {
if let Some(raw) = self.raw.take() {
resource_log!("Destroy raw TextureView {}", self.info.label());
resource_log!("Destroy raw TextureView {:?}", self.info.label());
unsafe {
use hal::Device;
self.device.raw().destroy_texture_view(raw);
Expand Down Expand Up @@ -1173,7 +1177,7 @@ pub struct Sampler<A: HalApi> {

impl<A: HalApi> Drop for Sampler<A> {
fn drop(&mut self) {
resource_log!("Destroy raw Sampler {}", self.info.label());
resource_log!("Destroy raw Sampler {:?}", self.info.label());
if let Some(raw) = self.raw.take() {
unsafe {
use hal::Device;
Expand Down Expand Up @@ -1270,7 +1274,7 @@ pub struct QuerySet<A: HalApi> {

impl<A: HalApi> Drop for QuerySet<A> {
fn drop(&mut self) {
resource_log!("Destroy raw QuerySet {}", self.info.label());
resource_log!("Destroy raw QuerySet {:?}", self.info.label());
if let Some(raw) = self.raw.take() {
unsafe {
use hal::Device;
Expand Down

0 comments on commit a1b183f

Please sign in to comment.