Off-Topic > Off-Topic - Tiny Tux's Corner

Magical research?

(1/1)

Lee:
I'm interested in how the "magic" in files is determined and at what level of the os this happens.

In particular, where is the shebang detected for an executable script?
Is this a function of the shell or of the kernel or something else?
Is it configurable via some config file or will I have to recompile something?

The problem I am trying to solve is that I have an interpreted language (mumps) that I would like to use for scripting, but it uses the semicolon and not the hash symbol as a comment marker.
So I'll need to use a shebang like

--- Code: ---;!/path/to/interpreter
--- End code ---
instead of

--- Code: ---#!/path/to/interpreter
--- End code ---
GT-M mumps is in the 1.x tce repo as gtm5.tce.  ( The maintainer of that extension -really- needs to update it.  :)  )

Can anyone point me to what I need to change?

(No, I haven't yet asked the GT-M devs about changing the interpreter to accommodate starting a script directly.)

vitex:
One mechanism is via the kernel.  See binfmt_misc and Kernel Support for miscellaneous (your favourite) Binary Formats v1.1.

I have used this capability to cross-develop an embedded ARM file system on x86 Linux by telling the x86 kernel to execute ARM programs by passing those programs to an x86-hosted version of qemu that emulates the ARM processor.


curaga:
libc, I suppose. binfmt_misc is disabled in our builds.

Lee:

--- Quote ---binfmt_misc is disabled in our builds
--- End quote ---

That would explain why I got nowhere with it (well, that and my utter lack of knowing what I was doing).

The links posted by vitex were informative and seemed to be taking me right where I needed to go.

Any likelihood of seeing binfmt_misc in a future tc kernel?  I don't know if there might be some large impact on size, or performance (or stability or security...)

curaga:
Well, I believe there's a small overhead on every binary exec with it enabled, to check whether the binary is special.

Navigation

[0] Message Index

Go to full version