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 :)

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

报告相同问题?

悬赏问题

  • ¥15 django项目运行报编码错误
  • ¥15 请问这个是什么意思?
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流
  • ¥15 Rstudio 保存代码闪退