LetoThe2nd changed the topic of #yocto to: Welcome to the Yocto Project | Learn more: https://www.yoctoproject.org | Community: https://www.yoctoproject.org/community | IRC logs: http://irc.yoctoproject.org/irc/ | Having difficulty on the list, with someone on the list or on IRC, contact Yocto Project Community Manager Letothe2nd | CoC: https://www.yoctoproject.org/community/code-of-conduct
warthog9 has quit [Remote host closed the connection]
Wouter0100670440 has quit [Quit: The Lounge - https://thelounge.chat]
Wouter0100670440 has joined #yocto
warthog9 has joined #yocto
<mischief> Marian46: maybe pass rdinit=/bin/...
<mischief> or just install your own symlink for init somewhere in the image recipe
otavio has joined #yocto
Ablu has quit [Ping timeout: 245 seconds]
jclsn has quit [Ping timeout: 260 seconds]
Ablu has joined #yocto
<khem> belgianguy: you might look into uefi support and its good for arm64 look into meta-arm, however, yocto does not provide infra for signing keys etc. its left to the distros
<khem> belgianguy: I would suggest to look into debian secure boot process
Marian46 has quit [Quit: Client closed]
Marian88 has joined #yocto
<Marian88> Finally I managed to boot a initramfs using: INITRAMFS_SCRIPTS = " initramfs-boot ". The only problem that I still have is the root password. I'm using -EXTRA_IMAGE_FEATURES ?= "debug-tweaks", but the initramfs image seems to not have this option enabled
<Marian88> genericx86-64 login: root
<Marian88> Password:
<Marian88> Login incorrect
<Marian88> genericx86-64 login: root
<Marian88> Password:
<Marian88> Login incorrect
<Marian88> genericx86-64 login:
<Marian88> any idea
<Marian88> ?
Marian88 has quit [Quit: Client closed]
Marian55 has joined #yocto
<khem> Marian55: Perhaps add IMAGE_FEATURES:append = " empty-root-password" in local.conf
starblue has quit [Ping timeout: 245 seconds]
starblue has joined #yocto
xmn has quit [Quit: ZZZzzz…]
Marian55 has quit [Quit: Client closed]
belgianguy has quit [Ping timeout: 245 seconds]
xmn has joined #yocto
Marian89 has joined #yocto
<Marian89> I managed to fix it via "+IMAGE_FEATURES:append = "${EXTRA_IMAGE_FEATURES}""
<Marian89> in the -initramfs.bb image
LocutusOfBorg has quit [Read error: Connection reset by peer]
LocutusOfBorg has joined #yocto
jclsn has joined #yocto
xmn has quit [Ping timeout: 248 seconds]
xmn has joined #yocto
otavio has quit [Ping timeout: 244 seconds]
rob_w has joined #yocto
Xhivo has joined #yocto
goliath has joined #yocto
valdemaras has joined #yocto
rfuentess has joined #yocto
warthog9 has quit [Quit: Leaving]
Wouter0100670440 has quit [Ping timeout: 256 seconds]
xmn has quit [Quit: ZZZzzz…]
mckoan|away is now known as mckoan
<mckoan> good morning
frieder has joined #yocto
pgowda_ has joined #yocto
valdemaras has quit [Quit: valdemaras]
warthog9 has joined #yocto
Schlumpf has joined #yocto
xmn has joined #yocto
AKN has joined #yocto
leon-anavi has joined #yocto
olani- has quit [Ping timeout: 246 seconds]
paulg has joined #yocto
valdemaras has joined #yocto
florian has joined #yocto
florian_kc has joined #yocto
<kanavin> y2038 facepalm of the day
<kanavin> void
<kanavin> _dbus_get_real_time (long *tv_sec,
<kanavin> long *tv_usec)
<kanavin> {
<kanavin> used throughout dbus, obviously
<RP> kanavin: it isn't something you'd think about :/
<kanavin> RP: not quite; the implementation does
<kanavin> struct timeval t;
<kanavin> gettimeofday (&t, NULL);
<kanavin> if (tv_sec)
<kanavin> *tv_sec = t.tv_sec;
<kanavin> if (tv_usec)
<kanavin> *tv_usec = t.tv_usec;
<kanavin> }
<kanavin> at which point it would be prudent to look up data types in timeval
<kanavin> (tv_sec would be time_t)
<RP> kanavin: ah right :/
Guest50 has joined #yocto
<Guest50> Isd there any way to lilst valid target architectures for a recipe which builds in a different subdirectory of tmp/work on a different computer ?
<Guest50> basically a recipe build on the correct subdirectory of /tmp/work on my station and finds what it needs there, but on a different computer it builds in another subdirectory and does not find one projects it needs to build come of its libraries
<Guest50> to build ONE of its libraries*
<Guest50> and decides to ignore this during its do_configure
<Guest50> not sure how to change the recipe to "force" it into the right build/tmp/work/ subdirectory
<Guest50> never needed to on my station
Xhivo has quit [Ping timeout: 246 seconds]
<ptsneves> Guest50: I do not think it is a good idea to depend on the tmp/work directory. If you need outputs from the recipe you should deploy it somewhere
<Guest50> but how comes the recipe builds in a different subdirectory on a different machine?
xmn has quit [Quit: ZZZzzz…]
<kanavin> RP: what I don't understand is why c compiler is happy with that. Surely assigning long long to long or long to int should be at least a warning?
<RP> kanavin: I'd have thought the compiler would show a warning
<RP> probably depends on the compiler options?
<kanavin> RP: I just wrote a trivial program to check and there's not warning, not with Wall
<kanavin> is there some Wreally-super-duper-all maybe?
prabhakarlad has joined #yocto
<Guest50> RP: -Wall -Wextra ... Some diagnostics for non-ISO practices are controlled by specific warning options other than -Wpedantic, but are also made errors by -pedantic-errors
<kanavin> Guest50, all, extra, pedantic. Adding all three still doesn't make a warning.
<Guest50> RP:  version of gcc are you using?
<kanavin> I guess the question is for me? 12.2.0
<Guest50> try issuing a sizeof() of the respective integers,
<kanavin> 4 for int, 8 for long long
<kanavin> no warning
<kanavin> #include <stdio.h>
<kanavin> int main(){
<kanavin> a = b;
<kanavin> int a;
<kanavin> long long b = -3000000000;
<kanavin> printf("%d %ld\n",a, sizeof(a));
<kanavin> printf("%lld %ld\n",b, sizeof(b));
<kanavin> }
<RP> kanavin: this is more khem's area than mine to tbh, I just work out how to build the compilers...
<kanavin> RP: I think it's more or less clear gcc won't help, and maybe there's some awful reason why :-(
<kanavin> such as 'programmers should know what they're doing, and it's their fault if they mess up'
<RP> kanavin: I fear that may be the case
MrFrank has quit [Ping timeout: 246 seconds]
<sudip> kanavin: you can use -Wconversion
<sudip> I used that with your code and:
<sudip> test.c:7:5: warning: conversion from ‘long long int’ to ‘int’ may change value [-Wconversion]
<kanavin> sudip, right! why is it not in all or extra or pedantic?
MrFrank has joined #yocto
* sudip has no idea why
<ptsneves> Does anybody know why in get_taskhahs@siggen.py, the iteration of self.file_checksum_values[tid] is unsorted? I had 2 signatures which are identical except the file list is in a slightly different order leading to a different taskhsh
<rburton> ptsneves: sounds like a bug to me
wyre_ has joined #yocto
wyre has quit [Read error: Connection reset by peer]
<ptsneves> rburton: ok. Will try to sort the list and see if the hashes come out correctly
<RP> ptsneves: definitely a bug
<Guest50> still looking for an answer to previously posted question(s)
<Guest50> still need to understand so I can rectify the problem
olani- has joined #yocto
<ptsneves> Guest50: Try bitbake-getvar -r <recipe> WORKDIR on both machines and see where the values come from
<Guest50> ptsneves: Thank you, will try that as soon as the respective builds finish
starblue has quit [Ping timeout: 250 seconds]
Wouter0100670440 has joined #yocto
wyre_ has quit [Quit: ZNC 1.8.2 - https://znc.in]
starblue has joined #yocto
wyre has joined #yocto
MrFrank has quit [Read error: Connection reset by peer]
Schlumpf has quit [Quit: Client closed]
Schlumpf has joined #yocto
<ptsneves> RP: Ironically the dump_sigfile function sorts a_data['file_checksum_values']. I only spotted this because i opened the signatures directly with zstdcat
GNUmoon has quit [Ping timeout: 246 seconds]
Guest50 has quit [Quit: Client closed]
Schlumpf48 has joined #yocto
Schlumpf has quit [Ping timeout: 246 seconds]
MrFrank has joined #yocto
GNUmoon has joined #yocto
camus has quit [Ping timeout: 246 seconds]
camus has joined #yocto
<mcfrisk> How are poky oe-selftests executed on autobuilder(s)? I'd like to know what's in their conf/local.conf, auto.conf and site.conf
<mcfrisk> kanavin: what does test_testimage_virgl_headless need from the build host? some GPU HW or just vgem kernel module?
<mcfrisk> on my x86_64 build machine with "Integrated Matrox G200eW3 Graphics Controller", starting qemu with GPU support is always failing and thus test_testimage_virgl_headless too. loading vgem kernel module doesn't help. What do the upstream build/test servers have?
Estrella has quit [Ping timeout: 256 seconds]
<RP> ptsneves: yes, well spotted!
<RP> ptsneves: I'd be happy to fix that issue
<RP> mcfrisk: you can see it in the logs?
<RP> that one is an arm worker but you get the idea
<RP> mcfrisk: I think that test is excluded on some distros and has some host requirements
<kanavin> mcfrisk, loading vgem should help, that's what yocto ci does
<kanavin> spcifically vgem should create /dev/dri/renderD* entries, if the gpu driver does not
<mcfrisk> kanavin: I loaded the vgem module but starting qemu still fails with "qemu-system-x86_64: egl: render node init failed"
<kanavin> are permissions correct?
<mcfrisk> I saw that /dev/dri/renderD128 is created, ah I don't render group rights, will add and try again. thanks!
<kanavin> mcfrisk, qemu error message isn't helpful, I think I tried to make runqemu print something more useful in that case, not sure
<RP> mcfrisk: making some nicer errors messages around that would be nice if we could
<ad__> hi, any simple way to change glibc version ?
<kanavin> ad__, update to the yocto version that has the needed version
<mcfrisk> yea, I'm trying to improve the error messages and host dependency detection
<ad__> kanavin: agh, would like to test 2.28 in place of 2.33 hadrdknott
<kanavin> ad__, everything else is tested with 2.33, so you're likely to run into difficulties and unpredictable amount of time trying to resolve them
<kanavin> why 2.28?
<RP> ad__: you can copy in recipes and try it but no guarantees as we never tested that
<ad__> well, i am trying to compare to an older buldroot stuff that was more performant, using 2.28
<ad__> not sure glibc is the culprit, just investigating
<kanavin> ad__, it's perhaps easier to take a version of yocto that has 2.28
<ad__> kanavin: ok thanks, so not so simple
<kanavin> switching major pieces like glibc, or gcc while leaving everything else as it was is asking for cryptic failures
<ptsneves> RP: I fixed the issue like this(https://pastebin.com/tP10qcVJ) but I would like to create a reproducer for a test. I do not see anything similar. I think these check sum lists are coming from the data cache but I do not see where in the cache code the file list is retrieved. Ideally I would like to create 2 sets of bitbake recipe metadata whose cache objects only differ in the order of the files to checksum. Then from make an expect that they have the same
<ptsneves> task hash
valdemaras has quit [Quit: valdemaras]
<RP> ptsneves: sadly these issues are tricky, the ordering comes from python's dict ordering being random
<RP> ptsneves: the data is put into a dict and effectively randomised there
<RP> ad__: try swapping in some other recipes, see what happens would be my advice. I don't know how bad the issues would be
<ptsneves> RP: can you point me in the code where this is happening, so I at least learn something?
<RP> ptsneves: https://git.yoctoproject.org/poky/tree/bitbake/lib/bb/siggen.py#n200 is where it is defined as a dict. https://git.yoctoproject.org/poky/tree/bitbake/lib/bb/siggen.py#n338 is where it is assigned into that dict. At that point it is going to be unordered
<RP> ptsneves: or do you mean where dataCaches[mc].file_checksums[mcfn] comes from ?
<RP> ptsneves: are those full path filenames? If so that sorting won't be deterministic
valdemaras has joined #yocto
<ptsneves> Where dataCaches[mc].file_checksums[mcfn] comes from. I see it comes from the cooker but what populates it?
<ptsneves> RP: In my case no. The signature files are relative paths and after my patch they are correctly ordered
<RP> ptsneves: add_cacheData in cache.py
<ptsneves> RP: Thanks!
<mcfrisk> kanavin: loaded vgem module and added user to "render" group and now test_testimage_virgl_headless passes, thanks
<RP> ptsneves: I don't think you can't assume those paths are relative
<RP> ptsneves: see the comment in checksum.py:get_checksums about "/./" being injected into the path. You need to sort on the piece after that marker if present
<RP> ptsneves: or perhaps just sort on the checksums
<ptsneves> RP: Ah! clever! Indeed we do not really need any sorting of the paths. We just need the sort for the reproducibility
<RP> ptsneves: right
<ptsneves> Ohhh that would be not enough after all. The list will be ambiguous if sorted by checksum if there are more than one file with the same checksum.
<ptsneves> The list's order i mean
<ptsneves> I actually have such signature on hand
<RP> ptsneves: right, then you'll have to use the paths :/
xmn has joined #yocto
olani_ has quit [Remote host closed the connection]
<ptsneves> RP: Regarding the "/./" being injected. I do not think it matters for task hash purposes. As we talked, the ordering is just a means to have a unique representation for a list of (file,checksum) tuples. Which order irrelevant as long as it is unique.
<RP> ptsneves: someone might lay out the files differently between layers or something though
<RP> ptsneves: i.e. there are slightly unusual things someone might do that could affect this :(
<RP> I really don't want to introduce such a different bug
<RP> ptsneves: imagine a recipe in a layer that references a file in oe-core and two people lay the layers out differently in different paths
olani_ has joined #yocto
<ptsneves> RP: Such case would not affect the hash. If we sort only in the calc_taskhash function like in my proposal https://pastebin.com/tP10qcVJ i think we will not touch anything else. Do you agree?
<RP> ptsneves: no, I don't agree
<ptsneves> Nevermind the "/./" is inside the sorted loop. I dont really have a good idea on how to fix this then. I will try to understand better what the /./ does
<RP> ptsneves: what you probably need to do is write a specific sort function which splits the string on "/./" and returns the second bit as the sort key
<RP> ptsneves: it is there to stop us including user local build paths in the task checksums
<RP> otherwise everyone would have to build in the same path for sstate to match
<ptsneves> ok. Will have a go at it after lunch. Otherwise I will just open a bug so people are aware of the issue.
<RP> ptsneves: you're close, we just need to make sure we cover the corner cases
<ptsneves> Ok. By the way is this line https://git.yoctoproject.org/poky/tree/bitbake/lib/bb/siggen.py#n1100 incorrect as well?
<RP> ptsneves: that is probably ok as it is a list, written here: https://git.yoctoproject.org/poky/tree/bitbake/lib/bb/siggen.py#n429
<RP> so we probably need to fix that bit
<RP> once it is a list, the order is determinstic
pgowda_ has quit [Quit: Connection closed for inactivity]
Xagen has quit [Quit: My MacBook has gone to sleep. ZZZzzz…]
rob_w has quit [Remote host closed the connection]
kscherer has joined #yocto
Xagen has joined #yocto
Estrella has joined #yocto
dmoseley_ has joined #yocto
dmoseley has quit [Ping timeout: 256 seconds]
Wouter0100670440 has quit [Quit: The Lounge - https://thelounge.chat]
Wouter0100670440 has joined #yocto
Xagen has quit [Quit: My MacBook has gone to sleep. ZZZzzz…]
Xagen has joined #yocto
otavio has joined #yocto
dmoseley_ has quit [Quit: ZNC 1.8.2 - https://znc.in]
<ptsneves> RP: https://pastebin.com/HU5gxLcy does this key method work to handle the "/./" case?
dmoseley has joined #yocto
belsirk has joined #yocto
rfuentess has quit [Ping timeout: 245 seconds]
goliath has quit [Quit: SIGSEGV]
valdemaras has quit [Quit: valdemaras]
valdemaras has joined #yocto
dgriego has quit [Ping timeout: 246 seconds]
<RP> ptsneves: yes, that looks like what we need
<ptsneves> ok will submit to the to the mailing list after kids go to sleep :) I do not have the current computer configured for the mailing list
dgriego has joined #yocto
belsirk is now known as rfuentess
Schlumpf48 has quit [Quit: Client closed]
<tlwoerner> aha, there *are* 2 JPEWs!
<JPEW> tlwoerner: When did that happen.... *looks around suspiciously*
amitk has joined #yocto
AKN has quit [Read error: Connection reset by peer]
rfuentess has quit [Remote host closed the connection]
leon-anavi has quit [Quit: Leaving]
valdemaras has quit [Quit: valdemaras]
goliath has joined #yocto
<yates_work> i have a humble question on the yocto reference manual.
vladest has quit [Ping timeout: 248 seconds]
<yates_work> in that manual i see major headings like "Classes," "Tasks," "Images," etc., but I do not see a corresponding "Recipes." Where are are the various aspects of recipes defined? for example how recipe files are to be named, the required syntactic components (e.g., LICENSE), etc?
<JPEW> yates_work: Well.... we are actually working on getting that into the manual
<yates_work> JPEW: Ah! Ok, cool, thanks.
<yates_work> i am creating a new custom recipe for an app and the question i'm having is this: should i append the version number after the recipe base file name or not? e.g., if my application is called "myapp", is it ok to just name it "myapp.bb" or should i name it "myapp_1.0.bb"?
<rburton> if you don't put it in the filename then you get the default of 1.0 unless you set PV manually
<rburton> looking at oe-core will show you that most recipes put the version in the filename unless they're something that doesn't really have a version
<rburton> like, images don't have intrinsic versions
<yates_work> rburton: i see. thanks for answering such a basic question!
Dr_Who has joined #yocto
ptsneves has quit [Ping timeout: 244 seconds]
<zwelch> My do_patch task for my kernel recipe wants to run after do_kernel_metadata, but one of the patches adds the defconfig defined in KBUILD_DEFCONFIG. How can I break this cycle? (FWIW, adding `addtask do_patch before do_kernel_metadata` results in a circular dependency.)
<zwelch> I suspect one solution is "move the defconfig from the patch to the layer", but the patch is being automatically extracted from a vendor's BSP package and I'd rather avoid complicating that process.
<Saur> yates_work: Also know that you can only use versioned bbappends if the recipe actually has a version in the recipe name. I.e., for a foobar_1.%.bbappend to work, the foobar recipe has to be called something like foobar_1.2.3.bb. It does not work to have versioned bbappends for recipes that set PV in the recipe.
<dvergatal> RP: I'm sorry I couldn't get on the meeting I was busy ATM
mckoan is now known as mckoan|away
florian_kc has quit [Ping timeout: 248 seconds]
florian has quit [Quit: Ex-Chat]
ptsneves has joined #yocto
prabhakarlad has quit [Quit: Client closed]
vladest has joined #yocto
<khem> RP: kanavin the example is convertion between two integer types and compiler does an implicit conversion if no explicit cast is specified. Now if implicit conversion is happening and target type is smaller like in this case then there is risk of overflow and behaviour is upto compiler to define with gcc and clang the behaviour is to discard upper 32bits. thats why there is no warning by default but you can use -Wconversion to enable
<khem> compiler to warn about implicit conversions of this kind
<RP> dvergatal: no problem
vladest has quit [Ping timeout: 246 seconds]
tgamblin has quit [Quit: Leaving]
tgamblin has joined #yocto
<yates_work> Saur: good point, thanks.
<kanavin> khem, yes, the point is something else: this behaviour leads to subtle bugs, and compiler could do a better job of warning about it
lexano has joined #yocto
<kanavin> khem, i.e. see dbus's implementation of getting time here. There's no help from gcc indicating that this will discard data when long is 32 bit: https://gitlab.freedesktop.org/dbus/dbus/-/blob/master/dbus/dbus-sysdeps-unix.c#L3408
<kanavin> I have a patch, but I'd rather not have to spend time chasing such issues https://git.yoctoproject.org/poky-contrib/tree/meta/recipes-core/dbus/dbus/0001-time-use-time_t-for-seconds-instead-of-long.patch?h=akanavin/y2038&id=7f47c2
<kanavin> not your fault obviously :)
prabhakarlad has joined #yocto
<khem> compiler takes a general approach as long as code generation is correct. It does offers knobs if programmer wants to be strict or not, integer promotion and conversions are language features. Its good to know them especially in C which is not strictly typed language
<khem> one can certainly argue to make -Wconversion to be part of -Wextra upstream
goliath has quit [Quit: SIGSEGV]
<kanavin> khem, I wonder if you will take a harder stance on this when your power supply goes out in Jan 19 2038 :)
<kanavin> the more I look at C, the more I'm in favour of bondage and discipline languages
<kanavin> such as rust
belgianguy has joined #yocto
valdemaras has joined #yocto
<belgianguy> khem, thanks, yeah I've been reading a lot about Debian, they seem to have only recently fixed a bug with Secure Boot and ARM64, but then whilst digging I read about GPLv3 not being compatible with Secure Boot, which is a hornets nest of its own, ... So far I've only seen deby from meta-debian as a Debian-like distro, but I don't know how similar it is to "real" Debian
frieder has quit [Remote host closed the connection]
flom84 has joined #yocto
flom84 has quit [Remote host closed the connection]
starblue has quit [Quit: WeeChat 3.8]
flom84 has joined #yocto
starblue has joined #yocto
<khem> kanavin: I think if I were to start with a clean state - C/C++ will not be at top of consideration for sure
<kanavin> khem, I've been fixing stuff like this for the past three weeks or so, so my patience with C is a bit thin :) https://git.yoctoproject.org/poky-contrib/log/?h=akanavin/y2038
<khem> Y2038 issue is independent of language though
valdemaras has quit [Read error: Connection reset by peer]
<khem> I understand
<kanavin> I beg to differ. It's very much C-specific.
<kanavin> C/libc
<khem> system C library ( particularly glibc in this case ) agreed. But its a implementation issue rather than language
<khem> belgianguy: yeah, although I would suggest to not mix debian and yocto/OE unless you know what you are getting into, it has a potential of painting yourself into wall
<kanavin> khem, it's also a language issue. C is both ambiguous about how many bits are in long, and won't warn you when 64 bit time_t is assigned to 32 bit long.
<belgianguy> khem, hmm, the layered approach really interested me about Yocto/OE and that there was some industrial inflow, from "pure" Debian I've only seen a buster version that supposedly works with a custom 4.14 kernel
<khem> right, you can get inspiration from that on how secure boot is implemented and get it done on yocto
<belgianguy> khem, I've seen some Bootlin Youtube videos regarding Secure Boot and it seems a very complex topic, signing every step, and it's not well documented for embedded systems (and depend a lot on vendor, too)
<khem> belgianguy: yes it is you need all the signing infra vetted
<khem> kanavin: time_t is not defined by C or C++ std so technically c/c++ compiler can not do much about it. its another define/typedef impl
amitk has quit [Remote host closed the connection]
ptsneves has quit [Quit: ptsneves]
ptsneves has joined #yocto
<kanavin> khem, C could mandate strict checks in type conversions, and deprecate long... in theory :)
<kanavin> declaring that c programmers should know what they're doing is insane, because practice shows they do not
<kanavin> short/long/long long while we're at it
<kanavin> all this ambiguous crap
<kanavin> int too!
ptsneves has quit [Ping timeout: 260 seconds]
florian_kc has joined #yocto
* kanavin finally gets all 32 bit ptests to pass y2038 grrrr
* kanavin should write 'Why C is not my favorite programming language' one of these days
<tgamblin> kanavin: I'd read it
<kanavin> (much of what he said in 1981 doesn't apply to modern pascal)
dgriego has quit [Ping timeout: 244 seconds]
ptsneves has joined #yocto
dgriego has joined #yocto
dgriego has quit [Ping timeout: 246 seconds]
davidinux has quit [Ping timeout: 248 seconds]
davidinux has joined #yocto
dgriego has joined #yocto
vladest has joined #yocto
Haxxa has quit [Quit: Haxxa flies away.]
<dario`> hi, i built nativesdk-rust from master, and i think the target definition json files are missing; i think something like https://pbot.rmdir.de/-rwZHClgYadlGTBsVcBk5g might help (that's from some mickledore+X branch, but rust_1.69.bb looks mostly like rust_1.70.bb in master there)
Haxxa has joined #yocto
<dario`> is anyone around who can confirm whether that's at all possible or whether i'm just looking at it the wrong way or something?
<kanavin> dario`, you should probably find out how target json gets made and installed in rust-native, and why it isn't happening in nativesdk-rust
<kanavin> rust toolchain is intricate, and it's unlikely anyone remembers all the details unless they happen to be working on it this very moment
<RP> dario`: a test case showing how things fails and what this fixes would also help FWIW. I would send the patch, I can imagine how there could be an issue like this
<RP> dario`: although thinking about it, the target definition would vary per target so it wouldn't be right coming from a nativesdk recipe
<RP> the nativesdk recipe isn't meant to be target specific
<dario`> hm, but isn't nativesdk-gcc also specific for whatever target you're building for?
<RP> dario`: gcc-cross-canadian is the target gcc in an sdk and is architecture specific
<dario`> but yes, how i noticed was rustc from the sdk complaining that it couldn't find target spec for x86_64-poky-linux, and even `rustc --print target-list` did that, and providing some target spec fixed that issue, maybe that's not the right point though, not sure
<RP> dario`: I don't doubt it might be missing, I'm just saying that providing it through nativesdk-rust isn't right
<RP> dario`: we do have sdk tests for rust so this does work with master (see meta/lib/oeqa/sdk/cases/rust.py)
<dario`> hm, and rust-cross-canadian does install them, maybe i just don't want nativesdk-rust for my use-case then..
<dario`> what's nativesdk-rust used for anyway then, if building packages reasonably requires rust-cross-canadian?
<dario`> (just answer rtfm if that's appropriate)
flom84 has quit [Ping timeout: 256 seconds]
ptsneves has quit [Ping timeout: 252 seconds]
<kanavin> dario`, I suspect it is not used for anything in particular
<kanavin> nativesdk-cargo depends on it, but I'm not sure if that's a leftover from old time
<kanavin> times
<RP> dario`: that QA test points at rust-cross-canadian having the json files. Those depend on nativesdk-rust as the compiler which is target independent
<dario`> is there a one-sentence summary of "nativesdk" like in https://www.mail-archive.com/yocto@yoctoproject.org/msg22483.html?
<RP> dario`: I think what you want is SDK_TOOLCHAIN_LANGS += "rust"
<dario`> ah, i'll take a look at that, thanks :)
<RP> dario`: "nativesdk" build once per sdk, run on sdk, output code for sdk
<RP> it happens rust can output for target with the json addition
<RP> kanavin: it is the main compiler, definitely needed. It works a bit differently to gcc
<smurray> RP: I have a couple of recent mickledore change backports and a fix for riscv for my kirkstone Rust mixin layer, do I just push those in?
<RP> smurray: I think so, you're the maintainer! :)
<smurray> RP: heh
<kanavin> smurray, you can post to yocto@ list too
<kanavin> for mixin layers it's ok to post/push simultaneously
<RP> smurray: usually for my own changes I have to post them and get feedback before I merge
<smurray> kanavin: yeah, I'll post them there as well
<smurray> RP: right
<RP> how long "before" is varies depending on how risky the change is and how much breakage it might fix
<smurray> I actually have a new issue I need to figure out, there's a crate dependency of the major Rust thing we build for AGL atm that doesn't build for risc-v due to it (ring crate) being a wrapper around a bunch of crypto asm
<dario`> building SDK with SDK_TOOLCHAIN_LANGS += "rust" now, thanks so much RP and kanavin :-)
Wouter0100670440 has quit [Quit: The Lounge - https://thelounge.chat]
Wouter0100670440 has joined #yocto
<yates_work> if i build something with a MACHINE ?= "genericx86-64" under a standard ubuntu desktop distribution, which that actually get installed to the system? (e.g., /usr/local/bin)?
<yates_work> slightly different question: if i build something with a MACHINE ?= "genericx86-64" under a standard ubuntu desktop distribution, can i run it natively on that system?
amitk_ has quit [Ping timeout: 256 seconds]
<yates_work> s/which that/will that/
amitk has joined #yocto
<kanavin> yates_work, in general, no. If you want to run things on ubuntu, build them using ubuntu tooling.
<kanavin> yates_work, however, building something in it's -native variant will work
<kanavin> but that's independent of what MACHINE is set to
dgriego_ has joined #yocto
florian_kc has quit [Ping timeout: 244 seconds]
dgriego has quit [Ping timeout: 248 seconds]
Xagen has quit [Quit: My MacBook has gone to sleep. ZZZzzz…]
<khem> kanavin: there is lot of legacy code in C that has to be carried forward. Clang is doing some aggressive steps in this area e.g. trying to default to newer C std and this leads to fundamental breakages like autoconf probing tests failing to compile and worse in some cases the test logic depended on these old c89 behaviors
mpb27 has joined #yocto
mpb28 has joined #yocto
dmoseley_ has joined #yocto
dmoseley has quit [Ping timeout: 252 seconds]