dousao8152 2017-06-20 08:58
浏览 263
已采纳

如何在Golang中使用在汇编代码中定义的函数?

In golangs AES crypto package cipher_amd64.go makes use of functions that are defined in assembler code (asm_amd64.s). In the mentioned go file only the function headers are defined:

// defined in asm_amd64.s
func encryptBlockAsm(nr int, xk *uint32, dst, src *byte)
func decryptBlockAsm(nr int, xk *uint32, dst, src *byte)
func expandKeyAsm(nr int, key *byte, enc *uint32, dec *uint32)

How can I use these functions in my own code? Just declaring the headers and importing "crypto/aes" as in the mentioned .go file does not work (undefined: expandKeyAsm).

Thank you very much!

  • 写回答

1条回答 默认 最新

  • doubengman2072 2017-06-20 10:47
    关注
    1. Copy the asm_amd64.s contents over to your package
    2. Define the functions somewehere in that package
    3. Use those functions in the package

    Example (with the asm_amd64.s in the same package):

    package main
    
    import "fmt"
    
    func encryptBlockAsm(nr int, xk *uint32, dst, src *byte)
    func decryptBlockAsm(nr int, xk *uint32, dst, src *byte)
    func expandKeyAsm(nr int, key *byte, enc *uint32, dec *uint32)
    
    func main() {
        var nr int
        var xk uint32
        var dst byte
        var src byte
    
        fmt.Printf("Before:\t%v, %v, %v, %v
    ", nr, xk, dst, src)
    
        encryptBlockAsm(nr, &xk, &dst, &src)
    
        fmt.Printf("After:\t%v, %v, %v, %v
    ", nr, xk, dst, src)
    }
    

    Yields:

    Before: 0, 0, 0, 0
    After:  0, 0, 231, 173
    

    I have no idea what the inputs should be but at least it demonstrates this does something :)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码