I haven't talked about my goal for personal computing in a while.

With Sundog nerdsniping me in to attempting to turn the LibSSH-ESP32 port in to the basis of a full fledged SSH client for the ESP32, I guess I should spend a few minutes talking about why I bother with this bullshit.

Computers could be good, but they aren't.

That's the gist of it.

I guess I mean Good with a capital G, as in "a force for good in the world", but I also mean good with a lowercase g, as in "not super shitty to use, or think about".

I'm not going to waste a lot of bits talking about how computers are bad. I've done this a lot before, and you probably already agree with me. I'll quickly summarize the high points.

Show thread

What's wrong with (modern) computing?

- Computers spy on us all the time
- Computers are insecure, while pretending not to to be.
- Computers enable new modes of rent seeking, further exasperated by shitty patents and worse laws
- Computers/the modern internet encourage behaviors which are bad for our mental health as individuals.
- Computers and the modern internet, in concert with modern capitalism have built a world essentially without public spaces.

You know, all that bullshit.

Show thread

As I said, it's a summation. There's nuance. There are more problems.

That list should serve as an okay shorthand for the kind of thing I'm talking about.

Computers? They're bad.

Show thread
Follow

But I'm here, talking to you, through a computer. I derive my living from computers. I spend most of my free time in front of a computer.

In spite of all the ways computers are lowercase b bad, computers enable a lot of Good.

I believe in the potential of computers, in our digital future.

I've spent a lot of time thinking about what the next 30 years in computing might look like, the successes and failures of the last 30 years, and the inflection point at which a computer is Good Enough for most tasks.

I've spent a lot of time thinking about the concept of planned obsolescence as it applies to computing, and what modern computing might look like without the profit motive fucking everything up.

Show thread

Sidebar:

I'm just a dude.

I'm a sysadmin. I spend a lot of time using computers, and specifically I spend a lot of time fixing machines that are failing in some way.

But I'm just some dude who thinks about stuff and imagines futures which are less horrible than present.

I've said that as a way to say: I don't claim to have The Answer, I just have some ideas. I'm going to talk about those ideas.

Sidebar over.

Show thread

So how did we get from the gleaming promise of the digital age as imagined in the 70s to the harsh cyberpunk reality of the 20s?

Centralization, rent seeking, planned obsolescence, surveillance, advertising, and copyright.

How do we move forward?

Re-decentralization, a rejection of the profit motive, building for the future/to be repaired, building for privacy, rejecting advertising, and embracing Free software.

Show thread

Personally, there's another facet to all of this:

I use and maintain computers professionally, and recreationaly.

Sometimes, I want to do something that doesn't feel or look like my day job. Unfortunately, most of my hobbies feel and look a lot like my day job.

To that end, I have some weird old computers that I keep around because they're useful and also because they're Vastly Different than the computers I use at work.

My , mac plus, and palm pilots fall in this camp.

Show thread

I can do about 80% of what I want to use a computer for with my 486 based, non-backlit, black and white HP Omnibook.

Add my newly refurbished and upgraded Palm Lifedrive, and I'm closer to 95%.

Let's run through those tasks:

Palm:
- Listen to music (The palm is a 4GB CF card with a 2GB SD card, basically.)
- Watch movies (I have to encode them specially for the palm, but the lifedrive makes a great video iPod.)
- Read books (plucker is still pretty great)
- RSS (ditto above)

Show thread

Omnibook:

- Email (via some old DOS software the name of which I'll have to look up, and lots of effort on getting my mail server configured correctly. + an ESP32 based modem. This took some doing and I still don't love how I'm doing it. I'll do a blog post about it eventually.)
- Social (mastodon via brutaldon via lynx via telnet over tor to an onion endpoint I run in my home, not ideal, or via BBS)
- Write (via Windows 3.1 notepad)

Show thread

