⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mul_1.c

📁 一个C源代码分析器
💻 C
字号:
/* __mpn_mul_1 -- Multiply a limb vector with a single limb and   store the product in a second limb vector.Copyright (C) 1991, 1992, 1993, 1994 Free Software Foundation, Inc.This file is part of the GNU MP Library.The GNU MP Library is free software; you can redistribute it and/or modifyit under the terms of the GNU Library General Public License as published bythe Free Software Foundation; either version 2 of the License, or (at youroption) any later version.The GNU MP Library is distributed in the hope that it will be useful, butWITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITYor FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Library General PublicLicense for more details.You should have received a copy of the GNU Library General Public Licensealong with the GNU MP Library; see the file COPYING.LIB.  If not, write tothe Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */#include "gmp.h"#include "gmp-impl.h"#include "longlong.h"mp_limb__mpn_mul_1 (res_ptr, s1_ptr, s1_size, s2_limb)     register mp_ptr res_ptr;     register mp_srcptr s1_ptr;     mp_size_t s1_size;     register mp_limb s2_limb;{  register mp_limb cy_limb;  register mp_size_t j;  register mp_limb prod_high, prod_low;  /* The loop counter and index J goes from -S1_SIZE to -1.  This way     the loop becomes faster.  */  j = -s1_size;  /* Offset the base pointers to compensate for the negative indices.  */  s1_ptr -= j;  res_ptr -= j;  cy_limb = 0;  do    {      umul_ppmm (prod_high, prod_low, s1_ptr[j], s2_limb);      prod_low += cy_limb;      cy_limb = (prod_low < cy_limb) + prod_high;      res_ptr[j] = prod_low;    }  while (++j != 0);  return cy_limb;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -