APPLIES TO: 
	Oracle Database - Enterprise Edition - Version 10.2.0.1 and later 
	Information in this document applies to any platform. 
	GOAL 
	How to calculate the correct subnet to use in oifcfg, etc. 
	oifcfg requires you to enter the subnet used for public and cluster_interconnect networks. 
	However, ifconfig usually shows the IP and the netmask, but not the subnet. 
	This note will show how to determine the subnet to be used with oifcfg. 
	More generally, it also applies to the general question of determining the subnet for a given interface, given the IP address and netmask. 
	SOLUTION 
	Suppose that the interface to be used for public network is e1000g0 with ip address 171.197.26.137 and netmask ffffffc0. 
	
	In ifconfig -a output we will see this: 
	
	e1000g0: 
	flags=209040843 
	mtu 1500 index 2 
	inet 171.197.26.137 netmask ffffffc0 broadcast 171.197.26.191 
	groupname prod 
	ether 0:14:4f:95:39:9a 
	
	
	Note that the netmask is displayed as ffffffc0 in hex. (In some platforms it is displayed in decimal rather than hex.) 
	This netmask ffffffc0 = ff.ff.ff.c0 = 255.255.255.192 . 
	In binary notation this is 11111111.11111111.11111111.11000000 
	
	Another common way you may see to represent the netmask is as a simple 2-digit number like "26", to get this number, simply add up the digits:  
	
	11111111.11111111.11111111.11000000 
	=> (1+1+1+1+1+1+1+1) + (1+1+1+1+1+1+1+1) + (1+1+1+1+1+1+1+1) + (1+1+0+0+0+0+0+0) 
	= 8+8+8+2 = 26 
	
	A fast way to find the subnet, given the network address (171.197.26.137) and the netmask (255.255.255.192), is to use an IP calculator. 
	Free IP calculators are available online. In this example, I used the calculator at http://jodies.de/ipcalc. Many others are available. 
	
	Plugging the address (171.197.26.137) and the netmask (255.255.255.192) into the calculator at http://jodies.de/ipcalc gives this output: 
	
	Result: 
	Address:  171.197. 26.137       10101011.11000101.00011010.10 001001 
	Netmask:  255.255.255.192 = 26  11111111.11111111.11111111.11 000000 
	Wildcard:   0.  0.  0. 63       00000000.00000000.00000000.00 111111 
	=> 
	Network:  171.197. 26.128/26    10101011.11000101.00011010.10 000000 (Class B) 
	Broadcast:171.197. 26.191       10101011.11000101.00011010.10 111111 
	HostMin:  171.197. 26.129       10101011.11000101.00011010.10 000001 
	HostMax:  171.197. 26.190       10101011.11000101.00011010.10 111110 
	Hosts/Net: 62 
	
	=> note how that gives the network 171.197.26.128/26 
	Ignore the /26 in this output, the "subnet" needed for oifcfg is 171.197.26.128. 
	
	Another way to get this information is to do a bit-AND on each bit of the address and netmask: 
	
	171.197. 26.137 => 10101011.11000101.00011010.10 001001 
	255.255.255.192 => 11111111.11111111.11111111.11 000000 
	                 & ------------------------------------  
	                   10101011.11000101.00011010.10 000000 => 171.197.26.128 
	
	
	Yet another way to get this information is from oifcfg itself. 
	The command oifcfg iflist shows the interface name and subnet for each interface: 
	
	$ ./oifcfg iflist 
	e1000g0 171.197.26.128 
	e1000g2 171.197.26.128 
	e1000g3 10.241.6.0 
	
	So now you see where that 128 is coming from in oifcfg iflist. For each interface, oifcfg iflist shows the subnet for that interface. 
	
	So to enter this into oifcfg as the public network, you would use this syntax: 
	
	oifcfg setif -global e1000g0/171.197.26.128:public