Which operating systems for 80286 computers allowsed a process to use more than 128k data?
Clash Royale CLAN TAG#URR8PPP
up vote
2
down vote
favorite
Out of all operating systems for the 80286 processor I found, only two make use of the protected mode's ability to load more than one segment for text and one for data. These are MS DOS (through various DOS extenders) and Windows. All other operating systems I checked would only give one text segment and one data segment to each process and call it a day. Were there any other operating systems that made full use of protected mode segmentation on the 80286?
operating-system 80286 segmentation
add a comment |Â
up vote
2
down vote
favorite
Out of all operating systems for the 80286 processor I found, only two make use of the protected mode's ability to load more than one segment for text and one for data. These are MS DOS (through various DOS extenders) and Windows. All other operating systems I checked would only give one text segment and one data segment to each process and call it a day. Were there any other operating systems that made full use of protected mode segmentation on the 80286?
operating-system 80286 segmentation
I can find a lot of sources that strongly imply that MINIX is an answer, but none that is a smoking gun. Certainly there is a whole-system limit of 16mb but confirmation of per-process limits so far eludes me. Maybe somebody else can help?
â Tommy
59 mins ago
1
@Tommy Minix is not the answer as far as I'm concerned. On Minix, each process has one text and one data/stack segment. Segment sizes are fixed at link time and can be changed by thechmem
utility to give programs more space. It's not possible to change segment sizes at runtime, there isn't even abrk
syscall!
â fuz
56 mins ago
you have definitively stomped on that suggestion. I'll wager there's at least one CP/M-86 program that just runs away with the environment and thereby is as valid an answer as DOS, but that also feels like a cheat. It'd be interesting to know what VisiOn does given that programs are interpreted, not natively compiled.
â Tommy
49 mins ago
1
What about Xenix 286?
â mannaggia
28 mins ago
add a comment |Â
up vote
2
down vote
favorite
up vote
2
down vote
favorite
Out of all operating systems for the 80286 processor I found, only two make use of the protected mode's ability to load more than one segment for text and one for data. These are MS DOS (through various DOS extenders) and Windows. All other operating systems I checked would only give one text segment and one data segment to each process and call it a day. Were there any other operating systems that made full use of protected mode segmentation on the 80286?
operating-system 80286 segmentation
Out of all operating systems for the 80286 processor I found, only two make use of the protected mode's ability to load more than one segment for text and one for data. These are MS DOS (through various DOS extenders) and Windows. All other operating systems I checked would only give one text segment and one data segment to each process and call it a day. Were there any other operating systems that made full use of protected mode segmentation on the 80286?
operating-system 80286 segmentation
operating-system 80286 segmentation
asked 1 hour ago
fuz
447416
447416
I can find a lot of sources that strongly imply that MINIX is an answer, but none that is a smoking gun. Certainly there is a whole-system limit of 16mb but confirmation of per-process limits so far eludes me. Maybe somebody else can help?
â Tommy
59 mins ago
1
@Tommy Minix is not the answer as far as I'm concerned. On Minix, each process has one text and one data/stack segment. Segment sizes are fixed at link time and can be changed by thechmem
utility to give programs more space. It's not possible to change segment sizes at runtime, there isn't even abrk
syscall!
â fuz
56 mins ago
you have definitively stomped on that suggestion. I'll wager there's at least one CP/M-86 program that just runs away with the environment and thereby is as valid an answer as DOS, but that also feels like a cheat. It'd be interesting to know what VisiOn does given that programs are interpreted, not natively compiled.
â Tommy
49 mins ago
1
What about Xenix 286?
â mannaggia
28 mins ago
add a comment |Â
I can find a lot of sources that strongly imply that MINIX is an answer, but none that is a smoking gun. Certainly there is a whole-system limit of 16mb but confirmation of per-process limits so far eludes me. Maybe somebody else can help?
â Tommy
59 mins ago
1
@Tommy Minix is not the answer as far as I'm concerned. On Minix, each process has one text and one data/stack segment. Segment sizes are fixed at link time and can be changed by thechmem
utility to give programs more space. It's not possible to change segment sizes at runtime, there isn't even abrk
syscall!
â fuz
56 mins ago
you have definitively stomped on that suggestion. I'll wager there's at least one CP/M-86 program that just runs away with the environment and thereby is as valid an answer as DOS, but that also feels like a cheat. It'd be interesting to know what VisiOn does given that programs are interpreted, not natively compiled.
â Tommy
49 mins ago
1
What about Xenix 286?
â mannaggia
28 mins ago
I can find a lot of sources that strongly imply that MINIX is an answer, but none that is a smoking gun. Certainly there is a whole-system limit of 16mb but confirmation of per-process limits so far eludes me. Maybe somebody else can help?
â Tommy
59 mins ago
I can find a lot of sources that strongly imply that MINIX is an answer, but none that is a smoking gun. Certainly there is a whole-system limit of 16mb but confirmation of per-process limits so far eludes me. Maybe somebody else can help?
â Tommy
59 mins ago
1
1
@Tommy Minix is not the answer as far as I'm concerned. On Minix, each process has one text and one data/stack segment. Segment sizes are fixed at link time and can be changed by the
chmem
utility to give programs more space. It's not possible to change segment sizes at runtime, there isn't even a brk
syscall!â fuz
56 mins ago
@Tommy Minix is not the answer as far as I'm concerned. On Minix, each process has one text and one data/stack segment. Segment sizes are fixed at link time and can be changed by the
chmem
utility to give programs more space. It's not possible to change segment sizes at runtime, there isn't even a brk
syscall!â fuz
56 mins ago
you have definitively stomped on that suggestion. I'll wager there's at least one CP/M-86 program that just runs away with the environment and thereby is as valid an answer as DOS, but that also feels like a cheat. It'd be interesting to know what VisiOn does given that programs are interpreted, not natively compiled.
â Tommy
49 mins ago
you have definitively stomped on that suggestion. I'll wager there's at least one CP/M-86 program that just runs away with the environment and thereby is as valid an answer as DOS, but that also feels like a cheat. It'd be interesting to know what VisiOn does given that programs are interpreted, not natively compiled.
â Tommy
49 mins ago
1
1
What about Xenix 286?
â mannaggia
28 mins ago
What about Xenix 286?
â mannaggia
28 mins ago
add a comment |Â
1 Answer
1
active
oldest
votes
up vote
3
down vote
OS/2 supported âÂÂhuge memoryâ on 286s. Using the DosAllocHuge
function, programs could allocate more than 64KiB of memory, and would get a sequence of segment selectors which could be used to easily access all the allocated memory. The process is detailed in section 9.2.2 of Gordon LetwinâÂÂs Inside OS/2.
Xenix 286 also supported multiple text and data segments; processes with multiple segments were called âÂÂlarge model processesâ (the same terminology as was used with C compilers under DOS). See Overview of the Xenix 286 Operating System.
FlexOS 286 (and perhaps Concurrent DOS 286) also allowed programs to allocate multiple segments. malloc
could only allocate up to 64KiB at once, but programs could call it multiple times to allocate more than 64KiB in total in multiple segments.
I suspected Coherent 3 might have supported multiple segments, but it turns out thatâÂÂs not the case, at least according to the Coherent 3.2 FAQ (question 7).
Oh yeah, I totally forgot about OS/2. Any others you know of?
â fuz
41 mins ago
add a comment |Â
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
3
down vote
OS/2 supported âÂÂhuge memoryâ on 286s. Using the DosAllocHuge
function, programs could allocate more than 64KiB of memory, and would get a sequence of segment selectors which could be used to easily access all the allocated memory. The process is detailed in section 9.2.2 of Gordon LetwinâÂÂs Inside OS/2.
Xenix 286 also supported multiple text and data segments; processes with multiple segments were called âÂÂlarge model processesâ (the same terminology as was used with C compilers under DOS). See Overview of the Xenix 286 Operating System.
FlexOS 286 (and perhaps Concurrent DOS 286) also allowed programs to allocate multiple segments. malloc
could only allocate up to 64KiB at once, but programs could call it multiple times to allocate more than 64KiB in total in multiple segments.
I suspected Coherent 3 might have supported multiple segments, but it turns out thatâÂÂs not the case, at least according to the Coherent 3.2 FAQ (question 7).
Oh yeah, I totally forgot about OS/2. Any others you know of?
â fuz
41 mins ago
add a comment |Â
up vote
3
down vote
OS/2 supported âÂÂhuge memoryâ on 286s. Using the DosAllocHuge
function, programs could allocate more than 64KiB of memory, and would get a sequence of segment selectors which could be used to easily access all the allocated memory. The process is detailed in section 9.2.2 of Gordon LetwinâÂÂs Inside OS/2.
Xenix 286 also supported multiple text and data segments; processes with multiple segments were called âÂÂlarge model processesâ (the same terminology as was used with C compilers under DOS). See Overview of the Xenix 286 Operating System.
FlexOS 286 (and perhaps Concurrent DOS 286) also allowed programs to allocate multiple segments. malloc
could only allocate up to 64KiB at once, but programs could call it multiple times to allocate more than 64KiB in total in multiple segments.
I suspected Coherent 3 might have supported multiple segments, but it turns out thatâÂÂs not the case, at least according to the Coherent 3.2 FAQ (question 7).
Oh yeah, I totally forgot about OS/2. Any others you know of?
â fuz
41 mins ago
add a comment |Â
up vote
3
down vote
up vote
3
down vote
OS/2 supported âÂÂhuge memoryâ on 286s. Using the DosAllocHuge
function, programs could allocate more than 64KiB of memory, and would get a sequence of segment selectors which could be used to easily access all the allocated memory. The process is detailed in section 9.2.2 of Gordon LetwinâÂÂs Inside OS/2.
Xenix 286 also supported multiple text and data segments; processes with multiple segments were called âÂÂlarge model processesâ (the same terminology as was used with C compilers under DOS). See Overview of the Xenix 286 Operating System.
FlexOS 286 (and perhaps Concurrent DOS 286) also allowed programs to allocate multiple segments. malloc
could only allocate up to 64KiB at once, but programs could call it multiple times to allocate more than 64KiB in total in multiple segments.
I suspected Coherent 3 might have supported multiple segments, but it turns out thatâÂÂs not the case, at least according to the Coherent 3.2 FAQ (question 7).
OS/2 supported âÂÂhuge memoryâ on 286s. Using the DosAllocHuge
function, programs could allocate more than 64KiB of memory, and would get a sequence of segment selectors which could be used to easily access all the allocated memory. The process is detailed in section 9.2.2 of Gordon LetwinâÂÂs Inside OS/2.
Xenix 286 also supported multiple text and data segments; processes with multiple segments were called âÂÂlarge model processesâ (the same terminology as was used with C compilers under DOS). See Overview of the Xenix 286 Operating System.
FlexOS 286 (and perhaps Concurrent DOS 286) also allowed programs to allocate multiple segments. malloc
could only allocate up to 64KiB at once, but programs could call it multiple times to allocate more than 64KiB in total in multiple segments.
I suspected Coherent 3 might have supported multiple segments, but it turns out thatâÂÂs not the case, at least according to the Coherent 3.2 FAQ (question 7).
edited 2 mins ago
answered 42 mins ago
Stephen Kitt
32.3k4130150
32.3k4130150
Oh yeah, I totally forgot about OS/2. Any others you know of?
â fuz
41 mins ago
add a comment |Â
Oh yeah, I totally forgot about OS/2. Any others you know of?
â fuz
41 mins ago
Oh yeah, I totally forgot about OS/2. Any others you know of?
â fuz
41 mins ago
Oh yeah, I totally forgot about OS/2. Any others you know of?
â fuz
41 mins ago
add a comment |Â
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fretrocomputing.stackexchange.com%2fquestions%2f8097%2fwhich-operating-systems-for-80286-computers-allowsed-a-process-to-use-more-than%23new-answer', 'question_page');
);
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
I can find a lot of sources that strongly imply that MINIX is an answer, but none that is a smoking gun. Certainly there is a whole-system limit of 16mb but confirmation of per-process limits so far eludes me. Maybe somebody else can help?
â Tommy
59 mins ago
1
@Tommy Minix is not the answer as far as I'm concerned. On Minix, each process has one text and one data/stack segment. Segment sizes are fixed at link time and can be changed by the
chmem
utility to give programs more space. It's not possible to change segment sizes at runtime, there isn't even abrk
syscall!â fuz
56 mins ago
you have definitively stomped on that suggestion. I'll wager there's at least one CP/M-86 program that just runs away with the environment and thereby is as valid an answer as DOS, but that also feels like a cheat. It'd be interesting to know what VisiOn does given that programs are interpreted, not natively compiled.
â Tommy
49 mins ago
1
What about Xenix 286?
â mannaggia
28 mins ago