forked from sangge/tpre-python
		
	main #24
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -11,3 +11,4 @@ src/temp_key_file | |||||||
| src/client.db | src/client.db | ||||||
| src/server.db | src/server.db | ||||||
| build | build | ||||||
|  | src/tpre.cpython-311-x86_64-linux-gnu.so | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								include/tpre.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								include/tpre.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | #ifndef tpre_SM2_H | ||||||
|  | #define tpre_SM2_H | ||||||
|  |  | ||||||
|  | #include <Python.h> | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  |  | ||||||
|  | // define TPRE Big Number | ||||||
|  | typedef uint64_t TPRE_BN[8] | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // GF(p) | ||||||
|  | typedef TPRE_BN SM2_Fp; | ||||||
|  |  | ||||||
|  | // GF(n) | ||||||
|  | typedef TPRE_BN SM2_Fn; | ||||||
|  |  | ||||||
|  | // 定义一个结构体来表示雅各比坐标系的点 | ||||||
|  | typedef struct | ||||||
|  | { | ||||||
|  |     TPRE_BN X; | ||||||
|  |     TPRE_BN Y; | ||||||
|  |     TPRE_BN Z; | ||||||
|  | } JACOBIAN_POINT; | ||||||
|  |  | ||||||
|  | // 定义一个结构体来表示点 | ||||||
|  | typedef struct | ||||||
|  | { | ||||||
|  |     uint8_t x[32]; | ||||||
|  |     uint8_t y[32]; | ||||||
|  | } TPRE_POINT; | ||||||
							
								
								
									
										11
									
								
								src/setup.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/setup.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | from setuptools import setup, Extension | ||||||
|  |  | ||||||
|  | # 定义您的扩展 | ||||||
|  | ext = Extension("tpre", sources=["tpre.c"]) | ||||||
|  |  | ||||||
|  | setup( | ||||||
|  |     name="tpre", | ||||||
|  |     version="1.0", | ||||||
|  |     description="tpre written in C", | ||||||
|  |     ext_modules=[ext], | ||||||
|  | ) | ||||||
							
								
								
									
										138
									
								
								src/tpre.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								src/tpre.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | |||||||
|  | #include <Python.h> | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include "../include/tpre.h" | ||||||
|  |  | ||||||
|  | const SM2_BN SM2_P = { | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0x00000000, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xfffffffe, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const SM2_BN SM2_B = { | ||||||
|  |     0x4d940e93, | ||||||
|  |     0xddbcbd41, | ||||||
|  |     0x15ab8f92, | ||||||
|  |     0xf39789f5, | ||||||
|  |     0xcf6509a7, | ||||||
|  |     0x4d5a9e4b, | ||||||
|  |     0x9d9f5e34, | ||||||
|  |     0x28e9fa9e, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const SM2_JACOBIAN_POINT _SM2_G = { | ||||||
|  |     { | ||||||
|  |         0x334c74c7, | ||||||
|  |         0x715a4589, | ||||||
|  |         0xf2660be1, | ||||||
|  |         0x8fe30bbf, | ||||||
|  |         0x6a39c994, | ||||||
|  |         0x5f990446, | ||||||
|  |         0x1f198119, | ||||||
|  |         0x32c4ae2c, | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         0x2139f0a0, | ||||||
|  |         0x02df32e5, | ||||||
|  |         0xc62a4740, | ||||||
|  |         0xd0a9877c, | ||||||
|  |         0x6b692153, | ||||||
|  |         0x59bdcee3, | ||||||
|  |         0xf4f6779c, | ||||||
|  |         0xbc3736a2, | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |     }, | ||||||
|  | }; | ||||||
|  | const SM2_JACOBIAN_POINT *SM2_G = &_SM2_G; | ||||||
|  |  | ||||||
|  | const SM2_BN SM2_N = { | ||||||
|  |     0x39d54123, | ||||||
|  |     0x53bbf409, | ||||||
|  |     0x21c6052b, | ||||||
|  |     0x7203df6b, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xfffffffe, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // u = (p - 1)/4, u + 1 = (p + 1)/4 | ||||||
|  | const SM2_BN SM2_U_PLUS_ONE = { | ||||||
|  |     0x00000000, | ||||||
|  |     0x40000000, | ||||||
|  |     0xc0000000, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xffffffff, | ||||||
|  |     0xbfffffff, | ||||||
|  |     0x3fffffff, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const SM2_BN SM2_ONE = {1, 0, 0, 0, 0, 0, 0, 0}; | ||||||
|  | const SM2_BN SM2_TWO = {2, 0, 0, 0, 0, 0, 0, 0}; | ||||||
|  | const SM2_BN SM2_THREE = {3, 0, 0, 0, 0, 0, 0, 0}; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // 将Python中的multiply函数转换为C | ||||||
|  | static Point multiply(Point a, int64_t n) | ||||||
|  | { | ||||||
|  |     Point result; | ||||||
|  |     // ...实现乘法逻辑... | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Python接口函数 | ||||||
|  | static PyObject *py_multiply(PyObject *self, PyObject *args) | ||||||
|  | { | ||||||
|  |     Point a; | ||||||
|  |     int64_t n; | ||||||
|  |  | ||||||
|  |     // 从Python参数解析值到C变量 | ||||||
|  |     if (!PyArg_ParseTuple(args, "(ll)l", &a.x, &a.y, &n)) | ||||||
|  |     { | ||||||
|  |         return NULL; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Point result = multiply(a, n); | ||||||
|  |  | ||||||
|  |     // 将C结构体的结果转换回Python对象 | ||||||
|  |     return Py_BuildValue("(ll)", result.x, result.y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // 模块方法定义 | ||||||
|  | static PyMethodDef MyMethods[] = { | ||||||
|  |     {"multiply", py_multiply, METH_VARARGS, "Multiply a point on the curve by a scalar"}, | ||||||
|  |     {NULL, NULL, 0, NULL} // 哨兵 | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // 模块定义 | ||||||
|  | static struct PyModuleDef tpre = { | ||||||
|  |     PyModuleDef_HEAD_INIT, | ||||||
|  |     "tpre", | ||||||
|  |     NULL, // 模块文档 | ||||||
|  |     -1, | ||||||
|  |     MyMethods}; | ||||||
|  |  | ||||||
|  | // 初始化模块 | ||||||
|  | PyMODINIT_FUNC PyInit_tpre(void) | ||||||
|  | { | ||||||
|  |     return PyModule_Create(&tpre); | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user