Product Idea: USB Flash Drives
#51
(03-28-2021, 03:28 PM)barray Wrote: Given the current trend of things, I have a pessimistic outlook. On the plus side, hopefully it gives the world an opportunity to reorganize their supply chains so that they rely less on shipping stuff all around the world - which is not particularly sustainable.

I agree.  Earning more money is good, but not at the cost of destroying things, environment, nature, jobs, or people's health and lives.  Unfortunately, many aspects of humanity seem to have become pushed to the side or even forgotten in the last couple of decades.

(03-28-2021, 03:28 PM)barray Wrote: It'll take a while to set something up anyway... I really want to be able to group discussions so that they make more logical sense, I think so far we have the greater subjects of 'software', 'hardware' and 'production'. Then for each of those is several important discussions that need to happen. Long threads tend to result in lost information in the long run.

If Pine64 eventually remains silent, we should move the entire discussion elsewhere.  I would suggest using some of the existing wiki implementations (preferably one written in PHP) instead of setting up a forum, because the wikis provide good page talks and very good revisioning of pretty much everything.  The usual wiki flow is to discuss on a talk page and then update the main page, which is usually very effective: condensed results of talks end up on main pages for future reference.

Moreover, splitting the discussion into multiple threads right now might actually be counterproductive, because that could be good for you and me, but would probably make the whole thing much harder to grasp for someone just having a first look at the entire idea/project.

(03-28-2021, 03:28 PM)barray Wrote: I hope so. The other option is that we post updates back to this forum to incorporate feedback from the community. People post about significant software updates for example, I don't think it's unreasonable as long as we don't spam and the device still relies on the BL602.

Good idea.  After moving the discussion somewhere else, we should definitely provide periodic updates here, of course provided that the first storage device is a "hat" for one of the BL602 boards made by Pine64.

(03-28-2021, 03:28 PM)barray Wrote: It's now been almost a month of hoping for some feedback. I'm not going to hold my breath - I have no idea what we have to do to get some attention.

Let's keep the hope present for a while, but expect nothing.  More than enough has been done to attract their attention, so the ball is in their court now.
  Reply
#52
(03-28-2021, 09:46 PM)dsimic Wrote: I agree.  Earning more money is good, but not at the cost of destroying things, environment, nature, jobs, or people's health and lives.  Unfortunately, many aspects of humanity seem to have become pushed to the side or even forgotten in the last couple of decades.

Seems like that ship got unblocked.

(03-28-2021, 09:46 PM)dsimic Wrote: If Pine64 eventually remains silent, we should move the entire discussion elsewhere.  I would suggest using some of the existing wiki implementations (preferably one written in PHP) instead of setting up a forum, because the wikis provide good page talks and very good revisioning of pretty much everything.  The usual wiki flow is to discuss on a talk page and then update the main page, which is usually very effective: condensed results of talks end up on main pages for future reference.

If we are to go down that road, then it's probably better to use a Wiki associated with something like GitHub/GitLab (https://docs.gitlab.com/ee/user/project/wiki/). We could then even get a webpage out of it (https://docs.gitlab.com/ee/user/project/pages/).

(03-28-2021, 09:46 PM)dsimic Wrote: Moreover, splitting the discussion into multiple threads right now might actually be counterproductive, because that could be good for you and me, but would probably make the whole thing much harder to grasp for someone just having a first look at the entire idea/project.

I think it would make sense to start consolidating the ideas here anyway into a more presentable format - who is going to read through so many comments just to find out what the basic idea is?
  Reply
#53
Have you talked about the project idea in chat, Pine community chat is usually pretty good at getting everyone's attention?
Come have a chat in the Pine IRC channel >>
  Reply
#54
One thing I saw on another software project, was automated testing. Anytime a feature was changed or added, a test routine was changed or added to specifically test that change or addition.

Perhaps something along that lines should be implemented.

Start with simpler firmware without encryption or UAS / UASP, (USB attached SCSI protocol), and make the test routines verify those features. Then move on to more important features.
--
Arwen Evenstar
Princess of Rivendale
  Reply
#55
(03-29-2021, 08:34 AM)xalius Wrote: Have you talked about the project idea in chat, Pine community chat is usually pretty good at getting everyone's attention?

No, but I did and you were in the IRC chat.

