Saltar al contenido

Modo operativo de CPU de 32 bits y 64 bits en Linux

Nuestro grupo de trabajo ha pasado mucho tiempo buscando para darle respuesta a tu interrogante, te compartimos la solución por esto nuestro objetivo es servirte de mucha apoyo.

Solución:

lscpu le está diciendo que su arquitectura es i686 (una CPU Intel de 32 bits) y que su CPU admite los modos de funcionamiento de 32 y 64 bits. No podrá instalar aplicaciones creadas para x64, ya que están diseñadas específicamente para arquitecturas x64.

Su CPU particular puede manejar los paquetes integrados i386 o i686. Hay varias formas de verificar su arquitectura y preferencias de sistema operativo.

lscpu

Como ya sabe, puede usar el comando lscpu. Funciona bien para darte una idea aproximada de lo que es capaz de hacer tu CPU.

$ lscpu
Architecture:          x86_64
CPU op-mode(s):        32-bit, 64-bit
CPU(s):                4
Thread(s) per core:    2
Core(s) per socket:    2
CPU socket(s):         1
NUMA node(s):          1
Vendor ID:             GenuineIntel
CPU family:            6
Model:                 37
Stepping:              5
CPU MHz:               1199.000
Virtualization:        VT-x
L1d cache:             32K
L1i cache:             32K
L2 cache:              256K
L3 cache:              3072K
NUMA node0 CPU(s):     0-3

/ proc / cpuinfo

En realidad, estos son los datos proporcionados por el kernel que la mayoría de las herramientas, como lscpu utilizar para mostrar. Encuentro este resultado un poco agradable en el hecho de que le muestra información sobre el número de modelo de su CPU en particular. También le mostrará una sección para cada núcleo que pueda tener su CPU.

Aquí está la salida para un solo núcleo:

$ cat /proc/cpuinfo 
processor   : 0
vendor_id   : GenuineIntel
cpu family  : 6
model       : 37
model name  : Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz
stepping    : 5
cpu MHz     : 1466.000
cache size  : 3072 KB
physical id : 0
siblings    : 4
core id     : 0
cpu cores   : 2
apicid      : 0
initial apicid  : 0
fpu     : yes
fpu_exception   : yes
cpuid level : 11
wp      : yes
flags       : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx rdtscp lm constant_tsc arch_perfmon pebs bts rep_good xtopology nonstop_tsc aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm sse4_1 sse4_2 popcnt aes lahf_lm ida arat tpr_shadow vnmi flexpriority ept vpid
bogomips    : 5319.74
clflush size    : 64
cache_alignment : 64
address sizes   : 36 bits physical, 48 bits virtual
power management:

Así es como se ven las primeras 3 líneas de cada sección para un núcleo:

$ grep processor -A 3 /proc/cpuinfo
processor   : 0
vendor_id   : GenuineIntel
cpu family  : 6
model       : 37
--
processor   : 1
vendor_id   : GenuineIntel
cpu family  : 6
model       : 37
--
processor   : 2
vendor_id   : GenuineIntel
cpu family  : 6
model       : 37
--
processor   : 3
vendor_id   : GenuineIntel
cpu family  : 6
model       : 37

La salida de /proc/cpuinfo también puede decirle el tipo de arquitectura que su CPU está proporcionando a través de los distintos indicadores que muestra. Observe estas líneas del comando anterior:

$ grep /proc/cpuinfo | head -1
    flags       : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx rdtscp lm constant_tsc arch_perfmon pebs bts rep_good xtopology nonstop_tsc aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm sse4_1 sse4_2 popcnt aes lahf_lm ida arat tpr_shadow vnmi flexpriority ept vpid

Las banderas que terminan en _lm decirle que su procesador admite “modo largo”. El modo largo es otro nombre para 64 bits.

tu nombre

Este comando se puede usar para determinar qué plataforma fue construida para soportar su kernel. Por ejemplo:

Kernel de 64 bits

$ uname -a
Linux grinchy 2.6.35.14-106.fc14.x86_64 #1 SMP Wed Nov 23 13:07:52 UTC 2011 x86_64 x86_64 x86_64 GNU/Linux

Kernel de 32 bits

$ uname -a
Linux skinner.bubba.net 2.6.18-238.19.1.el5.centos.plus #1 SMP Mon Jul 18 10:07:01 EDT 2011 i686 i686 i386 GNU/Linux

Esta salida se puede refinar un poco más usando los interruptores, [-m|--machine], [-p|--processor], y [-i|--hardware-platform].

Aquí está la salida para los mismos sistemas anteriores.

64 bits

$ uname -m; uname -p; uname -i
x86_64
x86_64
x86_64

32 bits