- Consult reference material (via the internet or gopher over my esp32 modem with the appropriate DOS software and SSL proxy, or more likely, via a real hacky thing I wrote to mirror a bunch of websites to a local web server.)
- Develop (frankly Via GW-BASIC, although I'd love to start doing real programming again.)
- Games (this is the thing the omnibook is worst at! I consider that a strength most of the time, but I do have a lot of parser based IF games on it.)

Show thread

There was a time in the recent past when I used a Pentium MMX laptop as my only computer outside of work for weeks at a time.

It could do basically everything I wanted it to do, including some far more impressive games.

It's batteries gave out, finally, but until then it made a decent little computer.

Show thread

The only real problem I run in to in these setups are the hoops I have to jump through because I'm the only one using them, and because (wireless) networking technology has advanced in ways that are not backwards compatible on the hardware level, while leaving laptops without a clear upgrade path.

...

Show thread

This feels like a kind of rambling sidebar, but there's a point:

Most tasks that computers are used for on a daily basis could be completed on much less powerful hardware if there wasn't a profit incentive in the way.

Show thread

So, circling back to the original point: I'm imaging a world in which computers are different.

Specifically, different in that they are designed to be cheap, easily repaired or replaced, and to just Do Their Job forever.

(This requires defining the job they are supposed to do.)

Show thread

No one gets upset that their typewriter can't browse the internet, you know?

But a computer isn't an appliance, it's an everything machine, and as an Everything machine, if it can't do the New Shiny Thing we have to throw it away and get a new one.

That's the mentality I'm trying to break out of.

I want to define a(n extendable!) list of tasks that I feel like will be relevant indefinitely, and build a machine to last 30 years.

Show thread

Which, finally, brings us back to the ESP32!

See thread: retro.social/@ajroach42/105397

Basically, the ESP32 is a simple microcontroller (that is to say, it's a computer! It's just not a computer the way we usually think about it.)

It's really cheap, like $3 or $4 for a simple board. There are folks making software for it already to treat it like a desktop computer.

It's not completely open or completely standardized or capable of everything I want out of my but ...

Show thread

They get most of the way there on every count, and they have built in wifi and are so very cheap.

It would be entirely possible to base a new paradigm of multi-decade computers on the ESP32, but built in such a way as to be agnostic to the actual hardware (that is to say, you follow the write once run anywhere model of Java, and use the ESP32 as the host of a virtualized environment OR you build for the ESP32, and then emulate the ESP32 on newer hardware in the future)

Show thread

This is basically the approach that Infocom took in the 80s when they developed text adventure games for every computer on the planet.

They invented a fake computer, compiled all their games for that fake computer, and then wrote emulators for that fake computer for every major machine of the era.

As a result, basically any computer can run an infocom game.

Show thread

Now, is the ESP32 a good home for a multi-decade computer?

I dunno!

It's a little more limited than I would have picked (I'd have probably stopped in the early multimedia era), but it's also way less power hungry than what I would have picked, and frankly significantly cheaper and easier to understand.

So I'm going to spend the next few months exploring the ESP32 as the basis for a purpose built computer that inherits the legacy of the tinkerers of the microcomputer era.

Show thread

Principles I plan to adhere to in my ESP32 exploration:

- Offline first, but networked
- Understandable is better than "easy to use"
- don't make assumptions about available hardware
- Don't re-invent the wheel without a good reason
- don't try to build a modern computer
- Decide what this machine should do, make sure it's good at those things.

Show thread

Further thoughts:

Chip-8 - en.wikipedia.org/wiki/CHIP-8 - Chip 8 is a virtual machine from the 70s for making games and software portable. It's part of the reason your graphing calculator plays games.

The 100 year computer project (thedorkweb.substack.com/p/the-) that sent me careening back down this path has a lot in common with chip-8 (and the article mentions it by name.)

Show thread

I have other thoughts but it's dinner time. I'll revisit it.

Show thread

We've talked a little about hardware. We've talked a little about use cases, but we should probably dig deeper in to that.

The remaining piece of this puzzle is software, which I think is closely tied to, but ultimately separate from, use cases.

I'll talk about that now, a bit, until I fall asleep.

So first things first, it's late and this might be incoherent.

Show thread
Show more

@ajroach42 This code has been getting published to Github btw, @enkiv2 likes linking to them!

@alcinnz @enkiv2 It has, yeah. It's not Free Software though. Just something that was archived.

Show more
Show more

@ajroach42 Espressif also made ESP32-C based on RISC-V (ESP based on Xtensa LX6 is now named ESP-S by Espressif). So this is a more long term evolution. They currently give away RISC-V based boards, if you mail to them and have good projects (else it’s abour 2~3€ the board :)

Show more
Show more
Show more

@ajroach42 I've been reading through your goal of a multi-decade computer and it echos a lot of thoughts I've had. I'm building a house this spring and want to put in a whole home system that will hopefully be as future-proof as reasonably possible. It is a hard goal. My gut tells me that you're a little on the primitive end with your use cases, but not by much. I think things got good enough around 2010 on the hardware/software end. Any reason you would shy away from Raspberry Pi?

@daniel the end of the windows XP era is a good target in terms of features depending on your software and your use case.

I have some computers that age that get regular use.

I use and enjoy various raspberry pis in some special purpose builds. Outside of thag I find them to be, basically, just normal computers but slightly underpowered for some tasks. In my experience this leads to folks trying to use them like normal computers and then getting frustrated.

Show more

@ajroach42 I think one significant goalpost was reached when peripherals got better than human senses could discern. Another was the maturity of software RAID systems. Yet another, was the plateauing of audio/video codecs. One of the biggest hurdles for me is the reliance of smart phones to capture recordings. They are too convenient and have amazing quality. Getting the iPhone to talk to Linux is always a PITA. If Linux smartphones take off, I have a hard time figuring out what else I need.