@dsimic We have been suggested to make a wiki page, hence: https://wiki.pine64.org/wiki/PineFlash We are still discussing (as I write) how such a thing can be linked to, making it clear it is community driven at this stage. We should use this space to consolidate the ideas from these discussions.

(03-29-2021, 11:15 AM)Arwen Wrote: One thing I saw on another software project, was automated testing. Anytime a feature was changed or added, a test routine was changed or added to specifically test that change or addition.

For sure we will need tonnes of testing - losing data is unacceptable and we should guard against that in every way possible. Being open source we can make this effort very clear.

(03-29-2021, 11:15 AM)Arwen Wrote: Start with simpler firmware without encryption or UAS / UASP, (USB attached SCSI protocol), and make the test routines verify those features. Then move on to more important features.

That would be the intention - to develop this incrementally Smile
  Reply
#56
@Arwen @Julius_GU I added your suggestions under 'Suggest Features': https://wiki.pine64.org/wiki/PineFlash I've tried to condense them down to their core ideas. I may have mis-attributed or missed some stuff, so please take a read.

The wiki is of course just a first draft, feel free to add some stuff. I feel a lot better now that we are able to document some of the awesome discussions happening in here.
  Reply
#57
(03-29-2021, 08:09 AM)barray Wrote: If we are to go down that road, then it's probably better to use a Wiki associated with something like GitHub/GitLab (https://docs.gitlab.com/ee/user/project/wiki/). We could then even get a webpage out of it (https://docs.gitlab.com/ee/user/project/pages/).

Gah, for some reason I don't like GitHub...  IMHO, it's vastly overhyped, and people just don't think too much and use Git for projects that would actually benefit from using Subversion.  Also, GitLab is written in Ruby, which just plain s*cks when it comes to the installation and later maintenance.

(03-29-2021, 11:15 AM)Arwen Wrote: One thing I saw on another software project, was automated testing. Anytime a feature was changed or added, a test routine was changed or added to specifically test that change or addition. Perhaps something along that lines should be implemented.

Start with simpler firmware without encryption or UAS / UASP, (USB attached SCSI protocol), and make the test routines verify those features. Then move on to more important features.

Automated testing, unit tests or however people call it are good, but the trouble with hardware projects is that fully automating the testing is usually not possible.  For example, a lot of trouble with proper operation of a USB device comes from its plugging and unplugging into the host device, which would be really complicated to be automated, if possible at all.

However, automated testing could be implemented to a certain degree.

(03-30-2021, 11:20 AM)barray Wrote: We have been suggested to make a wiki page, hence: https://wiki.pine64.org/wiki/PineFlash We are still discussing (as I write) how such a thing can be linked to, making it clear it is community driven at this stage. We should use this space to consolidate the ideas from these discussions.

This is a good solution for now, but the new PineFlash wiki page should be linked from somewhere.  I'd suggest that we link it in the first post in this thread, until it's decided where to link it from within the wiki.

Also, I took some time to clean up the PineFlash page a bit, and to improve the wording and layout of the main wiki page.  The main page looks a bit more professional now, if you agree. Cool
  Reply
#58
In regards to testing, @dsimic you have a good point about insertion. However, perhaps that can be simulated by having the host port's USB power turned off. Something like this;

- Start with USB port power off
- Plug in USB storage device
- Initiate automated testing, which turns power on

During various steps, the testing can disable power, to power cycle / reboot the USB storage device. Whence all those tests pass, perhaps having another set of partially automated testing with interactive USB storage device insertions and removals.

Even if host power can't be removed, (and we can probably create a special test jig that can do so, if we can't find one already available), using interactive tests with the user performing the inserts and removals will still be quite valuable.

In fact, one of my original suggestions is copy on write. Meaning that the internal directory structure remains consistent, even through unexpected power cycles. So with automated power cycle support, we can test that function by writing to the USB flash drive and disabling power at various intervals. Then on power up, make sure that preexisting data is still available.
--
Arwen Evenstar
Princess of Rivendale
  Reply
#59
Things may sometimes seem deceptively simple.  Please allow me to explain.

One of the problems is that using software to cut the power from a plugged-in USB device is actually not possible on regular USB ports.  The available power-related knobs in /sys actually only tell the plugged-in USB devices to go into suspended state, and it's up to the particular USB device to do (or ignore) the requested suspend operation.  In other words, no power cuts are actually performed by the host.

