Skip Navigation
General Programming Discussion @lemmy.ml ☆ Yσɠƚԋσʂ ☆ @lemmy.ml

C Is Not a Low-level Language. Your computer is not a fast PDP-11.

queue.acm.org /detail.cfm
10
General Programming Discussion @lemmy.ml LalSalaamComrade @lemmy.ml
As a C beginner, should I be bothered by not being able to understand this?
TechNews @radiation.party irradiated @radiation.party
BOT
[HN] C Is Not a Low-level Language – Your computer is not a fast PDP-11

You're viewing a single thread.

10 comments
  • All this argument does is bump up ASM to a low-level language.

    I get the resistance in calling C low level but we aren't about to mistake C runtimes for a JIT.

    LLVM certainly makes the comparison easier.

    • That's not what the article is saying though. It's arguing that the memory model that imperative languages assume is not actually how modern chips work. What we end up with effectively is a VM on the chip that pretends to be a really fast PDP-11 style architecture. Writing assembly against this VM still has the same problem. Interestingly, the way modern chips are designed actually fits better with functional style that doesn't rely on global state.

      • i got there at the end

      • Do you think Habit and Ante are better candidates to improve this situation?

        • I'm not familiar enough with how Habit and Ante represent memory allocation to say, but part of the problem right now is that there's already a VM baked into the chip to provide the PDP-11 style emulation on top of it. Ideally, we'd want chips that expose their native behavior, and then craft languages to take advantage of it. Similarly to what we're seeing happening with graphics chips.

          • Is this issue persistent in RISC-based processors too, like SPARC, POWER or RISC-V? Or is this a modular component that can go in with any architecture?

            • I imagine it would be the same dynamic, and you could have an emulation layer on the chip with its own instruction set for legacy code while providing direct access to the native instruction set.

You've viewed 10 comments.