Show more

@ajroach42
Support for the Extensa core is being merged into LLVM, so your language and compiler options are going to be nice, and ESP-32s are going into lightbulbs so there's plenty potential for salvage

I've been working with zig as a front end for C to trying setting up a cross compiler environment. I've always hated builds so this project is especially easy to procrastinate on, but if one of us gets that working then it's pretty easy for someone to build that code for RISC-V or other LLVM supported architecture later

@yaaps I don't know zig, but am otherwise pleased with the contents of this post.

@ajroach42
While zig is a new C-like language with some interesting features, what you'd be most interested in would be its utility as an alternative front end for Clang:

andrewkelley.me/post/zig-cc-po

Besides the features in that blog, there's some nice things about the way zig manages libc for the cross compiling environment and tracks changes in your code to reduce unnecessary recompiling

But I'm not trying to open up rabbit holes under your feet while you're just crossing the field. I've got to crack open a couple laptops to shuffle SSDs around to get a working dev laptop again

@ajroach42

"Most tasks that computers are used for on a daily basis could be completed on much less powerful hardware if there wasn't a profit incentive in the way....

I want to define a(n extendable!) list of tasks that I feel like will be relevant indefinitely, and build a machine to last 30 years."

I mean to me this only leads one place; getting emacs to run on the absolute most minimum hardware :P

If you are making do on limited hardware you are mainly doing text editing at that point.

@ajroach42

Emacs is already over 30 years old, it will be around as long as computers are around and coupled with org mode and it can do anything that involves text within a single wholistic workflow.

If a computer was designed around emacs/org mode you certainly wouldnt try to use it like a shiny new computer (and fall into that expectation trap that would keep you from truly interfacing with this computer as a new experience).

Anyways heres a pamphlet about the one true god that is emacs

@Alonealastalovedalongthe most of what I do, most of what most people do, with a computer is editing text and then sending that text to places.

Databases, spreadsheets, web pages, emails, IMs, all text at heart.

I imagine emacs has already been ported to the ESP32, but I haven't verified that.

I'm considering a slightly different approach, one that aims to be more proscriptive, but the emacs life is valid.

Long and a bit rambly, sorry 

@ajroach42 I used to think we'd naturally get to Star Trek the Next Generation as our tech brought us towards post scarsity. But it takes humans to do it.

@ajroach42 How are you getting Tor on DOS? Or have you somehow built that functionality into the WiFi modem?

@ajroach42 what kind of viable business models can companies adopt so they'll resist the urge to use built-in obsolescence?
(Well other than proper management instead of oligarchic fat cat management)

@vesperto decentralized, worker owned, cooperatively managed, much smaller scale manufacturing coupled with some changes in consumer habits are the only path forward I see.

@ajroach42 free software is not enough. we need libre silicon and integrated circuits.

@theruran @ajroach42
So the closest we get to libre hardware with ARM (ignoring how ARM makes money and who's buying it) is FairPhone and Librem, which apparently have some binary blobs but they're disabled?

Then there's a RISC-V system scheduled for release next year. Totally libre hardware and it runs... Which Linux? ChromiumOS?

So maybe we set our sights a little lower, not that ESP-32 is problem free...

hackaday.com/2016/10/27/basic-

(Not all undocumented features could be this pleasant)

@yaaps @ajroach42 I did a class project this semester on this system: betrusted.io/

I don't think everything there is libre hardware but it's about as close as is feasible today. They go through great lengths to employ evidence-based security and also discuss some of its limitations.

@theruran Finaly such device has been industrialized. I'm been trying to set up such project fo
r years, but failed to find associates to do so. @yaaps @ajroach42

@yaaps @theruran @ajroach42 be careful with RISC-V stuff. The standard instruction set is open; implementations of that instruction set need not be. Moreover, there's no requirement that extensions to that instruction set architecture be nonproprietary either.

@vertigo @theruran
I think the use cases for @ajroach42 are more concerned with bulk commercial data harvesting and less concerned with state actors. It's an interesting use case for hardware with development sponsored in China. When your activity is technically legal production of culture even though your motive is to disrupt capital, accessibility is more relevant

@drwho @ajroach42 Great write-up!

I was just thinking... I think it's been mentioned before: to move away from silicon because Big Tech has a death grip on it. There may be cleaner and safer processes with other semiconductor materials? Thought I saw experimentation with graphite, too.

@theruran @ajroach42 Thanks! It's a little dated, I haven't updated it in about six years, but I tried to give the general principles legs for the long haul.

There is some experimentation with graphite - graphenes in general, really. Experiments in using carbon nanotubes as transistors are still ongoing. Personally, I think rod logic might be a better application for them but at best I'm a somewhat well read laybeing in that particular field.

Sign in to participate in the conversation
R E T R O  S O C I A L

A social network for the 19A0s.