Maybe it's possible to cut power on USB ports that are present on some SBCs, which I'm not sure about at the moment, but the lack of that feature on regular (i.e. found on PC motherboards) USB ports turns the whole thing into being impossible to automate.  We must not rely on testing using only the USB ports on a few select SBCs.

Moreover, it's not just about cutting the power.  The four USB 2.0 strips inside the USB Type-A plug are intentionally not of the same lenght; the two strips that carry power are longer than the strips that carry data, so the device has some time to wake up before the data lines are connected upon plugging a USB device into a USB receptacle.  In the scenario of cutting and re-establishing power to a USB device, there would be no such delay, which would take the whole setup out of the USB specification and make the whole automated setup rather pointless.

It's even worse with USB 3.0; sometimes, USB 3.0 devices are seen as "ghost" USB 2.0 devices upon unplugging them from a USB 3.0 host receptacle.  All that due to the different positions and lengths of the USB 2.0 and 3.0 pins inside the connectors.

Edit: By the way, flash memory is inherently of a COW nature.  However, the only way we could guarantee data consistency in presence of sudden power cuts is to use raw flash, with no built-in wear leveling, and do everyhing in the device firmware.  If the flash does anything on its own, using some sort of a built-in microcontroller, all bets are off and no data consistency can be guaranteed.

Edit #2: I stand corrected. It is actually possible to use software to cut power on regular USB ports, with certain rules and restrictions as described in detail here, but the note on having no delay between connecting power and data lines still remains.
  Reply
#60
(04-01-2021, 07:50 AM)dsimic Wrote: Gah, for some reason I don't like GitHub...  IMHO, it's vastly overhyped, and people just don't think too much and use Git for projects that would actually benefit from using Subversion.  Also, GitLab is written in Ruby, which just plain s*cks when it comes to the installation and later maintenance.

I understand the point about GitHub, but it's also quite popular. GitLab is not nice to maintain for sure (as is most large web applications), but the one hosted at https://gitlab.com would be sufficient.

(04-01-2021, 07:50 AM)dsimic Wrote: Automated testing, unit tests or however people call it are good, but the trouble with hardware projects is that fully automating the testing is usually not possible.  For example, a lot of trouble with proper operation of a USB device comes from its plugging and unplugging into the host device, which would be really complicated to be automated, if possible at all.

However, automated testing could be implemented to a certain degree.

I don't think it replaces a human, but it for sure ensures that at least the simplest of the bugs can be caught early on. I would see several layers of testing anyway, regression testing (done on build), file transfer testing (a script that can be run) and manual testing (use the stick for a week with some code before declaring a release).

(04-01-2021, 07:50 AM)dsimic Wrote: This is a good solution for now, but the new PineFlash wiki page should be linked from somewhere.  I'd suggest that we link it in the first post in this thread, until it's decided where to link it from within the wiki.

I did link it: https://wiki.pine64.org/index.php?title=...oldid=9632 but then it got yeeted from the front page: https://wiki.pine64.org/index.php?title=...oldid=9634

Apparently they want something more fledged out before adding it and there is no real consensus about exactly how it would be presented.

I'll see what I can do about editing my original comment to point to the wiki.

(04-01-2021, 07:50 AM)dsimic Wrote: Also, I took some time to clean up the PineFlash page a bit, and to improve the wording and layout of the main wiki page.  The main page looks a bit more professional now, if you agree. Cool

I checked it out earlier, seems mostly good.

(04-01-2021, 01:27 PM)Arwen Wrote: In regards to testing, @dsimic you have a good point about insertion. However, perhaps that can be simulated by having the host port's USB power turned off. Something like this;

- Start with USB port power off
- Plug in USB storage device
- Initiate automated testing, which turns power on

During various steps, the testing can disable power, to power cycle / reboot the USB storage device. Whence all those tests pass, perhaps having another set of partially automated testing with interactive USB storage device insertions and removals.

Even if host power can't be removed, (and we can probably create a special test jig that can do so, if we can't find one already available), using interactive tests with the user performing the inserts and removals will still be quite valuable.

In fact, one of my original suggestions is copy on write. Meaning that the internal directory structure remains consistent, even through unexpected power cycles. So with automated power cycle support, we can test that function by writing to the USB flash drive and disabling power at various intervals. Then on power up, make sure that preexisting data is still available.

I think we will cross that bridge when we come to it - I suspect manual testing will be good for quite a while. I imagine most of our bugs will come from more humble origins and will be more easily reproduced.

(04-01-2021, 02:05 PM)dsimic Wrote: One of the problems is that using software to cut the power from a plugged-in USB device is actually not possible on regular USB ports.  The available power-related knobs in /sys actually only tell the plugged-in USB devices to go into suspended state, and it's up to the particular USB device to do (or ignore) the requested suspend operation.  In other words, no power cuts are actually performed by the host.

Maybe it's possible to cut power on USB ports that are present on some SBCs, which I'm not sure about at the moment, but the lack of that feature on regular (i.e. found on PC motherboards) USB ports turns the whole thing into being impossible to automate. We must not rely on testing using only the USB ports on a few select SBCs.

Edit #2: I stand corrected. It is actually possible to use software to cut power on regular USB ports, with certain rules and restrictions as described in detail here, but the note on having no delay between connecting power and data lines still remains.

I think it is possible as you say, but not on absolutely every host and turning the USB port power back on can be a pain... Some for example only trigger the power when the resistance between D+ and D- is detected and require a disconnect followed by a reconnect in order to reset this condition.

(04-01-2021, 02:05 PM)dsimic Wrote: Moreover, it's not just about cutting the power.  The four USB 2.0 strips inside the USB Type-A plug are intentionally not of the same lenght; the two strips that carry power are longer than the strips that carry data, so the device has some time to wake up before the data lines are connected upon plugging a USB device into a USB receptacle.  In the scenario of cutting and re-establishing power to a USB device, there would be no such delay, which would take the whole setup out of the USB specification and make the whole automated setup rather pointless.

Yeah, we would need something to disconnect all the lines and that doesn't unintentionally add capacitance (which at high speed is a large ask). Let's just not explore this manual disconnect unless we absolutely have to... Again, I think manual disconnect will be sufficient for the time being.

(04-01-2021, 02:05 PM)dsimic Wrote: It's even worse with USB 3.0; sometimes, USB 3.0 devices are seen as "ghost" USB 2.0 devices upon unplugging them from a USB 3.0 host receptacle.  All that due to the different positions and lengths of the USB 2.0 and 3.0 pins inside the connectors.

Ouch, wasn't aware of this.

(04-01-2021, 02:05 PM)dsimic Wrote: Edit: By the way, flash memory is inherently of a COW nature.  However, the only way we could guarantee data consistency in presence of sudden power cuts is to use raw flash, with no built-in wear leveling, and do everyhing in the device firmware.  If the flash does anything on its own, using some sort of a built-in microcontroller, all bets are off and no data consistency can be guaranteed.

Any memory we are using we have control. If we want, we could fit the device with a beefy cap and continue running despite being powered off - the hardware is entirely in our control. And also there are filesystems that are robust to random disconnects, like ZFS for example. We won't have to re-invent the wheel on this one.
  Reply


Possibly Related Threads…
Thread Author Replies Views Last Post
  Possible new Pine64 product - Pine Blue Ray DVD Linux tv box Omnios 5 2,439 07-24-2023, 03:21 PM
Last Post: Omnios
  QuartzPro64 SPI flash Melab 1 1,230 03-16-2023, 07:50 PM
Last Post: Melab
  Modular product design Zotax 0 1,097 01-28-2023, 11:50 AM
Last Post: Zotax
  Product Idea: PineTracker EternityForest 0 1,011 01-12-2023, 10:33 PM
Last Post: EternityForest
  New product idea: Pine Glasses Blathers 2 3,344 12-02-2022, 09:51 PM
Last Post: erikzoltan
Lightbulb Product Idea: Pine Graphics Tablet israel 10 10,087 04-19-2022, 04:12 AM
Last Post: Houstand345
  Article: Auto Flash and Test NuttX on RISC-V BL602 (PineCone) lupyuen 0 1,493 01-24-2022, 05:41 PM
Last Post: lupyuen
  Rackmount cluster case as a Pine Store product? dfr 3 4,090 09-30-2021, 04:52 PM
Last Post: poVoq
  E-Note Device (E-Ink, E-Paper, Project Idea) Sirius 9 10,634 08-18-2021, 08:28 AM
Last Post: biketool
  PineVR as a new product? poVoq 11 13,218 05-31-2021, 09:33 AM
Last Post: MirceaKitsune

Forum Jump:


Users browsing this thread: 7 Guest(s)