teensy4-rs icon indicating copy to clipboard operation
teensy4-rs copied to clipboard

Also depending on defmt_rtt causes linker error

Open cstrahan opened this issue 1 year ago • 3 comments

Describe the bug

If I have teensy4-bsp as a dependency and defmt_rtt, I run into the follow linker error:

error: linking with `rust-lld` failed: exit status: 1
  |
  = note: "rust-lld" "-flavor" "gnu" "/tmp/rustcWb1qH0/symbols.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1698cbrh57m8zbig.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.17hqc163sowduikf.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1c0pke542efhztpa.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1gcy1l9q970kethh.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1hjytgrzn014pvny.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1hrzdi77cga39c2c.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1o7gpd7sbhf6diez.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1svgbdrp2txfc9df.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1wiikf5tl97w8lw9.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1y7l2rxqxmu81j6w.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.1y8yj1hjx42jkhbb.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.23eso5siv5miqgeg.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.2496ubo6dilz0dh0.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.24xsif871styfzdz.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.2fwd7xdgzohquhah.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.2mv6mmdfxcm2vodx.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.2ti6y79n82ij49gd.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.2vzrlktgipihdmi2.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.2wo8hke1hcvacqhr.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.31r4btohq5ecferm.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.33tw4p1tpaprbh1o.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.38d0ov15dwzqoogj.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.3gfy98u2kewwq410.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.3iewsmvvwtpzv7py.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.3kj81ct46ylel0kf.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.3ytcznt1h62or4hr.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.40ovhf3ego2s7ig3.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4194rbwvhr01zp8b.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.41pn65j27f54qux3.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.42q6yvdpvkxi5a3v.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4670j36h8p8l19y2.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4aszei5q1o6vte7p.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4lgo8xmi6jxb5zz7.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4ly43frrlq8qxr2k.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4nhzwoc8gfl86v7n.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4ov65bxvphj1wh3e.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4qb4mw64m1afmehv.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4qcvdj5yk4tr85wf.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.4yaf87072awaku4w.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.548obllg8xjin87e.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.58fsjwaubq4n7ej3.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.59orvig4dovnfi13.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.5aglzkmhce3g66wk.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.h6x7yhwp74mfihj.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.k322i9aocp18ktj.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.mfmj2tv592a8kju.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.vntr5sypm3ijwp6.rcgu.o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8.y9t6s2yq1mavajr.rcgu.o" "--as-needed" "-L" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps" "-L" "/home/cstrahan/src/hello-teensy/target/debug/deps" "-L" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/build/cortex-m-6a37c50e708cf516/out" "-L" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/build/cortex-m-rt-cc7a386d27b79b4e/out" "-L" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/build/defmt-b113be18faa0503d/out" "-L" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/build/teensy4-bsp-1f714b3b36da0a35/out" "-L" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/build/imxrt-ral-c74ab446f64d079b/out" "-L" "/home/cstrahan/.rustup/toolchains/stable-x86_64-unknown-linux-gnu/lib/rustlib/thumbv7em-none-eabihf/lib" "-Bstatic" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libdefmt_rtt-fa04cffbc8b7768e.rlib" "--start-group" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libteensy4_panic-00dcdb87c834a2e3.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libteensy4_bsp-db0abac9bda853f1.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libteensy4_fcb-f966d99042a0f0b1.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_boot_gen-1677db8c64ed0202.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libteensy4_pins-c53fad41ea7b571c.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_rt-f90588d32a69444c.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_log-706459c02f6ee9f8.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libusbd_serial-e1fa295ced35fda3.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/liblog-cb9733bf151d6000.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libdefmt-39d45ba5368247b8.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libbbqueue-dc74669a6984b1be.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_hal-bb43c4e790fa1c59.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libfugit-b9705af0257410c7.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libgcd-892b231ba8b31be9.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libcfg_if-0ad3b77ad375d821.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_usbd-2598f0529b2e2b69.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libbitflags-19dbb7f029acf790.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libusb_device-1ba7449f597739d6.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_dma-5abb3e0e98823f44.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_ral-5ff00c5942a13b8d.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libral_registers-97f43ded08e78683.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_iomuxc-157500efa95fa2e9.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libcortex_m_rt-3c646330265b2911.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libcortex_m-ca2e426d88a9bb11.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libembedded_hal-069bb70b6c321d93.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libvoid-c50586df6ec5a499.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libnb-150933db1dae51b0.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libnb-7491f12c028aa802.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libcritical_section-994236c64a420eaa.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libvolatile_register-e41c248030b4467d.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libvcell-2df741877111b647.rlib" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libbare_metal-b7d81898d145dd3d.rlib" "/home/cstrahan/.rustup/toolchains/stable-x86_64-unknown-linux-gnu/lib/rustlib/thumbv7em-none-eabihf/lib/librustc_std_workspace_core-d7ce7a7285aa2f5d.rlib" "/home/cstrahan/.rustup/toolchains/stable-x86_64-unknown-linux-gnu/lib/rustlib/thumbv7em-none-eabihf/lib/libcore-b31aee0fbd201a8d.rlib" "--end-group" "/home/cstrahan/.rustup/toolchains/stable-x86_64-unknown-linux-gnu/lib/rustlib/thumbv7em-none-eabihf/lib/libcompiler_builtins-1c8ac2583d77193f.rlib" "-Bdynamic" "--eh-frame-hdr" "-znoexecstack" "-L" "/home/cstrahan/.rustup/toolchains/stable-x86_64-unknown-linux-gnu/lib/rustlib/thumbv7em-none-eabihf/lib" "-o" "/home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/hello_teensy-74cd17b2013ebba8" "--gc-sections" "-Tt4link.x" "-Tdefmt.x"
  = note: rust-lld: error: duplicate symbol: _defmt_acquire
          >>> defined at lib.rs:43 (src/lib.rs:43)
          >>>            defmt_rtt-fa04cffbc8b7768e.defmt_rtt.ff6b3d8a-cgu.6.rcgu.o:(_defmt_acquire) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libdefmt_rtt-fa04cffbc8b7768e.rlib
          >>> defined at defmt.rs:104 (src/defmt.rs:104)
          >>>            imxrt_log-706459c02f6ee9f8.imxrt_log.3e92aa03-cgu.5.rcgu.o:(.text._defmt_acquire+0x1) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_log-706459c02f6ee9f8.rlib
          
          rust-lld: error: duplicate symbol: _defmt_flush
          >>> defined at lib.rs:43 (src/lib.rs:43)
          >>>            defmt_rtt-fa04cffbc8b7768e.defmt_rtt.ff6b3d8a-cgu.6.rcgu.o:(_defmt_flush) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libdefmt_rtt-fa04cffbc8b7768e.rlib
          >>> defined at defmt.rs:104 (src/defmt.rs:104)
          >>>            imxrt_log-706459c02f6ee9f8.imxrt_log.3e92aa03-cgu.5.rcgu.o:(.text._defmt_flush+0x1) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_log-706459c02f6ee9f8.rlib
          
          rust-lld: error: duplicate symbol: _defmt_release
          >>> defined at lib.rs:43 (src/lib.rs:43)
          >>>            defmt_rtt-fa04cffbc8b7768e.defmt_rtt.ff6b3d8a-cgu.6.rcgu.o:(_defmt_release) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libdefmt_rtt-fa04cffbc8b7768e.rlib
          >>> defined at defmt.rs:104 (src/defmt.rs:104)
          >>>            imxrt_log-706459c02f6ee9f8.imxrt_log.3e92aa03-cgu.5.rcgu.o:(.text._defmt_release+0x1) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_log-706459c02f6ee9f8.rlib
          
          rust-lld: error: duplicate symbol: _defmt_write
          >>> defined at lib.rs:43 (src/lib.rs:43)
          >>>            defmt_rtt-fa04cffbc8b7768e.defmt_rtt.ff6b3d8a-cgu.6.rcgu.o:(_defmt_write) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libdefmt_rtt-fa04cffbc8b7768e.rlib
          >>> defined at defmt.rs:104 (src/defmt.rs:104)
          >>>            imxrt_log-706459c02f6ee9f8.imxrt_log.3e92aa03-cgu.5.rcgu.o:(.text._defmt_write+0x1) in archive /home/cstrahan/src/hello-teensy/target/thumbv7em-none-eabihf/debug/deps/libimxrt_log-706459c02f6ee9f8.rlib

If I make the following change then I can compile successfully:

diff --git a/Cargo.toml b/Cargo.toml
index 0953c94..f2c8df8 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -48,7 +48,7 @@ features = ["imxrt1060"]
 [dependencies.imxrt-log]
 version = "0.1"
 default-features = false
-features = ["usbd", "log", "defmt"]
+#features = ["usbd", "log", "defmt"]
 
 [dependencies.imxrt-rt]
 version = "0.1"

To Reproduce

Build with both teensy4-bsp as a dependency and defmt_rtt.

Expected behavior

Should compile successfully.

Additional context :thinking:

cstrahan avatar Feb 12 '23 05:02 cstrahan