$ uname -m; uname -p; uname -i
i686
i686
i386

NOTA: También hay una versión abreviada de uname -m que puede ejecutar como un comando independiente, arch. Devuelve exactamente lo mismo que uname -m. Puede leer más sobre el arch comando en la documentación de coreutils.

extracto

arch imprime el nombre del hardware de la máquina y es equivalente a ‘uname -m’.

hwinfo

Probablemente la mejor herramienta para analizar su hardware tiene que ser hwinfo. Este paquete puede mostrarle prácticamente cualquier cosa que desee / necesite saber sobre su hardware, directamente desde la terminal. Me ha ahorrado docenas de veces cuando necesitaba información de un chip en la placa base de un sistema o necesitaba conocer la revisión de una placa en una ranura PCI.

Puede consultarlo contra los diferentes subsistemas de una computadora. En nuestro caso, veremos el cpu subsistema.

$ hwinfo --cpu
01: None 00.0: 10103 CPU                                        
  [Created at cpu.301]
  Unique ID: rdCR.a2KaNXABdY4
  Hardware Class: cpu
  Arch: X86-64
  Vendor: "GenuineIntel"
  Model: 6.37.5 "Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz"
  Features: fpu,vme,de,pse,tsc,msr,pae,mce,cx8,apic,sep,mtrr,pge,mca,cmov,pat,pse36,clflush,dts,acpi,mmx,fxsr,sse,sse2,ss,ht,tm,pbe,syscall,nx,rdtscp,lm,constant_tsc,arch_perfmon,pebs,bts,rep_good,xtopology,nonstop_tsc,aperfmperf,pni,pclmulqdq,dtes64,monitor,ds_cpl,vmx,smx,est,tm2,ssse3,cx16,xtpr,pdcm,sse4_1,sse4_2,popcnt,aes,lahf_lm,ida,arat,tpr_shadow,vnmi,flexpriority,ept,vpid
  Clock: 2666 MHz
  BogoMips: 5319.74
  Cache: 3072 kb
  Units/Processor: 16
  Config Status: cfg=new, avail=yes, need=no, active=unknown

De nuevo, similar a /proc/cpuinfo este comando le muestra la composición de cada núcleo individual en un sistema de múltiples núcleos. Aquí está la primera línea de cada sección de un núcleo, solo para darle una idea.

$ hwinfo --cpu | grep CPU
01: None 00.0: 10103 CPU
  Model: 6.37.5 "Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz"
02: None 01.0: 10103 CPU
  Model: 6.37.5 "Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz"
03: None 02.0: 10103 CPU
  Model: 6.37.5 "Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz"
04: None 03.0: 10103 CPU
  Model: 6.37.5 "Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz"

getconf

Esta es probablemente la forma más obvia de saber qué arquitectura presenta su CPU al sistema operativo. Haciendo uso de getconf, su consulta de la variable de sistema LONG_BIT. Esta no es una variable de entorno.

# 64-bit system
$ getconf LONG_BIT
64

# 32-bit system
$ getconf LONG_BIT
32

lshw

Otra herramienta más, similar en capacidades a hwinfo. Puede consultar prácticamente cualquier cosa que desee saber sobre el hardware subyacente. Por ejemplo:

# 64-bit Kernel
$ lshw -class cpu
  *-cpu                   
   description: CPU
   product: Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz
   vendor: Intel Corp.
   physical id: 6
   bus info: [email protected]
   version: Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz
   slot: None
   size: 1199MHz
   capacity: 1199MHz
   width: 64 bits
   clock: 133MHz
   capabilities: fpu fpu_exception wp vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx rdtscp x86-64 constant_tsc arch_perfmon pebs bts rep_good xtopology nonstop_tsc aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm sse4_1 sse4_2 popcnt aes lahf_lm ida arat tpr_shadow vnmi flexpriority ept vpid cpufreq
   configuration: cores=2 enabledcores=2 threads=4


# 32-bit Kernel
$ lshw -class cpu
  *-cpu:0
   description: CPU
   product: Intel(R) Core(TM)2 CPU          4300  @ 1.80GHz
   vendor: Intel Corp.
   physical id: 400
   bus info: [email protected]
   version: 6.15.2
   serial: 0000-06F2-0000-0000-0000-0000
   slot: Microprocessor
   size: 1800MHz
   width: 64 bits
   clock: 800MHz
   capabilities: boot fpu fpu_exception wp vme de pse tsc msr pae mce cx8 apic mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe x86-64 constant_tsc pni monitor ds_cpl est tm2 ssse3 cx16 xtpr lahf_lm
   configuration: id=1
 *-logicalcpu:0
      description: Logical CPU
      physical id: 1.1
      width: 64 bits
      capabilities: logical
 *-logicalcpu:1
      description: Logical CPU
      physical id: 1.2
      width: 64 bits
      capabilities: logical

Modo (s) de operación de la CPU?

Varios de los comandos informan que lo que parece ser una CPU de 32 bits admite modos de 32 y 64 bits. Esto puede ser un poco confuso y engañoso, pero si comprende la historia de las CPU, Intel específicamente, sabrá que tienen un historial de juegos con sus productos donde una CPU puede tener un conjunto de instrucciones que admite 16 bits, pero puede direccionar más RAM que 2 ^ 16.

Lo mismo ocurre con estas CPU. La mayoría de la gente sabe que una CPU de 32 bits solo puede direccionar 2 ^ 32 = 4 GB de RAM. Pero hay versiones de CPU que pueden abordar más. Estas CPU a menudo utilizarían un kernel de Linux con el sufijo PAE – Extensión de dirección física. El uso de un kernel habilitado para PAE junto con este hardware le permitiría direccionar hasta 64 GB en un sistema de 32 bits.

Podrías pensar bien, entonces, ¿por qué necesito una arquitectura de 64 bits? El problema con estas CPU es que el espacio de un solo proceso está limitado a 2 ^ 32, por lo que si tiene un gran programa de simulación o computacional que necesita más de 2 ^ 32 de espacio direccionable en la RAM, entonces esto no le habría ayudado con ese.

Eche un vistazo a la página de wikipedia sobre la microarquitectura P6 (i686) para obtener más información.

TL; DR – Entonces, ¿cuál es la arquitectura de mi CPU?

En general, puede resultar confuso porque varios de los comandos y metodologías anteriores utilizan el término “arquitectura” de manera flexible. Si está interesado en saber si el sistema operativo subyacente es de 32 bits o de 64 bits, utilice estos comandos:

  • lscpu
  • getconf LONG_BIT
  • tu nombre

Si, por otro lado, desea conocer la arquitectura de la CPU, utilice estos comandos:

  • / proc / cpuinfo
  • hwinfo
  • lshw

Específicamente, desea buscar campos donde diga cosas como “ancho: 64” o “ancho: 32” si está utilizando una herramienta como lshw, o busque las banderas:

  • lm: Modo largo (x86-64: amd64, también conocido como Intel 64, es decir, con capacidad de 64 bits)
  • lahf_lm: LAHF / SAHF en modo largo

Los presentes de estos 2 indicadores le dicen que la CPU es de 64 bits. Sus ausencias te dicen que es de 32 bits.

Consulte estas URL para obtener información adicional sobre los indicadores de la CPU.

  • ¿Qué significan las banderas en / proc / cpuinfo?
  • Indicadores de funciones de la CPU y sus significados

Referencias

páginas man

  • página de manual de lscpu
  • / proc / cpuinfo página de referencia
  • página de manual de uname
  • página de manual de hwinfo
  • página de manual de getconf

artículos:

  • Compruebe si una máquina funciona con un procesador / sistema operativo Linux de 64 o 32 bits.
  • Descubra si el procesador es de 32 bits o 64 (Linux)
  • Necesita ayuda: comprobación de 32 bits / 64 bits para Linux

Si su kernel es un kernel de Linux de 32 bits, no podrá ejecutar programas de 64 bits, incluso si su procesador lo admite.

Instale un kernel de 64 bits (y todo el sistema operativo, por supuesto) para ejecutar 64 bits

Para completar: dado que en la mayoría de las arquitecturas de 64 bits es posible ejecutar código de 32 bits, tanto en el espacio del kernel como en el espacio del usuario, no se debe olvidar que en realidad hay 4 combinaciones posibles:

  • Espacio de usuario de 32 bits en un kernel de 32 bits
  • Espacio de usuario de 64 bits en un kernel de 64 bits
  • Espacio de usuario de 32 bits en un kernel de 64 bits
  • ambos Espacio (s) de usuario de 64 y 32 bits en un kernel de 64 bits

uname es la forma habitual de determinar la variante del kernel. Para el espacio de usuario, file es bastante bueno para reconocer ejecutables: file $SHELL o file /sbin/init son modismos convenientes. Solo la existencia de ambos/lib/*.soy/lib64/*.so Por lo general, es una buena indicación de que el sistema tiene ambas variantes de espacio de usuario.

Sección de Reseñas y Valoraciones

Al final de todo puedes encontrar las aclaraciones de otros gestores de proyectos, tú de igual manera tienes el poder insertar el tuyo si te apetece.

¡Haz clic para puntuar esta entrada!
(Votos: 0 Promedio: 0)



Utiliza Nuestro Buscador

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *