[swift-evolution] Low-level Swift
Félix Cloutier
felixcca at yahoo.ca
Thu Jan 7 15:22:26 CST 2016
It is. This:
> func foo(ptr: UnsafeMutablePointer<Int32>) {
> ptr.memory = 4
> ptr.memory = 5
> }
compiles to:
> define hidden void @_TF4test3fooFGVSs20UnsafeMutablePointerVSs5Int32_T_(i8* nocapture) #1 {
> entry:
> %.value = bitcast i8* %0 to i32*
> store i32 5, i32* %.value, align 4
> ret void
> }
Notice how it's "missing" a store.
Félix
> Le 7 janv. 2016 à 15:54:36, Austin Zheng via swift-evolution <swift-evolution at swift.org> a écrit :
>
> I'd think the hypothetical way in Swift to write to configuration registers would be to create an UnsafeMutablePointer<Int64> (or some other raw integer type) from a raw memory address, and then get/set the contents using the 'memory' property. Not sure if the compiler is "smart" enough to optimize out memory accesses made using that mechanism, although I would assume no.
>
> Austin
>
> On Thu, Jan 7, 2016 at 3:52 AM, Romain Goyet via swift-evolution <swift-evolution at swift.org <mailto:swift-evolution at swift.org>> wrote:
> Hi everyone,
>
> In the introduction to Swift <https://developer.apple.com/library/ios/documentation/Swift/Conceptual/Swift_Programming_Language/>, it is presented as an "industrial-quality systems programming language".
> According to Wikipedia <https://en.wikipedia.org/wiki/System_programming_language>, this means that I could expect to be able to write device drivers or operating systems in Swift.
>
> However it seems like this claim is only partially true, since several important low-level features seem to be completely missing:
>
> - Is it possible to generate volatile memory accesses <http://llvm.org/docs/LangRef.html#volatile-memory-accesses> in Swift? Writing device drivers is virtually impossible without a way to guarantee certain memory operations are actually made (and not optimized-out).
>
> - Is it possible to embed raw binary data in Swift? For example, an equivalent of the following C code "const int8_t foo[6] = {0x00,0x11,0x22,0x33,0x44,0x55};"? The simple Swift equivalent, "let foo: [Int8] = [0x0,0x1,0x2,0x3,0x4,0x6];" is obviously wildly different. Being able to embed raw binary data is very important in a low-level environment: for example, you may need to feed specific data to a device for an initialization sequence at a point where you don't have a filesystem available yet.
>
> There might be other aspects that I'm overlooking right now, but I think that's enough to start a discussion: is Swift really meant to be a systems programming language?
>
> Thanks,
>
> - Romain
>
> _______________________________________________
> swift-evolution mailing list
> swift-evolution at swift.org <mailto:swift-evolution at swift.org>
> https://lists.swift.org/mailman/listinfo/swift-evolution <https://lists.swift.org/mailman/listinfo/swift-evolution>
>
>
> _______________________________________________
> swift-evolution mailing list
> swift-evolution at swift.org <mailto:swift-evolution at swift.org>
> https://lists.swift.org/mailman/listinfo/swift-evolution <https://lists.swift.org/mailman/listinfo/swift-evolution>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-evolution/attachments/20160107/86788236/attachment.html>
More information about the swift-evolution
mailing list